xref: /rk3399_rockchip-uboot/fs/zfs/zfs_lzjb.c (revision 326ea986ac150acdc7656d57fca647db80b50158)
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