modprobe-small: make string buffer code robust; fix help text
together with previous one-liner: function old new delta append 70 99 +29 parse_module 295 311 +16 copy_stringbuf 35 36 +1 packed_usage 26545 26540 -5 appendc 27 - -27 ------------------------------------------------------------------------------ (add/remove: 0/1 grow/shrink: 3/1 up/down: 46/-32) Total: 14 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
f9c814b0ee
commit
0c6914e50c
@ -2824,9 +2824,21 @@
|
|||||||
"-rw------- 1 andersen andersen 0 Apr 25 17:10 /tmp/temp.mWiLjM\n"
|
"-rw------- 1 andersen andersen 0 Apr 25 17:10 /tmp/temp.mWiLjM\n"
|
||||||
|
|
||||||
#define modprobe_trivial_usage \
|
#define modprobe_trivial_usage \
|
||||||
"[-knqrsv] MODULE [symbol=value...]"
|
IF_MODPROBE_SMALL("[-qfwrsv] MODULE [symbol=value...]") \
|
||||||
|
IF_NOT_MODPROBE_SMALL("[-" \
|
||||||
|
IF_FEATURE_2_4_MODULES("k")"nqrsv" \
|
||||||
|
IF_FEATURE_MODPROBE_BLACKLIST("b")"] MODULE [symbol=value...]")
|
||||||
#define modprobe_full_usage "\n\n" \
|
#define modprobe_full_usage "\n\n" \
|
||||||
"Options:" \
|
"Options:" \
|
||||||
|
IF_MODPROBE_SMALL( \
|
||||||
|
"\n -q Quiet" \
|
||||||
|
"\n -f Force" \
|
||||||
|
"\n -w Wait for unload" \
|
||||||
|
"\n -r Remove module (stacks) or do autoclean" \
|
||||||
|
"\n -s Report via syslog instead of stderr" \
|
||||||
|
"\n -v Verbose" \
|
||||||
|
) \
|
||||||
|
IF_NOT_MODPROBE_SMALL( \
|
||||||
IF_FEATURE_2_4_MODULES( \
|
IF_FEATURE_2_4_MODULES( \
|
||||||
"\n -k Make module autoclean-able" \
|
"\n -k Make module autoclean-able" \
|
||||||
) \
|
) \
|
||||||
@ -2837,7 +2849,8 @@
|
|||||||
"\n -v Verbose" \
|
"\n -v Verbose" \
|
||||||
IF_FEATURE_MODPROBE_BLACKLIST( \
|
IF_FEATURE_MODPROBE_BLACKLIST( \
|
||||||
"\n -b Apply blacklist to module names too" \
|
"\n -b Apply blacklist to module names too" \
|
||||||
)
|
) \
|
||||||
|
)
|
||||||
|
|
||||||
#define modprobe_notes_usage \
|
#define modprobe_notes_usage \
|
||||||
"modprobe can (un)load a stack of modules, passing each module options (when\n" \
|
"modprobe can (un)load a stack of modules, passing each module options (when\n" \
|
||||||
|
@ -44,11 +44,13 @@ struct globals {
|
|||||||
char *module_load_options;
|
char *module_load_options;
|
||||||
smallint dep_bb_seen;
|
smallint dep_bb_seen;
|
||||||
smallint wrote_dep_bb_ok;
|
smallint wrote_dep_bb_ok;
|
||||||
int module_count;
|
unsigned module_count;
|
||||||
int module_found_idx;
|
int module_found_idx;
|
||||||
int stringbuf_idx;
|
unsigned stringbuf_idx;
|
||||||
char stringbuf[32 * 1024]; /* some modules have lots of stuff */
|
unsigned stringbuf_size;
|
||||||
|
char *stringbuf; /* some modules have lots of stuff */
|
||||||
/* for example, drivers/media/video/saa7134/saa7134.ko */
|
/* for example, drivers/media/video/saa7134/saa7134.ko */
|
||||||
|
/* therefore having a fixed biggish buffer is not wise */
|
||||||
};
|
};
|
||||||
#define G (*ptr_to_globals)
|
#define G (*ptr_to_globals)
|
||||||
#define modinfo (G.modinfo )
|
#define modinfo (G.modinfo )
|
||||||
@ -58,16 +60,29 @@ struct globals {
|
|||||||
#define module_found_idx (G.module_found_idx )
|
#define module_found_idx (G.module_found_idx )
|
||||||
#define module_load_options (G.module_load_options)
|
#define module_load_options (G.module_load_options)
|
||||||
#define stringbuf_idx (G.stringbuf_idx )
|
#define stringbuf_idx (G.stringbuf_idx )
|
||||||
|
#define stringbuf_size (G.stringbuf_size )
|
||||||
#define stringbuf (G.stringbuf )
|
#define stringbuf (G.stringbuf )
|
||||||
#define INIT_G() do { \
|
#define INIT_G() do { \
|
||||||
SET_PTR_TO_GLOBALS(xzalloc(sizeof(G))); \
|
SET_PTR_TO_GLOBALS(xzalloc(sizeof(G))); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
static void append(const char *s)
|
||||||
|
{
|
||||||
|
unsigned len = strlen(s);
|
||||||
|
if (stringbuf_idx + len + 15 > stringbuf_size) {
|
||||||
|
stringbuf_size = stringbuf_idx + len + 127;
|
||||||
|
dbg2_error_msg("grow stringbuf to %u", stringbuf_size);
|
||||||
|
stringbuf = xrealloc(stringbuf, stringbuf_size);
|
||||||
|
}
|
||||||
|
memcpy(stringbuf + stringbuf_idx, s, len);
|
||||||
|
stringbuf_idx += len;
|
||||||
|
}
|
||||||
|
|
||||||
static void appendc(char c)
|
static void appendc(char c)
|
||||||
{
|
{
|
||||||
if (stringbuf_idx < sizeof(stringbuf))
|
/* We appendc() only after append(), + 15 trick in append()
|
||||||
stringbuf[stringbuf_idx++] = c;
|
* makes it unnecessary to check for overflow here */
|
||||||
|
stringbuf[stringbuf_idx++] = c;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bksp(void)
|
static void bksp(void)
|
||||||
@ -76,15 +91,6 @@ static void bksp(void)
|
|||||||
stringbuf_idx--;
|
stringbuf_idx--;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void append(const char *s)
|
|
||||||
{
|
|
||||||
size_t len = strlen(s);
|
|
||||||
if (stringbuf_idx + len < sizeof(stringbuf)) {
|
|
||||||
memcpy(stringbuf + stringbuf_idx, s, len);
|
|
||||||
stringbuf_idx += len;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void reset_stringbuf(void)
|
static void reset_stringbuf(void)
|
||||||
{
|
{
|
||||||
stringbuf_idx = 0;
|
stringbuf_idx = 0;
|
||||||
@ -92,7 +98,7 @@ static void reset_stringbuf(void)
|
|||||||
|
|
||||||
static char* copy_stringbuf(void)
|
static char* copy_stringbuf(void)
|
||||||
{
|
{
|
||||||
char *copy = xmalloc(stringbuf_idx);
|
char *copy = xzalloc(stringbuf_idx + 1); /* terminating NUL */
|
||||||
return memcpy(copy, stringbuf, stringbuf_idx);
|
return memcpy(copy, stringbuf, stringbuf_idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,7 +222,6 @@ static void parse_module(module_info *info, const char *pathname)
|
|||||||
pos = (ptr - module_image);
|
pos = (ptr - module_image);
|
||||||
}
|
}
|
||||||
bksp(); /* remove last ' ' */
|
bksp(); /* remove last ' ' */
|
||||||
appendc('\0');
|
|
||||||
info->aliases = copy_stringbuf();
|
info->aliases = copy_stringbuf();
|
||||||
replace(info->aliases, '-', '_');
|
replace(info->aliases, '-', '_');
|
||||||
|
|
||||||
@ -229,7 +234,6 @@ static void parse_module(module_info *info, const char *pathname)
|
|||||||
dbg2_error_msg("dep:'%s'", ptr);
|
dbg2_error_msg("dep:'%s'", ptr);
|
||||||
append(ptr);
|
append(ptr);
|
||||||
}
|
}
|
||||||
appendc('\0');
|
|
||||||
info->deps = copy_stringbuf();
|
info->deps = copy_stringbuf();
|
||||||
|
|
||||||
free(module_image);
|
free(module_image);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user