* [PATCH] LZ4: compression/decompression signedness mismatch
@ 2013-07-12 9:24 Sergey Senozhatsky
[not found] ` <CADv+DGka4s1xc2UYqu+-EqHW8jA56JrtEE_sMsMOpc6NDmc6Zw@mail.gmail.com>
0 siblings, 1 reply; 7+ messages in thread
From: Sergey Senozhatsky @ 2013-07-12 9:24 UTC (permalink / raw)
To: Kyungsik Lee; +Cc: Andrew Morton, Yann Collet, linux-kernel
LZ4 compression and decompression functions require different
in signedness input/output parameters: unsigned char for
compression and signed char for decompression.
Change decompression API to require unsigned char.
Signed-off-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
---
include/linux/lz4.h | 8 ++++----
lib/lz4/lz4_decompress.c | 8 ++++----
2 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/include/linux/lz4.h b/include/linux/lz4.h
index d21c13f..c13f0bc 100644
--- a/include/linux/lz4.h
+++ b/include/linux/lz4.h
@@ -67,8 +67,8 @@ int lz4hc_compress(const unsigned char *src, size_t src_len,
* note : Destination buffer must be already allocated.
* slightly faster than lz4_decompress_unknownoutputsize()
*/
-int lz4_decompress(const char *src, size_t *src_len, char *dest,
- size_t actual_dest_len);
+int lz4_decompress(unsigned const char *src, size_t *src_len,
+ unsigned char *dest, size_t actual_dest_len);
/*
* lz4_decompress_unknownoutputsize()
@@ -82,6 +82,6 @@ int lz4_decompress(const char *src, size_t *src_len, char *dest,
* Error if return (< 0)
* note : Destination buffer must be already allocated.
*/
-int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
- char *dest, size_t *dest_len);
+int lz4_decompress_unknownoutputsize(unsigned const char *src, size_t src_len,
+ unsigned char *dest, size_t *dest_len);
#endif
diff --git a/lib/lz4/lz4_decompress.c b/lib/lz4/lz4_decompress.c
index d3414ea..7ceda1f 100644
--- a/lib/lz4/lz4_decompress.c
+++ b/lib/lz4/lz4_decompress.c
@@ -283,8 +283,8 @@ _output_error:
return (int) (-(((char *) ip) - source));
}
-int lz4_decompress(const char *src, size_t *src_len, char *dest,
- size_t actual_dest_len)
+int lz4_decompress(unsigned const char *src, size_t *src_len,
+ unsigned char *dest, size_t actual_dest_len)
{
int ret = -1;
int input_len = 0;
@@ -302,8 +302,8 @@ exit_0:
EXPORT_SYMBOL_GPL(lz4_decompress);
#endif
-int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
- char *dest, size_t *dest_len)
+int lz4_decompress_unknownoutputsize(unsigned const char *src, size_t src_len,
+ unsigned char *dest, size_t *dest_len)
{
int ret = -1;
int out_len = 0;
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH] LZ4: compression/decompression signedness mismatch
[not found] ` <CADv+DGka4s1xc2UYqu+-EqHW8jA56JrtEE_sMsMOpc6NDmc6Zw@mail.gmail.com>
@ 2013-07-12 9:48 ` Sergey Senozhatsky
2013-07-18 21:18 ` Sergey Senozhatsky
0 siblings, 1 reply; 7+ messages in thread
From: Sergey Senozhatsky @ 2013-07-12 9:48 UTC (permalink / raw)
To: Yann Collet; +Cc: Sergey Senozhatsky, Kyungsik Lee, Andrew Morton, linux-kernel
On (07/12/13 11:28), Yann Collet wrote:
> The reference implementation, hosted at :�
> [1]https://code.google.com/p/lz4/
> only proposes char* (signed) types as part of the interface contract.
> I would recommend to keep it that way, to remain consistent.
> Regards
Crypto lz4 accepts u8 * for both compression and decompression:
lz4_compress_crypto(struct crypto_tfm *tfm, const u8 *src,
unsigned int slen, u8 *dst, unsigned int *dlen)
lz4_decompress_crypto(struct crypto_tfm *tfm, const u8 *src,
unsigned int slen, u8 *dst, unsigned int *dlen)
Internally LZ4 may cast unsigned char* to signed char*, the same way you
already do with compression:
int lz4_compress(const unsigned char *src, size_t src_len,
unsigned char *dst, size_t *dst_len, void *wrkmem)
calls:
lz4_compressctx(void *ctx,
const char *source, char *dest,
int isize, int maxoutputsize)
At the moment API is a bit misaligned: unsiged char* for compression and signed char* for
decompression.
My 'real word' use case is, suppose:
struct foo {
[..]
int (*compress)(const unsigned char *src, size_t src_len,
unsigned char *dst, size_t *dst_len, void *wrkmem);
int (*decompress)(const unsigned char *src, size_t src_len,
unsigned char *dst, size_t *dst_len);
};
and (for example) module also provides sysfs attribute, so user can switch select
LZO or LZ4 compressions depending of his needs:
->compress = lzo1x_1_compress;
->decompress = lzo1x_decompress_safe;
to
->compress = lz4_compress;
->decompress = lz4_decompress_unknownoutputsize;
the last one produces unneccessary compilation warning.
-ss
> 2013/7/12 Sergey Senozhatsky <[2]sergey.senozhatsky@gmail.com>
>
> LZ4 compression and decompression functions require different
> in signedness input/output parameters: unsigned char for
> compression and signed char for decompression.
>
> Change decompression API to require unsigned char.
>
> Signed-off-by: Sergey Senozhatsky <[3]sergey.senozhatsky@gmail.com>
>
> ---
>
> �include/linux/lz4.h � � �| 8 ++++----
> �lib/lz4/lz4_decompress.c | 8 ++++----
> �2 files changed, 8 insertions(+), 8 deletions(-)
>
> diff --git a/include/linux/lz4.h b/include/linux/lz4.h
> index d21c13f..c13f0bc 100644
> --- a/include/linux/lz4.h
> +++ b/include/linux/lz4.h
> @@ -67,8 +67,8 @@ int lz4hc_compress(const unsigned char *src, size_t
> src_len,
> � * � � note : �Destination buffer must be already allocated.
> � * � � � � � � slightly faster than lz4_decompress_unknownoutputsize()
> � */
> -int lz4_decompress(const char *src, size_t *src_len, char *dest,
> - � � � � � � � size_t actual_dest_len);
> +int lz4_decompress(unsigned const char *src, size_t *src_len,
> + � � � � � � � unsigned char *dest, size_t actual_dest_len);
>
> �/*
> � * lz4_decompress_unknownoutputsize()
> @@ -82,6 +82,6 @@ int lz4_decompress(const char *src, size_t *src_len,
> char *dest,
> � * � � � � � � � Error if return (< 0)
> � * � � note : �Destination buffer must be already allocated.
> � */
> -int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
> - � � � � � � � char *dest, size_t *dest_len);
> +int lz4_decompress_unknownoutputsize(unsigned const char *src, size_t
> src_len,
> + � � � � � � � unsigned char *dest, size_t *dest_len);
> �#endif
> diff --git a/lib/lz4/lz4_decompress.c b/lib/lz4/lz4_decompress.c
> index d3414ea..7ceda1f 100644
> --- a/lib/lz4/lz4_decompress.c
> +++ b/lib/lz4/lz4_decompress.c
> @@ -283,8 +283,8 @@ _output_error:
> � � � � return (int) (-(((char *) ip) - source));
> �}
>
> -int lz4_decompress(const char *src, size_t *src_len, char *dest,
> - � � � � � � � size_t actual_dest_len)
> +int lz4_decompress(unsigned const char *src, size_t *src_len,
> + � � � � � � � unsigned char *dest, size_t actual_dest_len)
> �{
> � � � � int ret = -1;
> � � � � int input_len = 0;
> @@ -302,8 +302,8 @@ exit_0:
> �EXPORT_SYMBOL_GPL(lz4_decompress);
> �#endif
>
> -int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
> - � � � � � � � char *dest, size_t *dest_len)
> +int lz4_decompress_unknownoutputsize(unsigned const char *src, size_t
> src_len,
> + � � � � � � � unsigned char *dest, size_t *dest_len)
> �{
> � � � � int ret = -1;
> � � � � int out_len = 0;
>
> References
>
> Visible links
> 1. https://code.google.com/p/lz4/
> 2. mailto:sergey.senozhatsky@gmail.com
> 3. mailto:sergey.senozhatsky@gmail.com
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] LZ4: compression/decompression signedness mismatch
2013-07-12 9:48 ` Sergey Senozhatsky
@ 2013-07-18 21:18 ` Sergey Senozhatsky
2013-07-18 21:29 ` Geert Uytterhoeven
0 siblings, 1 reply; 7+ messages in thread
From: Sergey Senozhatsky @ 2013-07-18 21:18 UTC (permalink / raw)
To: Kyungsik Lee; +Cc: Yann Collet, Andrew Morton, linux-kernel
Hello,
On (07/12/13 12:48), Sergey Senozhatsky wrote:
> On (07/12/13 11:28), Yann Collet wrote:
> > The reference implementation, hosted at :�
> > [1]https://code.google.com/p/lz4/
> > only proposes char* (signed) types as part of the interface contract.
> > I would recommend to keep it that way, to remain consistent.
> > Regards
>
> Crypto lz4 accepts u8 * for both compression and decompression:
>
> lz4_compress_crypto(struct crypto_tfm *tfm, const u8 *src,
> unsigned int slen, u8 *dst, unsigned int *dlen)
>
> lz4_decompress_crypto(struct crypto_tfm *tfm, const u8 *src,
> unsigned int slen, u8 *dst, unsigned int *dlen)
>
>
> Internally LZ4 may cast unsigned char* to signed char*, the same way you
> already do with compression:
>
> int lz4_compress(const unsigned char *src, size_t src_len,
> unsigned char *dst, size_t *dst_len, void *wrkmem)
>
> calls:
> lz4_compressctx(void *ctx,
> const char *source, char *dest,
> int isize, int maxoutputsize)
>
+ lib/decompress_unlz4.c
STATIC int INIT decompress(unsigned char *buf, int in_len,
int(*fill)(void*, unsigned int),
int(*flush)(void*, unsigned int),
unsigned char *output,
int *posp,
void(*error)(char *x)
>
> At the moment API is a bit misaligned: unsiged char* for compression and signed char* for
> decompression.
>
>
> My 'real word' use case is, suppose:
>
> struct foo {
> [..]
> int (*compress)(const unsigned char *src, size_t src_len,
> unsigned char *dst, size_t *dst_len, void *wrkmem);
> int (*decompress)(const unsigned char *src, size_t src_len,
> unsigned char *dst, size_t *dst_len);
> };
>
>
> and (for example) module also provides sysfs attribute, so user can switch select
> LZO or LZ4 compressions depending of his needs:
>
> ->compress = lzo1x_1_compress;
> ->decompress = lzo1x_decompress_safe;
>
> to
> ->compress = lz4_compress;
> ->decompress = lz4_decompress_unknownoutputsize;
>
>
> the last one produces unneccessary compilation warning.
>
did you guys have a chance to review the patch? it does not change
implementation/internals, just decompression exported symbols.
-ss
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] LZ4: compression/decompression signedness mismatch
2013-07-18 21:18 ` Sergey Senozhatsky
@ 2013-07-18 21:29 ` Geert Uytterhoeven
2013-07-19 8:27 ` Kyungsik Lee
0 siblings, 1 reply; 7+ messages in thread
From: Geert Uytterhoeven @ 2013-07-18 21:29 UTC (permalink / raw)
To: Sergey Senozhatsky; +Cc: Kyungsik Lee, Yann Collet, Andrew Morton, linux-kernel
On Thu, Jul 18, 2013 at 11:18 PM, Sergey Senozhatsky
<sergey.senozhatsky@gmail.com> wrote:
> On (07/12/13 12:48), Sergey Senozhatsky wrote:
>> On (07/12/13 11:28), Yann Collet wrote:
>> > The reference implementation, hosted at :�
>> > [1]https://code.google.com/p/lz4/
>> > only proposes char* (signed) types as part of the interface contract.
>> > I would recommend to keep it that way, to remain consistent.
>> > Regards
>>
>> Crypto lz4 accepts u8 * for both compression and decompression:
>>
>> lz4_compress_crypto(struct crypto_tfm *tfm, const u8 *src,
>> unsigned int slen, u8 *dst, unsigned int *dlen)
>>
>> lz4_decompress_crypto(struct crypto_tfm *tfm, const u8 *src,
>> unsigned int slen, u8 *dst, unsigned int *dlen)
>>
>>
>> Internally LZ4 may cast unsigned char* to signed char*, the same way you
>> already do with compression:
>>
>> int lz4_compress(const unsigned char *src, size_t src_len,
>> unsigned char *dst, size_t *dst_len, void *wrkmem)
>>
>> calls:
>> lz4_compressctx(void *ctx,
>> const char *source, char *dest,
>> int isize, int maxoutputsize)
>>
>
>
> + lib/decompress_unlz4.c
> STATIC int INIT decompress(unsigned char *buf, int in_len,
> int(*fill)(void*, unsigned int),
> int(*flush)(void*, unsigned int),
> unsigned char *output,
> int *posp,
> void(*error)(char *x)
>
>>
>> At the moment API is a bit misaligned: unsiged char* for compression and signed char* for
>> decompression.
>>
>>
>> My 'real word' use case is, suppose:
>>
>> struct foo {
>> [..]
>> int (*compress)(const unsigned char *src, size_t src_len,
>> unsigned char *dst, size_t *dst_len, void *wrkmem);
>> int (*decompress)(const unsigned char *src, size_t src_len,
>> unsigned char *dst, size_t *dst_len);
>> };
>>
>>
>> and (for example) module also provides sysfs attribute, so user can switch select
>> LZO or LZ4 compressions depending of his needs:
>>
>> ->compress = lzo1x_1_compress;
>> ->decompress = lzo1x_decompress_safe;
>>
>> to
>> ->compress = lz4_compress;
>> ->decompress = lz4_decompress_unknownoutputsize;
>>
>>
>> the last one produces unneccessary compilation warning.
>>
>
> did you guys have a chance to review the patch? it does not change
> implementation/internals, just decompression exported symbols.
IMHO, all these memory buffers should be of type "(const) void *", cfr.
e.g. read(2) and memcpy(3).
This avoids casts in the callers.
Gr{oetje,eeting}s,
Geert
--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org
In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
-- Linus Torvalds
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] LZ4: compression/decompression signedness mismatch
2013-07-18 21:29 ` Geert Uytterhoeven
@ 2013-07-19 8:27 ` Kyungsik Lee
2013-07-19 9:04 ` Sergey Senozhatsky
2013-07-19 9:08 ` [PATCH] LZ4: compression/decompression signedness mismatch (v2) Sergey Senozhatsky
0 siblings, 2 replies; 7+ messages in thread
From: Kyungsik Lee @ 2013-07-19 8:27 UTC (permalink / raw)
To: Sergey Senozhatsky
Cc: Geert Uytterhoeven, Yann Collet, Andrew Morton, linux-kernel,
hyojun.im, chan.jeong
On Thu, Jul 18, 2013 at 11:29:57PM +0200, Geert Uytterhoeven wrote:
> On Thu, Jul 18, 2013 at 11:18 PM, Sergey Senozhatsky
> <sergey.senozhatsky@gmail.com> wrote:
> > On (07/12/13 12:48), Sergey Senozhatsky wrote:
> >> On (07/12/13 11:28), Yann Collet wrote:
> >> > The reference implementation, hosted at :�
> >> > [1]https://code.google.com/p/lz4/
> >> > only proposes char* (signed) types as part of the interface contract.
> >> > I would recommend to keep it that way, to remain consistent.
> >> > Regards
> >>
> >> Crypto lz4 accepts u8 * for both compression and decompression:
> >>
> >> lz4_compress_crypto(struct crypto_tfm *tfm, const u8 *src,
> >> unsigned int slen, u8 *dst, unsigned int *dlen)
> >>
> >> lz4_decompress_crypto(struct crypto_tfm *tfm, const u8 *src,
> >> unsigned int slen, u8 *dst, unsigned int *dlen)
> >>
> >>
> >> Internally LZ4 may cast unsigned char* to signed char*, the same way you
> >> already do with compression:
> >>
> >> int lz4_compress(const unsigned char *src, size_t src_len,
> >> unsigned char *dst, size_t *dst_len, void *wrkmem)
> >>
> >> calls:
> >> lz4_compressctx(void *ctx,
> >> const char *source, char *dest,
> >> int isize, int maxoutputsize)
> >>
> >
> >
> > + lib/decompress_unlz4.c
> > STATIC int INIT decompress(unsigned char *buf, int in_len,
> > int(*fill)(void*, unsigned int),
> > int(*flush)(void*, unsigned int),
> > unsigned char *output,
> > int *posp,
> > void(*error)(char *x)
> >
> >>
> >> At the moment API is a bit misaligned: unsiged char* for compression and signed char* for
> >> decompression.
> >>
> >>
> >> My 'real word' use case is, suppose:
> >>
> >> struct foo {
> >> [..]
> >> int (*compress)(const unsigned char *src, size_t src_len,
> >> unsigned char *dst, size_t *dst_len, void *wrkmem);
> >> int (*decompress)(const unsigned char *src, size_t src_len,
> >> unsigned char *dst, size_t *dst_len);
> >> };
> >>
> >>
> >> and (for example) module also provides sysfs attribute, so user can switch select
> >> LZO or LZ4 compressions depending of his needs:
> >>
> >> ->compress = lzo1x_1_compress;
> >> ->decompress = lzo1x_decompress_safe;
> >>
> >> to
> >> ->compress = lz4_compress;
> >> ->decompress = lz4_decompress_unknownoutputsize;
> >>
> >>
> >> the last one produces unneccessary compilation warning.
> >>
> >
> > did you guys have a chance to review the patch? it does not change
> > implementation/internals, just decompression exported symbols.
>
> IMHO, all these memory buffers should be of type "(const) void *", cfr.
> e.g. read(2) and memcpy(3).
>
> This avoids casts in the callers.
How about using "const unsigned char *" for the exported symbols in the
patch?
It is OK unless the patch changes the internal implementation.
Thanks,
Kyungsik
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] LZ4: compression/decompression signedness mismatch
2013-07-19 8:27 ` Kyungsik Lee
@ 2013-07-19 9:04 ` Sergey Senozhatsky
2013-07-19 9:08 ` [PATCH] LZ4: compression/decompression signedness mismatch (v2) Sergey Senozhatsky
1 sibling, 0 replies; 7+ messages in thread
From: Sergey Senozhatsky @ 2013-07-19 9:04 UTC (permalink / raw)
To: Kyungsik Lee
Cc: Geert Uytterhoeven, Yann Collet, Andrew Morton, linux-kernel,
hyojun.im, chan.jeong
On (07/19/13 17:27), Kyungsik Lee wrote:
> > >> On (07/12/13 11:28), Yann Collet wrote:
> > >> > The reference implementation, hosted at :�
> > >> > [1]https://code.google.com/p/lz4/
> > >> > only proposes char* (signed) types as part of the interface contract.
> > >> > I would recommend to keep it that way, to remain consistent.
> > >> > Regards
> > >>
> > >> Crypto lz4 accepts u8 * for both compression and decompression:
> > >>
> > >> lz4_compress_crypto(struct crypto_tfm *tfm, const u8 *src,
> > >> unsigned int slen, u8 *dst, unsigned int *dlen)
> > >>
> > >> lz4_decompress_crypto(struct crypto_tfm *tfm, const u8 *src,
> > >> unsigned int slen, u8 *dst, unsigned int *dlen)
> > >>
> > >>
> > >> Internally LZ4 may cast unsigned char* to signed char*, the same way you
> > >> already do with compression:
> > >>
> > >> int lz4_compress(const unsigned char *src, size_t src_len,
> > >> unsigned char *dst, size_t *dst_len, void *wrkmem)
> > >>
> > >> calls:
> > >> lz4_compressctx(void *ctx,
> > >> const char *source, char *dest,
> > >> int isize, int maxoutputsize)
> > >>
> > >
> > >
> > > + lib/decompress_unlz4.c
> > > STATIC int INIT decompress(unsigned char *buf, int in_len,
> > > int(*fill)(void*, unsigned int),
> > > int(*flush)(void*, unsigned int),
> > > unsigned char *output,
> > > int *posp,
> > > void(*error)(char *x)
> > >
> > >>
> > >> At the moment API is a bit misaligned: unsiged char* for compression and signed char* for
> > >> decompression.
> > >>
> > >>
> > >> My 'real word' use case is, suppose:
> > >>
> > >> struct foo {
> > >> [..]
> > >> int (*compress)(const unsigned char *src, size_t src_len,
> > >> unsigned char *dst, size_t *dst_len, void *wrkmem);
> > >> int (*decompress)(const unsigned char *src, size_t src_len,
> > >> unsigned char *dst, size_t *dst_len);
> > >> };
> > >>
> > >>
> > >> and (for example) module also provides sysfs attribute, so user can switch select
> > >> LZO or LZ4 compressions depending of his needs:
> > >>
> > >> ->compress = lzo1x_1_compress;
> > >> ->decompress = lzo1x_decompress_safe;
> > >>
> > >> to
> > >> ->compress = lz4_compress;
> > >> ->decompress = lz4_decompress_unknownoutputsize;
> > >>
> > >>
> > >> the last one produces unneccessary compilation warning.
> > >>
> > >
> > > did you guys have a chance to review the patch? it does not change
> > > implementation/internals, just decompression exported symbols.
> >
> > IMHO, all these memory buffers should be of type "(const) void *", cfr.
> > e.g. read(2) and memcpy(3).
> >
> > This avoids casts in the callers.
>
> How about using "const unsigned char *" for the exported symbols in the
> patch?
will resend shortly.
> It is OK unless the patch changes the internal implementation.
>
it doesn't.
thanks,
-ss
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH] LZ4: compression/decompression signedness mismatch (v2)
2013-07-19 8:27 ` Kyungsik Lee
2013-07-19 9:04 ` Sergey Senozhatsky
@ 2013-07-19 9:08 ` Sergey Senozhatsky
1 sibling, 0 replies; 7+ messages in thread
From: Sergey Senozhatsky @ 2013-07-19 9:08 UTC (permalink / raw)
To: Kyungsik Lee
Cc: Geert Uytterhoeven, Yann Collet, Andrew Morton, linux-kernel,
hyojun.im, chan.jeong
LZ4 compression and decompression functions require different
in signedness input/output parameters: unsigned char for
compression and signed char for decompression.
Change decompression API to require "(const) unsigned char *".
v2: minor coding style fix.
Signed-off-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
---
include/linux/lz4.h | 8 ++++----
lib/lz4/lz4_decompress.c | 8 ++++----
2 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/include/linux/lz4.h b/include/linux/lz4.h
index d21c13f..4356686 100644
--- a/include/linux/lz4.h
+++ b/include/linux/lz4.h
@@ -67,8 +67,8 @@ int lz4hc_compress(const unsigned char *src, size_t src_len,
* note : Destination buffer must be already allocated.
* slightly faster than lz4_decompress_unknownoutputsize()
*/
-int lz4_decompress(const char *src, size_t *src_len, char *dest,
- size_t actual_dest_len);
+int lz4_decompress(const unsigned char *src, size_t *src_len,
+ unsigned char *dest, size_t actual_dest_len);
/*
* lz4_decompress_unknownoutputsize()
@@ -82,6 +82,6 @@ int lz4_decompress(const char *src, size_t *src_len, char *dest,
* Error if return (< 0)
* note : Destination buffer must be already allocated.
*/
-int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
- char *dest, size_t *dest_len);
+int lz4_decompress_unknownoutputsize(const unsigned char *src, size_t src_len,
+ unsigned char *dest, size_t *dest_len);
#endif
diff --git a/lib/lz4/lz4_decompress.c b/lib/lz4/lz4_decompress.c
index d3414ea..4c069b2 100644
--- a/lib/lz4/lz4_decompress.c
+++ b/lib/lz4/lz4_decompress.c
@@ -283,8 +283,8 @@ _output_error:
return (int) (-(((char *) ip) - source));
}
-int lz4_decompress(const char *src, size_t *src_len, char *dest,
- size_t actual_dest_len)
+int lz4_decompress(const unsigned char *src, size_t *src_len,
+ unsigned char *dest, size_t actual_dest_len)
{
int ret = -1;
int input_len = 0;
@@ -302,8 +302,8 @@ exit_0:
EXPORT_SYMBOL_GPL(lz4_decompress);
#endif
-int lz4_decompress_unknownoutputsize(const char *src, size_t src_len,
- char *dest, size_t *dest_len)
+int lz4_decompress_unknownoutputsize(const unsigned char *src, size_t src_len,
+ unsigned char *dest, size_t *dest_len)
{
int ret = -1;
int out_len = 0;
^ permalink raw reply related [flat|nested] 7+ messages in thread
end of thread, other threads:[~2013-07-19 9:09 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-07-12 9:24 [PATCH] LZ4: compression/decompression signedness mismatch Sergey Senozhatsky
[not found] ` <CADv+DGka4s1xc2UYqu+-EqHW8jA56JrtEE_sMsMOpc6NDmc6Zw@mail.gmail.com>
2013-07-12 9:48 ` Sergey Senozhatsky
2013-07-18 21:18 ` Sergey Senozhatsky
2013-07-18 21:29 ` Geert Uytterhoeven
2013-07-19 8:27 ` Kyungsik Lee
2013-07-19 9:04 ` Sergey Senozhatsky
2013-07-19 9:08 ` [PATCH] LZ4: compression/decompression signedness mismatch (v2) Sergey Senozhatsky
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).