mmc-utils: Make functions static for local scope enforcement

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@wdc.com>
Link: https://lore.kernel.org/r/20240706171412.1613019-1-avri.altman@wdc.com
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
This commit is contained in:
Avri Altman 2024-07-06 20:14:12 +03:00 committed by Ulf Hansson
parent c8cef0598b
commit f884bfe684
5 changed files with 49 additions and 166 deletions

View File

@ -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];

View File

@ -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)

146
lsmmc.c
View File

@ -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;

18
mmc.c
View File

@ -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 ){

View File

@ -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;