2019-05-30 02:57:50 +03:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2008-07-14 20:08:37 +04:00
|
|
|
/*
|
|
|
|
* This file is part of UBIFS.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006-2008 Nokia Corporation.
|
|
|
|
* Copyright (C) 2006, 2007 University of Szeged, Hungary
|
|
|
|
*
|
|
|
|
* Authors: Adrian Hunter
|
|
|
|
* Artem Bityutskiy (Битюцкий Артём)
|
|
|
|
* Zoltan Sogor
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file provides a single place to access to compression and
|
|
|
|
* decompression.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/crypto.h>
|
|
|
|
#include "ubifs.h"
|
|
|
|
|
|
|
|
/* Fake description object for the "none" compressor */
|
|
|
|
static struct ubifs_compressor none_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_NONE,
|
2008-11-01 15:57:49 +03:00
|
|
|
.name = "none",
|
2008-07-14 20:08:37 +04:00
|
|
|
.capi_name = "",
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef CONFIG_UBIFS_FS_LZO
|
|
|
|
static DEFINE_MUTEX(lzo_mutex);
|
|
|
|
|
|
|
|
static struct ubifs_compressor lzo_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_LZO,
|
|
|
|
.comp_mutex = &lzo_mutex,
|
2008-11-01 15:57:49 +03:00
|
|
|
.name = "lzo",
|
2008-07-14 20:08:37 +04:00
|
|
|
.capi_name = "lzo",
|
|
|
|
};
|
|
|
|
#else
|
|
|
|
static struct ubifs_compressor lzo_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_LZO,
|
2008-11-01 15:57:49 +03:00
|
|
|
.name = "lzo",
|
2008-07-14 20:08:37 +04:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_UBIFS_FS_ZLIB
|
|
|
|
static DEFINE_MUTEX(deflate_mutex);
|
|
|
|
static DEFINE_MUTEX(inflate_mutex);
|
|
|
|
|
|
|
|
static struct ubifs_compressor zlib_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_ZLIB,
|
|
|
|
.comp_mutex = &deflate_mutex,
|
|
|
|
.decomp_mutex = &inflate_mutex,
|
|
|
|
.name = "zlib",
|
|
|
|
.capi_name = "deflate",
|
|
|
|
};
|
|
|
|
#else
|
|
|
|
static struct ubifs_compressor zlib_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_ZLIB,
|
|
|
|
.name = "zlib",
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2019-05-16 00:02:02 +03:00
|
|
|
#ifdef CONFIG_UBIFS_FS_ZSTD
|
|
|
|
static DEFINE_MUTEX(zstd_enc_mutex);
|
|
|
|
static DEFINE_MUTEX(zstd_dec_mutex);
|
|
|
|
|
|
|
|
static struct ubifs_compressor zstd_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_ZSTD,
|
|
|
|
.comp_mutex = &zstd_enc_mutex,
|
|
|
|
.decomp_mutex = &zstd_dec_mutex,
|
|
|
|
.name = "zstd",
|
|
|
|
.capi_name = "zstd",
|
|
|
|
};
|
|
|
|
#else
|
|
|
|
static struct ubifs_compressor zstd_compr = {
|
|
|
|
.compr_type = UBIFS_COMPR_ZSTD,
|
|
|
|
.name = "zstd",
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2008-07-14 20:08:37 +04:00
|
|
|
/* All UBIFS compressors */
|
|
|
|
struct ubifs_compressor *ubifs_compressors[UBIFS_COMPR_TYPES_CNT];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ubifs_compress - compress data.
|
|
|
|
* @in_buf: data to compress
|
|
|
|
* @in_len: length of the data to compress
|
|
|
|
* @out_buf: output buffer where compressed data should be stored
|
|
|
|
* @out_len: output buffer length is returned here
|
|
|
|
* @compr_type: type of compression to use on enter, actually used compression
|
|
|
|
* type on exit
|
|
|
|
*
|
|
|
|
* This function compresses input buffer @in_buf of length @in_len and stores
|
|
|
|
* the result in the output buffer @out_buf and the resulting length in
|
|
|
|
* @out_len. If the input buffer does not compress, it is just copied to the
|
|
|
|
* @out_buf. The same happens if @compr_type is %UBIFS_COMPR_NONE or if
|
|
|
|
* compression error occurred.
|
|
|
|
*
|
|
|
|
* Note, if the input buffer was not compressed, it is copied to the output
|
|
|
|
* buffer and %UBIFS_COMPR_NONE is returned in @compr_type.
|
|
|
|
*/
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
void ubifs_compress(const struct ubifs_info *c, const void *in_buf,
|
|
|
|
int in_len, void *out_buf, int *out_len, int *compr_type)
|
2008-07-14 20:08:37 +04:00
|
|
|
{
|
|
|
|
int err;
|
|
|
|
struct ubifs_compressor *compr = ubifs_compressors[*compr_type];
|
|
|
|
|
|
|
|
if (*compr_type == UBIFS_COMPR_NONE)
|
|
|
|
goto no_compr;
|
|
|
|
|
|
|
|
/* If the input data is small, do not even try to compress it */
|
|
|
|
if (in_len < UBIFS_MIN_COMPR_LEN)
|
|
|
|
goto no_compr;
|
|
|
|
|
|
|
|
if (compr->comp_mutex)
|
|
|
|
mutex_lock(compr->comp_mutex);
|
|
|
|
err = crypto_comp_compress(compr->cc, in_buf, in_len, out_buf,
|
2008-12-28 12:00:55 +03:00
|
|
|
(unsigned int *)out_len);
|
2008-07-14 20:08:37 +04:00
|
|
|
if (compr->comp_mutex)
|
|
|
|
mutex_unlock(compr->comp_mutex);
|
|
|
|
if (unlikely(err)) {
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
ubifs_warn(c, "cannot compress %d bytes, compressor %s, error %d, leave data uncompressed",
|
2008-07-14 20:08:37 +04:00
|
|
|
in_len, compr->name, err);
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
goto no_compr;
|
2008-07-14 20:08:37 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2008-10-26 17:58:25 +03:00
|
|
|
* If the data compressed only slightly, it is better to leave it
|
|
|
|
* uncompressed to improve read speed.
|
2008-07-14 20:08:37 +04:00
|
|
|
*/
|
2008-10-26 17:58:25 +03:00
|
|
|
if (in_len - *out_len < UBIFS_MIN_COMPRESS_DIFF)
|
2008-07-14 20:08:37 +04:00
|
|
|
goto no_compr;
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
no_compr:
|
|
|
|
memcpy(out_buf, in_buf, in_len);
|
|
|
|
*out_len = in_len;
|
|
|
|
*compr_type = UBIFS_COMPR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ubifs_decompress - decompress data.
|
|
|
|
* @in_buf: data to decompress
|
|
|
|
* @in_len: length of the data to decompress
|
|
|
|
* @out_buf: output buffer where decompressed data should
|
|
|
|
* @out_len: output length is returned here
|
|
|
|
* @compr_type: type of compression
|
|
|
|
*
|
|
|
|
* This function decompresses data from buffer @in_buf into buffer @out_buf.
|
|
|
|
* The length of the uncompressed data is returned in @out_len. This functions
|
|
|
|
* returns %0 on success or a negative error code on failure.
|
|
|
|
*/
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
int ubifs_decompress(const struct ubifs_info *c, const void *in_buf,
|
|
|
|
int in_len, void *out_buf, int *out_len, int compr_type)
|
2008-07-14 20:08:37 +04:00
|
|
|
{
|
|
|
|
int err;
|
|
|
|
struct ubifs_compressor *compr;
|
|
|
|
|
|
|
|
if (unlikely(compr_type < 0 || compr_type >= UBIFS_COMPR_TYPES_CNT)) {
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
ubifs_err(c, "invalid compression type %d", compr_type);
|
2008-07-14 20:08:37 +04:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
compr = ubifs_compressors[compr_type];
|
|
|
|
|
|
|
|
if (unlikely(!compr->capi_name)) {
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
ubifs_err(c, "%s compression is not compiled in", compr->name);
|
2008-07-14 20:08:37 +04:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (compr_type == UBIFS_COMPR_NONE) {
|
|
|
|
memcpy(out_buf, in_buf, in_len);
|
|
|
|
*out_len = in_len;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (compr->decomp_mutex)
|
|
|
|
mutex_lock(compr->decomp_mutex);
|
|
|
|
err = crypto_comp_decompress(compr->cc, in_buf, in_len, out_buf,
|
2008-12-28 12:00:55 +03:00
|
|
|
(unsigned int *)out_len);
|
2008-07-14 20:08:37 +04:00
|
|
|
if (compr->decomp_mutex)
|
|
|
|
mutex_unlock(compr->decomp_mutex);
|
|
|
|
if (err)
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
ubifs_err(c, "cannot decompress %d bytes, compressor %s, error %d",
|
2012-08-27 14:34:09 +04:00
|
|
|
in_len, compr->name, err);
|
2008-07-14 20:08:37 +04:00
|
|
|
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* compr_init - initialize a compressor.
|
|
|
|
* @compr: compressor description object
|
|
|
|
*
|
|
|
|
* This function initializes the requested compressor and returns zero in case
|
|
|
|
* of success or a negative error code in case of failure.
|
|
|
|
*/
|
|
|
|
static int __init compr_init(struct ubifs_compressor *compr)
|
|
|
|
{
|
|
|
|
if (compr->capi_name) {
|
|
|
|
compr->cc = crypto_alloc_comp(compr->capi_name, 0, 0);
|
|
|
|
if (IS_ERR(compr->cc)) {
|
UBIFS: extend debug/message capabilities
In the case where we have more than one volumes on different UBI
devices, it may be not that easy to tell which volume prints the
messages. Add ubi number and volume id in ubifs_msg/warn/error
to help debug. These two values are passed by struct ubifs_info.
For those where ubifs_info is not initialized yet, ubifs_* is
replaced by pr_*. For those where ubifs_info is not avaliable,
ubifs_info is passed to the calling function as a const parameter.
The output looks like,
[ 95.444879] UBIFS (ubi0:1): background thread "ubifs_bgt0_1" started, PID 696
[ 95.484688] UBIFS (ubi0:1): UBIFS: mounted UBI device 0, volume 1, name "test1"
[ 95.484694] UBIFS (ubi0:1): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.484699] UBIFS (ubi0:1): FS size: 30220288 bytes (28 MiB, 238 LEBs), journal size 1523712 bytes (1 MiB, 12 LEBs)
[ 95.484703] UBIFS (ubi0:1): reserved for root: 1427378 bytes (1393 KiB)
[ 95.484709] UBIFS (ubi0:1): media format: w4/r0 (latest is w4/r0), UUID 40DFFC0E-70BE-4193-8905-F7D6DFE60B17, small LPT model
[ 95.489875] UBIFS (ubi1:0): background thread "ubifs_bgt1_0" started, PID 699
[ 95.529713] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "test2"
[ 95.529718] UBIFS (ubi1:0): LEB size: 126976 bytes (124 KiB), min./max. I/O unit sizes: 2048 bytes/2048 bytes
[ 95.529724] UBIFS (ubi1:0): FS size: 19808256 bytes (18 MiB, 156 LEBs), journal size 1015809 bytes (0 MiB, 8 LEBs)
[ 95.529727] UBIFS (ubi1:0): reserved for root: 935592 bytes (913 KiB)
[ 95.529733] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID EEB7779D-F419-4CA9-811B-831CAC7233D4, small LPT model
[ 954.264767] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node type (255 but expected 6)
[ 954.367030] UBIFS error (ubi1:0 pid 756): ubifs_read_node: bad node at LEB 0:0, LEB mapping status 1
Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
2015-03-20 13:39:42 +03:00
|
|
|
pr_err("UBIFS error (pid %d): cannot initialize compressor %s, error %ld",
|
|
|
|
current->pid, compr->name, PTR_ERR(compr->cc));
|
2008-07-14 20:08:37 +04:00
|
|
|
return PTR_ERR(compr->cc);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ubifs_compressors[compr->compr_type] = compr;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* compr_exit - de-initialize a compressor.
|
|
|
|
* @compr: compressor description object
|
|
|
|
*/
|
|
|
|
static void compr_exit(struct ubifs_compressor *compr)
|
|
|
|
{
|
|
|
|
if (compr->capi_name)
|
|
|
|
crypto_free_comp(compr->cc);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ubifs_compressors_init - initialize UBIFS compressors.
|
|
|
|
*
|
|
|
|
* This function initializes the compressor which were compiled in. Returns
|
|
|
|
* zero in case of success and a negative error code in case of failure.
|
|
|
|
*/
|
|
|
|
int __init ubifs_compressors_init(void)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
|
|
|
|
err = compr_init(&lzo_compr);
|
|
|
|
if (err)
|
|
|
|
return err;
|
|
|
|
|
2019-05-16 00:02:02 +03:00
|
|
|
err = compr_init(&zstd_compr);
|
2008-07-14 20:08:37 +04:00
|
|
|
if (err)
|
|
|
|
goto out_lzo;
|
|
|
|
|
2019-05-16 00:02:02 +03:00
|
|
|
err = compr_init(&zlib_compr);
|
|
|
|
if (err)
|
|
|
|
goto out_zstd;
|
|
|
|
|
2008-07-14 20:08:37 +04:00
|
|
|
ubifs_compressors[UBIFS_COMPR_NONE] = &none_compr;
|
|
|
|
return 0;
|
|
|
|
|
2019-05-16 00:02:02 +03:00
|
|
|
out_zstd:
|
|
|
|
compr_exit(&zstd_compr);
|
2008-07-14 20:08:37 +04:00
|
|
|
out_lzo:
|
|
|
|
compr_exit(&lzo_compr);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ubifs_compressors_exit - de-initialize UBIFS compressors.
|
|
|
|
*/
|
2008-12-04 17:04:18 +03:00
|
|
|
void ubifs_compressors_exit(void)
|
2008-07-14 20:08:37 +04:00
|
|
|
{
|
|
|
|
compr_exit(&lzo_compr);
|
|
|
|
compr_exit(&zlib_compr);
|
2019-05-16 00:02:02 +03:00
|
|
|
compr_exit(&zstd_compr);
|
2008-07-14 20:08:37 +04:00
|
|
|
}
|