14d3c95f5SJorgen Lundman /*
24d3c95f5SJorgen Lundman * GRUB -- GRand Unified Bootloader
34d3c95f5SJorgen Lundman * Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc.
44d3c95f5SJorgen Lundman *
5*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+
64d3c95f5SJorgen Lundman */
74d3c95f5SJorgen Lundman /*
84d3c95f5SJorgen Lundman * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
94d3c95f5SJorgen Lundman * Use is subject to license terms.
104d3c95f5SJorgen Lundman */
114d3c95f5SJorgen Lundman
124d3c95f5SJorgen Lundman #include <common.h>
134d3c95f5SJorgen Lundman #include <malloc.h>
144d3c95f5SJorgen Lundman #include <linux/stat.h>
154d3c95f5SJorgen Lundman #include <linux/time.h>
164d3c95f5SJorgen Lundman #include <linux/ctype.h>
174d3c95f5SJorgen Lundman #include <asm/byteorder.h>
184d3c95f5SJorgen Lundman #include "zfs_common.h"
194d3c95f5SJorgen Lundman
204d3c95f5SJorgen Lundman #include <zfs/zfs.h>
214d3c95f5SJorgen Lundman #include <zfs/zio.h>
224d3c95f5SJorgen Lundman #include <zfs/dnode.h>
234d3c95f5SJorgen Lundman #include <zfs/uberblock_impl.h>
244d3c95f5SJorgen Lundman #include <zfs/vdev_impl.h>
254d3c95f5SJorgen Lundman #include <zfs/zio_checksum.h>
264d3c95f5SJorgen Lundman #include <zfs/zap_impl.h>
274d3c95f5SJorgen Lundman #include <zfs/zap_leaf.h>
284d3c95f5SJorgen Lundman #include <zfs/zfs_znode.h>
294d3c95f5SJorgen Lundman #include <zfs/dmu.h>
304d3c95f5SJorgen Lundman #include <zfs/dmu_objset.h>
314d3c95f5SJorgen Lundman #include <zfs/dsl_dir.h>
324d3c95f5SJorgen Lundman #include <zfs/dsl_dataset.h>
334d3c95f5SJorgen Lundman
344d3c95f5SJorgen Lundman #define MATCH_BITS 6
354d3c95f5SJorgen Lundman #define MATCH_MIN 3
364d3c95f5SJorgen Lundman #define OFFSET_MASK ((1 << (16 - MATCH_BITS)) - 1)
374d3c95f5SJorgen Lundman
384d3c95f5SJorgen Lundman /*
394d3c95f5SJorgen Lundman * Decompression Entry - lzjb
404d3c95f5SJorgen Lundman */
414d3c95f5SJorgen Lundman #ifndef NBBY
424d3c95f5SJorgen Lundman #define NBBY 8
434d3c95f5SJorgen Lundman #endif
444d3c95f5SJorgen Lundman
454d3c95f5SJorgen Lundman int
lzjb_decompress(void * s_start,void * d_start,uint32_t s_len,uint32_t d_len)464d3c95f5SJorgen Lundman lzjb_decompress(void *s_start, void *d_start, uint32_t s_len,
474d3c95f5SJorgen Lundman uint32_t d_len)
484d3c95f5SJorgen Lundman {
494d3c95f5SJorgen Lundman uint8_t *src = s_start;
504d3c95f5SJorgen Lundman uint8_t *dst = d_start;
514d3c95f5SJorgen Lundman uint8_t *d_end = (uint8_t *) d_start + d_len;
524d3c95f5SJorgen Lundman uint8_t *s_end = (uint8_t *) s_start + s_len;
534d3c95f5SJorgen Lundman uint8_t *cpy, copymap = 0;
544d3c95f5SJorgen Lundman int copymask = 1 << (NBBY - 1);
554d3c95f5SJorgen Lundman
564d3c95f5SJorgen Lundman while (dst < d_end && src < s_end) {
574d3c95f5SJorgen Lundman if ((copymask <<= 1) == (1 << NBBY)) {
584d3c95f5SJorgen Lundman copymask = 1;
594d3c95f5SJorgen Lundman copymap = *src++;
604d3c95f5SJorgen Lundman }
614d3c95f5SJorgen Lundman if (src >= s_end) {
624d3c95f5SJorgen Lundman printf("lzjb decompression failed\n");
634d3c95f5SJorgen Lundman return ZFS_ERR_BAD_FS;
644d3c95f5SJorgen Lundman }
654d3c95f5SJorgen Lundman if (copymap & copymask) {
664d3c95f5SJorgen Lundman int mlen = (src[0] >> (NBBY - MATCH_BITS)) + MATCH_MIN;
674d3c95f5SJorgen Lundman int offset = ((src[0] << NBBY) | src[1]) & OFFSET_MASK;
684d3c95f5SJorgen Lundman src += 2;
694d3c95f5SJorgen Lundman cpy = dst - offset;
704d3c95f5SJorgen Lundman if (src > s_end || cpy < (uint8_t *) d_start) {
714d3c95f5SJorgen Lundman printf("lzjb decompression failed\n");
724d3c95f5SJorgen Lundman return ZFS_ERR_BAD_FS;
734d3c95f5SJorgen Lundman }
744d3c95f5SJorgen Lundman while (--mlen >= 0 && dst < d_end)
754d3c95f5SJorgen Lundman *dst++ = *cpy++;
764d3c95f5SJorgen Lundman } else {
774d3c95f5SJorgen Lundman *dst++ = *src++;
784d3c95f5SJorgen Lundman }
794d3c95f5SJorgen Lundman }
804d3c95f5SJorgen Lundman if (dst < d_end) {
814d3c95f5SJorgen Lundman printf("lzjb decompression failed\n");
824d3c95f5SJorgen Lundman return ZFS_ERR_BAD_FS;
834d3c95f5SJorgen Lundman }
844d3c95f5SJorgen Lundman return ZFS_ERR_NONE;
854d3c95f5SJorgen Lundman }
86