diff options
| author | Denys Vlasenko <vda.linux@googlemail.com> | 2010-02-21 05:39:59 +0100 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-02-21 05:39:59 +0100 |
| commit | bef5711dab5b78dcaafb33a7f0071dfd90188fe1 (patch) | |
| tree | d1f741bcd7209db3bbe8e1ffe28aa9accb31f33b | |
| parent | 153fcaa6c17124ebbf0d50df5da95f3564c7402b (diff) | |
| download | busybox-w32-bef5711dab5b78dcaafb33a7f0071dfd90188fe1.tar.gz busybox-w32-bef5711dab5b78dcaafb33a7f0071dfd90188fe1.tar.bz2 busybox-w32-bef5711dab5b78dcaafb33a7f0071dfd90188fe1.zip | |
free: code shrink
function old new delta
free_main 330 302 -28
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
| -rw-r--r-- | procps/free.c | 83 |
1 files changed, 48 insertions, 35 deletions
diff --git a/procps/free.c b/procps/free.c index e8bea5064..a941b6252 100644 --- a/procps/free.c +++ b/procps/free.c | |||
| @@ -15,54 +15,67 @@ int free_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | |||
| 15 | int free_main(int argc UNUSED_PARAM, char **argv) | 15 | int free_main(int argc UNUSED_PARAM, char **argv) |
| 16 | { | 16 | { |
| 17 | struct sysinfo info; | 17 | struct sysinfo info; |
| 18 | unsigned mem_unit; | ||
| 19 | |||
| 20 | #if ENABLE_DESKTOP | ||
| 21 | if (argv[1] && argv[1][0] == '-') | ||
| 22 | bb_show_usage(); | ||
| 23 | #endif | ||
| 24 | |||
| 18 | sysinfo(&info); | 25 | sysinfo(&info); |
| 19 | 26 | ||
| 20 | /* Kernels prior to 2.4.x will return info.mem_unit==0, so cope... */ | 27 | /* Kernels prior to 2.4.x will return info.mem_unit==0, so cope... */ |
| 21 | if (info.mem_unit == 0) { | 28 | mem_unit = 1; |
| 22 | info.mem_unit=1; | 29 | if (info.mem_unit != 0) { |
| 30 | mem_unit = info.mem_unit; | ||
| 23 | } | 31 | } |
| 24 | if (info.mem_unit == 1) { | ||
| 25 | info.mem_unit=1024; | ||
| 26 | 32 | ||
| 27 | /* TODO: Make all this stuff not overflow when mem >= 4 Gib */ | 33 | /* Convert values to kbytes */ |
| 28 | info.totalram/=info.mem_unit; | 34 | if (mem_unit == 1) { |
| 29 | info.freeram/=info.mem_unit; | 35 | info.totalram >>= 10; |
| 36 | info.freeram >>= 10; | ||
| 30 | #if BB_MMU | 37 | #if BB_MMU |
| 31 | info.totalswap/=info.mem_unit; | 38 | info.totalswap >>= 10; |
| 32 | info.freeswap/=info.mem_unit; | 39 | info.freeswap >>= 10; |
| 33 | #endif | 40 | #endif |
| 34 | info.sharedram/=info.mem_unit; | 41 | info.sharedram >>= 10; |
| 35 | info.bufferram/=info.mem_unit; | 42 | info.bufferram >>= 10; |
| 36 | } else { | 43 | } else { |
| 37 | info.mem_unit/=1024; | 44 | mem_unit >>= 10; |
| 38 | /* TODO: Make all this stuff not overflow when mem >= 4 Gib */ | 45 | /* TODO: Make all this stuff not overflow when mem >= 4 Tb */ |
| 39 | info.totalram*=info.mem_unit; | 46 | info.totalram *= mem_unit; |
| 40 | info.freeram*=info.mem_unit; | 47 | info.freeram *= mem_unit; |
| 41 | #if BB_MMU | 48 | #if BB_MMU |
| 42 | info.totalswap*=info.mem_unit; | 49 | info.totalswap *= mem_unit; |
| 43 | info.freeswap*=info.mem_unit; | 50 | info.freeswap *= mem_unit; |
| 44 | #endif | 51 | #endif |
| 45 | info.sharedram*=info.mem_unit; | 52 | info.sharedram *= mem_unit; |
| 46 | info.bufferram*=info.mem_unit; | 53 | info.bufferram *= mem_unit; |
| 47 | } | 54 | } |
| 48 | 55 | ||
| 49 | if (argv[1] && argv[1][0] == '-') | 56 | printf(" %13s%13s%13s%13s%13s\n", |
| 50 | bb_show_usage(); | 57 | "total", |
| 51 | 58 | "used", | |
| 52 | printf("%6s%13s%13s%13s%13s%13s\n", "", "total", "used", "free", | 59 | "free", |
| 53 | "shared", "buffers"); | 60 | "shared", "buffers" /* swap and total don't have these columns */ |
| 54 | 61 | ); | |
| 55 | printf("%6s%13ld%13ld%13ld%13ld%13ld\n", "Mem:", info.totalram, | 62 | printf("%6s%13lu%13lu%13lu%13lu%13lu\n", "Mem:", |
| 56 | info.totalram-info.freeram, info.freeram, | 63 | info.totalram, |
| 57 | info.sharedram, info.bufferram); | 64 | info.totalram - info.freeram, |
| 58 | 65 | info.freeram, | |
| 66 | info.sharedram, info.bufferram | ||
| 67 | ); | ||
| 59 | #if BB_MMU | 68 | #if BB_MMU |
| 60 | printf("%6s%13ld%13ld%13ld\n", "Swap:", info.totalswap, | 69 | printf("%6s%13lu%13lu%13lu\n", "Swap:", |
| 61 | info.totalswap-info.freeswap, info.freeswap); | 70 | info.totalswap, |
| 62 | 71 | info.totalswap - info.freeswap, | |
| 63 | printf("%6s%13ld%13ld%13ld\n", "Total:", info.totalram+info.totalswap, | 72 | info.freeswap |
| 64 | (info.totalram-info.freeram)+(info.totalswap-info.freeswap), | 73 | ); |
| 65 | info.freeram+info.freeswap); | 74 | printf("%6s%13lu%13lu%13lu\n", "Total:", |
| 75 | info.totalram + info.totalswap, | ||
| 76 | (info.totalram - info.freeram) + (info.totalswap - info.freeswap), | ||
| 77 | info.freeram + info.freeswap | ||
| 78 | ); | ||
| 66 | #endif | 79 | #endif |
| 67 | return EXIT_SUCCESS; | 80 | return EXIT_SUCCESS; |
| 68 | } | 81 | } |
