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