Initial Linux ZFS GIT Repo
[zfs.git] / patches / port-no-zmod.patch
1 Do not use zmod.h in userspace.
2
3 Index: zfs+chaos4/lib/libzpool/gzip.c
4 ===================================================================
5 --- zfs+chaos4.orig/lib/libzpool/gzip.c
6 +++ zfs+chaos4/lib/libzpool/gzip.c
7 @@ -28,22 +28,35 @@
8  
9  #include <sys/debug.h>
10  #include <sys/types.h>
11 -#include <sys/zmod.h>
12  
13  #ifdef _KERNEL
14 +
15  #include <sys/systm.h>
16 -#else
17 +#include <sys/zmod.h>
18 +
19 +typedef size_t zlen_t;
20 +#define compress_func   z_compress_level
21 +#define uncompress_func z_uncompress
22 +
23 +#else /* _KERNEL */
24 +
25  #include <strings.h>
26 +#include <zlib.h>
27 +
28 +typedef uLongf zlen_t;
29 +#define compress_func   compress2
30 +#define uncompress_func uncompress
31 +
32  #endif
33  
34  size_t
35  gzip_compress(void *s_start, void *d_start, size_t s_len, size_t d_len, int n)
36  {
37 -       size_t dstlen = d_len;
38 +       zlen_t dstlen = d_len;
39  
40         ASSERT(d_len <= s_len);
41  
42 -       if (z_compress_level(d_start, &dstlen, s_start, s_len, n) != Z_OK) {
43 +       if (compress_func(d_start, &dstlen, s_start, s_len, n) != Z_OK) {
44                 if (d_len != s_len)
45                         return (s_len);
46  
47 @@ -51,18 +64,18 @@ gzip_compress(void *s_start, void *d_sta
48                 return (s_len);
49         }
50  
51 -       return (dstlen);
52 +       return ((size_t) dstlen);
53  }
54  
55  /*ARGSUSED*/
56  int
57  gzip_decompress(void *s_start, void *d_start, size_t s_len, size_t d_len, int n)
58  {
59 -       size_t dstlen = d_len;
60 +       zlen_t dstlen = d_len;
61  
62         ASSERT(d_len >= s_len);
63  
64 -       if (z_uncompress(d_start, &dstlen, s_start, s_len) != Z_OK)
65 +       if (uncompress_func(d_start, &dstlen, s_start, s_len) != Z_OK)
66                 return (-1);
67  
68         return (0);
69 Index: zfs+chaos4/lib/libzpool/kernel.c
70 ===================================================================
71 --- zfs+chaos4.orig/lib/libzpool/kernel.c
72 +++ zfs+chaos4/lib/libzpool/kernel.c
73 @@ -36,7 +36,6 @@
74  #include <sys/stat.h>
75  #include <sys/processor.h>
76  #include <sys/zfs_context.h>
77 -#include <sys/zmod.h>
78  #include <sys/utsname.h>
79  #include <sys/time.h>
80  
81 @@ -876,31 +875,6 @@ kernel_fini(void)
82         urandom_fd = -1;
83  }
84  
85 -int
86 -z_uncompress(void *dst, size_t *dstlen, const void *src, size_t srclen)
87 -{
88 -       int ret;
89 -       uLongf len = *dstlen;
90 -
91 -       if ((ret = uncompress(dst, &len, src, srclen)) == Z_OK)
92 -               *dstlen = (size_t)len;
93 -
94 -       return (ret);
95 -}
96 -
97 -int
98 -z_compress_level(void *dst, size_t *dstlen, const void *src, size_t srclen,
99 -    int level)
100 -{
101 -       int ret;
102 -       uLongf len = *dstlen;
103 -
104 -       if ((ret = compress2(dst, &len, src, srclen, level)) == Z_OK)
105 -               *dstlen = (size_t)len;
106 -
107 -       return (ret);
108 -}
109 -
110  /*ARGSUSED*/
111  size_t u8_textprep_str(char *i, size_t *il, char *o, size_t *ol, int nf,
112      size_t vers, int *err)