diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2019-10-25 12:12:22 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2019-10-25 12:12:22 +0200 |
commit | af7169b4a70eb3f60555ced17a40780f70aaaa5c (patch) | |
tree | 1633c3306b7d538fb44b12d27ec299e8db0f35fa /shell | |
parent | e1a7c97ac640701973eea000007fc8b9f9dd7126 (diff) | |
download | busybox-w32-af7169b4a70eb3f60555ced17a40780f70aaaa5c.tar.gz busybox-w32-af7169b4a70eb3f60555ced17a40780f70aaaa5c.tar.bz2 busybox-w32-af7169b4a70eb3f60555ced17a40780f70aaaa5c.zip |
clang/llvm 9 fix - do not eliminate a store to a fake "const"
This is *much* better (9 kbytes better) than dropping "*const"
optimization trick.
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'shell')
-rw-r--r-- | shell/ash.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/shell/ash.c b/shell/ash.c index c5588ea66..4b5eafa7c 100644 --- a/shell/ash.c +++ b/shell/ash.c | |||
@@ -489,7 +489,7 @@ extern struct globals_misc *BB_GLOBAL_CONST ash_ptr_to_globals_misc; | |||
489 | #define random_gen (G_misc.random_gen ) | 489 | #define random_gen (G_misc.random_gen ) |
490 | #define backgndpid (G_misc.backgndpid ) | 490 | #define backgndpid (G_misc.backgndpid ) |
491 | #define INIT_G_misc() do { \ | 491 | #define INIT_G_misc() do { \ |
492 | (*(struct globals_misc**)&ash_ptr_to_globals_misc) = xzalloc(sizeof(G_misc)); \ | 492 | (*(struct globals_misc**)not_const_pp(&ash_ptr_to_globals_misc)) = xzalloc(sizeof(G_misc)); \ |
493 | barrier(); \ | 493 | barrier(); \ |
494 | curdir = nullstr; \ | 494 | curdir = nullstr; \ |
495 | physdir = nullstr; \ | 495 | physdir = nullstr; \ |
@@ -1542,7 +1542,7 @@ extern struct globals_memstack *BB_GLOBAL_CONST ash_ptr_to_globals_memstack; | |||
1542 | #define g_stacknleft (G_memstack.g_stacknleft) | 1542 | #define g_stacknleft (G_memstack.g_stacknleft) |
1543 | #define stackbase (G_memstack.stackbase ) | 1543 | #define stackbase (G_memstack.stackbase ) |
1544 | #define INIT_G_memstack() do { \ | 1544 | #define INIT_G_memstack() do { \ |
1545 | (*(struct globals_memstack**)&ash_ptr_to_globals_memstack) = xzalloc(sizeof(G_memstack)); \ | 1545 | (*(struct globals_memstack**)not_const_pp(&ash_ptr_to_globals_memstack)) = xzalloc(sizeof(G_memstack)); \ |
1546 | barrier(); \ | 1546 | barrier(); \ |
1547 | g_stackp = &stackbase; \ | 1547 | g_stackp = &stackbase; \ |
1548 | g_stacknxt = stackbase.space; \ | 1548 | g_stacknxt = stackbase.space; \ |
@@ -2165,7 +2165,7 @@ extern struct globals_var *BB_GLOBAL_CONST ash_ptr_to_globals_var; | |||
2165 | #endif | 2165 | #endif |
2166 | #define INIT_G_var() do { \ | 2166 | #define INIT_G_var() do { \ |
2167 | unsigned i; \ | 2167 | unsigned i; \ |
2168 | (*(struct globals_var**)&ash_ptr_to_globals_var) = xzalloc(sizeof(G_var)); \ | 2168 | (*(struct globals_var**)not_const_pp(&ash_ptr_to_globals_var)) = xzalloc(sizeof(G_var)); \ |
2169 | barrier(); \ | 2169 | barrier(); \ |
2170 | for (i = 0; i < ARRAY_SIZE(varinit_data); i++) { \ | 2170 | for (i = 0; i < ARRAY_SIZE(varinit_data); i++) { \ |
2171 | varinit[i].flags = varinit_data[i].flags; \ | 2171 | varinit[i].flags = varinit_data[i].flags; \ |