Run Sparse and fix its warnings. Apparently, running make C=1 is rarely done, so make running sparse default. Signed-off-by: Avri Altman <avri.altman@xxxxxxx> --- 3rdparty/hmac_sha/sha2.c | 18 ++--- Makefile | 5 +- lsmmc.c | 146 ++++----------------------------------- mmc.c | 18 ++--- mmc_cmds.c | 28 ++++---- 5 files changed, 49 insertions(+), 166 deletions(-) diff --git a/3rdparty/hmac_sha/sha2.c b/3rdparty/hmac_sha/sha2.c index 337b414..9fcafb7 100644 --- a/3rdparty/hmac_sha/sha2.c +++ b/3rdparty/hmac_sha/sha2.c @@ -131,27 +131,27 @@ wv[h] = t1 + t2; \ } -uint32 sha224_h0[8] = +static uint32 sha224_h0[8] = {0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939, 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4}; -uint32 sha256_h0[8] = +static uint32 sha256_h0[8] = {0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19}; -uint64 sha384_h0[8] = +static uint64 sha384_h0[8] = {0xcbbb9d5dc1059ed8ULL, 0x629a292a367cd507ULL, 0x9159015a3070dd17ULL, 0x152fecd8f70e5939ULL, 0x67332667ffc00b31ULL, 0x8eb44a8768581511ULL, 0xdb0c2e0d64f98fa7ULL, 0x47b5481dbefa4fa4ULL}; -uint64 sha512_h0[8] = +static uint64 sha512_h0[8] = {0x6a09e667f3bcc908ULL, 0xbb67ae8584caa73bULL, 0x3c6ef372fe94f82bULL, 0xa54ff53a5f1d36f1ULL, 0x510e527fade682d1ULL, 0x9b05688c2b3e6c1fULL, 0x1f83d9abfb41bd6bULL, 0x5be0cd19137e2179ULL}; -uint32 sha256_k[64] = +static uint32 sha256_k[64] = {0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, @@ -169,7 +169,7 @@ uint32 sha256_k[64] = 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2}; -uint64 sha512_k[80] = +static uint64 sha512_k[80] = {0x428a2f98d728ae22ULL, 0x7137449123ef65cdULL, 0xb5c0fbcfec4d3b2fULL, 0xe9b5dba58189dbbcULL, 0x3956c25bf348b538ULL, 0x59f111f1b605d019ULL, @@ -213,7 +213,7 @@ uint64 sha512_k[80] = /* SHA-256 functions */ -void sha256_transf(sha256_ctx *ctx, const unsigned char *message, +static void sha256_transf(sha256_ctx *ctx, const unsigned char *message, unsigned int block_nb) { uint32 w[64]; @@ -429,8 +429,8 @@ void sha256_final(sha256_ctx *ctx, unsigned char *digest) /* SHA-512 functions */ -void sha512_transf(sha512_ctx *ctx, const unsigned char *message, - unsigned int block_nb) +static void sha512_transf(sha512_ctx *ctx, const unsigned char *message, + unsigned int block_nb) { uint64 w[80]; uint64 wv[8]; diff --git a/Makefile b/Makefile index a890833..6b60557 100644 --- a/Makefile +++ b/Makefile @@ -25,9 +25,10 @@ mandir = /usr/share/man progs = mmc -# make C=1 to enable sparse +# make C=1 to enable sparse - default +C ?= 1 ifdef C - check = sparse $(CHECKFLAGS) + check = sparse $(CHECKFLAGS) $(AM_CFLAGS) endif all: $(progs) diff --git a/lsmmc.c b/lsmmc.c index 9596722..7e0ea23 100644 --- a/lsmmc.c +++ b/lsmmc.c @@ -47,6 +47,7 @@ #include <unistd.h> #include "mmc.h" +#include "mmc_cmds.h" #define MASKTOBIT0(high) \ ((high >= 0) ? ((1ull << ((high) + 1ull)) - 1ull) : 0ull) @@ -231,7 +232,7 @@ static struct ids_database mmc_database[] = { }; /* Command line parsing functions */ -void usage(void) +static void usage(void) { printf("Usage: print mmc [-h] [-v] <device path ...>\n"); printf("\n"); @@ -240,7 +241,7 @@ void usage(void) printf("\t-v\tEnable verbose mode.\n"); } -int parse_opts(int argc, char **argv, struct config *config) +static int parse_opts(int argc, char **argv, struct config *config) { int c; @@ -302,7 +303,7 @@ static char *get_manufacturer(struct config *config, unsigned int manid) } /* MMC/SD file parsing functions */ -char *read_file(char *name) +static char *read_file(char *name) { char line[4096]; char *preparsed, *start = line; @@ -352,7 +353,7 @@ char *read_file(char *name) } /* Hexadecimal string parsing functions */ -char *to_binstr(char *hexstr) +static char *to_binstr(char *hexstr) { char *bindigits[] = { "0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", @@ -386,7 +387,7 @@ char *to_binstr(char *hexstr) return binstr; } -void bin_to_unsigned(unsigned int *u, char *binstr, int width) +static void bin_to_unsigned(unsigned int *u, char *binstr, int width) { *u = 0; assert(width <= 32); @@ -400,7 +401,7 @@ void bin_to_unsigned(unsigned int *u, char *binstr, int width) } } -void bin_to_ascii(char *a, char *binstr, int width) +static void bin_to_ascii(char *a, char *binstr, int width) { assert(width % 8 == 0); *a = '\0'; @@ -419,7 +420,7 @@ void bin_to_ascii(char *a, char *binstr, int width) } } -void parse_bin(char *hexstr, char *fmt, ...) +static void parse_bin(char *hexstr, char *fmt, ...) { va_list args; char *origstr; @@ -470,7 +471,7 @@ void parse_bin(char *hexstr, char *fmt, ...) } /* MMC/SD information parsing functions */ -void print_sd_cid(struct config *config, char *cid) +static void print_sd_cid(struct config *config, char *cid) { static const char *months[] = { "jan", "feb", "mar", "apr", "may", "jun", @@ -528,7 +529,7 @@ void print_sd_cid(struct config *config, char *cid) } } -void print_mmc_cid(struct config *config, char *cid) +static void print_mmc_cid(struct config *config, char *cid) { static const char *months[] = { "jan", "feb", "mar", "apr", "may", "jun", @@ -602,7 +603,7 @@ void print_mmc_cid(struct config *config, char *cid) } } -void print_sd_csd(struct config *config, char *csd) +static void print_sd_csd(struct config *config, char *csd) { unsigned int csd_structure; unsigned int taac_timevalue; @@ -1941,128 +1942,7 @@ static void print_mmc_csd(struct config *config, char *csd) } } -char *speed_class_speed(unsigned char id, bool ddr) -{ - if (ddr) { - switch (id) { - case 0x00: return "<4.8MB/s"; - case 0x08: return " 4.8MB/s"; - case 0x0a: return " 6.0MB/s"; - case 0x0f: return " 9.0MB/s"; - case 0x14: return "12.0MB/s"; - case 0x1e: return "18.0MB/s"; - case 0x28: return "24.0MB/s"; - case 0x32: return "30.0MB/s"; - case 0x3c: return "36.0MB/s"; - case 0x46: return "42.0MB/s"; - case 0x50: return "48.0MB/s"; - case 0x64: return "60.0MB/s"; - case 0x78: return "72.0MB/s"; - case 0x8c: return "84.0MB/s"; - case 0xa0: return "96.0MB/s"; - default: return "??.?MB/s"; - } - } else { - switch (id) { - case 0x00: return "<2.4MB/s"; - case 0x08: return " 2.4MB/s"; - case 0x0a: return " 3.0MB/s"; - case 0x0f: return " 4.5MB/s"; - case 0x14: return " 6.0MB/s"; - case 0x1e: return " 9.0MB/s"; - case 0x28: return "12.0MB/s"; - case 0x32: return "15.0MB/s"; - case 0x3c: return "18.0MB/s"; - case 0x46: return "21.0MB/s"; - case 0x50: return "24.0MB/s"; - case 0x64: return "30.0MB/s"; - case 0x78: return "36.0MB/s"; - case 0x8c: return "42.0MB/s"; - case 0xa0: return "48.0MB/s"; - default: return "??.?MB/s"; - } - } -} - -char speed_class_name(unsigned char id) -{ - switch (id) { - case 0x00: return '?'; - case 0x08: return 'A'; - case 0x0a: return 'B'; - case 0x0f: return 'C'; - case 0x14: return 'D'; - case 0x1e: return 'E'; - case 0x28: return 'F'; - case 0x32: return 'G'; - case 0x3c: return 'H'; - case 0x46: return 'J'; - case 0x50: return 'K'; - case 0x64: return 'M'; - case 0x78: return 'O'; - case 0x8c: return 'R'; - case 0xa0: return 'T'; - default: return '?'; - } -} - -char *power_class_consumption(unsigned int id, bool volt360) -{ - if (volt360) { - switch (id) { - case 0x0: return "100-200mA"; - case 0x1: return "120-220mA"; - case 0x2: return "150-250mA"; - case 0x3: return "180-280mA"; - case 0x4: return "200-300mA"; - case 0x5: return "220-320mA"; - case 0x6: return "250-350mA"; - case 0x7: return "300-400mA"; - case 0x8: return "350-450mA"; - case 0x9: return "400-500mA"; - case 0xa: return "450-550mA"; - default: return "reserved"; - } - } else { - switch (id) { - case 0x0: return "65-130mA"; - case 0x1: return "70-140mA"; - case 0x2: return "80-160mA"; - case 0x3: return "90-180mA"; - case 0x4: return "100-200mA"; - case 0x5: return "120-220mA"; - case 0x6: return "140-240mA"; - case 0x7: return "160-260mA"; - case 0x8: return "180-280mA"; - case 0x9: return "200-300mA"; - case 0xa: return "250-350mA"; - default: return "reserved"; - } - } -} - -char *sleep_consumption(unsigned int id) -{ - switch (id) { - case 0x00: return "not defined"; - case 0x01: return "2uA"; - case 0x02: return "4uA"; - case 0x03: return "8uA"; - case 0x04: return "16uA"; - case 0x05: return "32uA"; - case 0x06: return "64uA"; - case 0x07: return "128uA"; - case 0x08: return "0.256mA"; - case 0x09: return "0.512mA"; - case 0x0a: return "1.024mA"; - case 0x0b: return "2.048mA"; - case 0x0c: return "4.096mA"; - case 0x0d: return "8.192mA"; - default: return "reserved"; - } -} - -void print_sd_scr(struct config *config, char *scr) +static void print_sd_scr(struct config *config, char *scr) { unsigned int scr_structure; unsigned int sd_spec; @@ -2203,7 +2083,7 @@ void print_sd_scr(struct config *config, char *scr) } } -int process_dir(struct config *config, enum REG_TYPE reg) +static int process_dir(struct config *config, enum REG_TYPE reg) { char *type = NULL; char *reg_content = NULL; diff --git a/mmc.c b/mmc.c index bc8f74e..2c5b9b5 100644 --- a/mmc.c +++ b/mmc.c @@ -272,7 +272,7 @@ static struct Command commands[] = { "4. The MMC will perform a soft reset, if your system cannot handle that do not use the boot operation from mmc-utils.\n", NULL }, - { 0, 0, 0, 0 } + { NULL, 0, NULL, NULL } }; static char *get_prgname(char *programname) @@ -324,10 +324,10 @@ static void help(char *np) static int split_command(char *cmd, char ***commands) { - int c, l; - char *p, *s; + int c, l; + char *p, *s; - for( *commands = 0, l = c = 0, p = s = cmd ; ; p++, l++ ){ + for (*commands = NULL, l = c = 0, p = s = cmd ; ; p++, l++) { if ( *p && *p != ' ' ) continue; @@ -340,7 +340,7 @@ static int split_command(char *cmd, char ***commands) if( !*p ) break; } - (*commands)[c] = 0; + (*commands)[c] = NULL; return c; } @@ -444,7 +444,7 @@ static int parse_args(int argc, char **argv, int *nargs_, char **cmd_, char ***args_ ) { struct Command *cp; - struct Command *matchcmd=0; + struct Command *matchcmd = NULL; char *prgname = get_prgname(argv[0]); int i=0, helprequested=0; @@ -535,9 +535,9 @@ static int parse_args(int argc, char **argv, } int main(int ac, char **av ) { - char *cmd=0, **args=0; - int nargs=0, r; - CommandFunction func=0; + char *cmd = NULL, **args = NULL; + int nargs = 0, r; + CommandFunction func = NULL; r = parse_args(ac, av, &func, &nargs, &cmd, &args); if( r <= 0 ){ diff --git a/mmc_cmds.c b/mmc_cmds.c index 936e0c5..3b1bcf4 100644 --- a/mmc_cmds.c +++ b/mmc_cmds.c @@ -63,7 +63,7 @@ static inline __u32 per_byte_htole32(__u8 *arr) return arr[0] | arr[1] << 8 | arr[2] << 16 | arr[3] << 24; } -int read_extcsd(int fd, __u8 *ext_csd) +static int read_extcsd(int fd, __u8 *ext_csd) { int ret = 0; struct mmc_ioc_cmd idata; @@ -93,7 +93,8 @@ static void fill_switch_cmd(struct mmc_ioc_cmd *cmd, __u8 index, __u8 value) cmd->flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC; } -int write_extcsd_value(int fd, __u8 index, __u8 value, unsigned int timeout_ms) +static int +write_extcsd_value(int fd, __u8 index, __u8 value, unsigned int timeout_ms) { int ret = 0; struct mmc_ioc_cmd idata = {}; @@ -110,7 +111,7 @@ int write_extcsd_value(int fd, __u8 index, __u8 value, unsigned int timeout_ms) return ret; } -int send_status(int fd, __u32 *response) +static int send_status(int fd, __u32 *response) { int ret = 0; struct mmc_ioc_cmd idata; @@ -744,7 +745,7 @@ int do_boot_bus_conditions_set(int nargs, char **argv) return ret; } -int do_hwreset(int value, int nargs, char **argv) +static int do_hwreset(int value, int nargs, char **argv) { __u8 ext_csd[512]; int fd, ret; @@ -972,7 +973,7 @@ out_free: return ret; } -unsigned int get_sector_count(__u8 *ext_csd) +static unsigned int get_sector_count(__u8 *ext_csd) { return (ext_csd[EXT_CSD_SEC_COUNT_3] << 24) | (ext_csd[EXT_CSD_SEC_COUNT_2] << 16) | @@ -980,7 +981,7 @@ unsigned int get_sector_count(__u8 *ext_csd) ext_csd[EXT_CSD_SEC_COUNT_0]; } -int is_blockaddresed(__u8 *ext_csd) +static int is_blockaddresed(__u8 *ext_csd) { unsigned int sectors = get_sector_count(ext_csd); @@ -988,18 +989,19 @@ int is_blockaddresed(__u8 *ext_csd) return (sectors > (2u * 1024 * 1024 * 1024) / 512); } -unsigned int get_hc_wp_grp_size(__u8 *ext_csd) +static unsigned int get_hc_wp_grp_size(__u8 *ext_csd) { return ext_csd[221]; } -unsigned int get_hc_erase_grp_size(__u8 *ext_csd) +static unsigned int get_hc_erase_grp_size(__u8 *ext_csd) { return ext_csd[224]; } -int set_partitioning_setting_completed(int dry_run, const char * const device, - int fd) +static int +set_partitioning_setting_completed(int dry_run, const char *const device, + int fd) { int ret; @@ -1047,7 +1049,7 @@ int set_partitioning_setting_completed(int dry_run, const char * const device, return 0; } -int check_enhanced_area_total_limit(const char * const device, int fd) +static int check_enhanced_area_total_limit(const char *const device, int fd) { __u8 ext_csd[512]; __u32 regl; @@ -2267,7 +2269,7 @@ int do_rpmb_write_key(int nargs, char **argv) return ret; } -int rpmb_read_counter(int dev_fd, unsigned int *cnt) +static int rpmb_read_counter(int dev_fd, unsigned int *cnt) { int ret; struct rpmb_frame frame_in = { @@ -2589,7 +2591,7 @@ int do_rpmb_write_block(int nargs, char **argv) return ret; } -int do_cache_ctrl(int value, int nargs, char **argv) +static int do_cache_ctrl(int value, int nargs, char **argv) { __u8 ext_csd[512]; int fd, ret; -- 2.25.1