summaryrefslogtreecommitdiff
path: root/networking/telnet.c
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2007-06-04 10:16:52 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2007-06-04 10:16:52 +0000
commit74324c86663f57a19c1de303ee8c8e5449db9ef2 (patch)
tree11f5da9de4212875ce5811be2e1050e076378c9a /networking/telnet.c
parent4e5f82c76f08614d0b69f9ec4a8baac303af15f6 (diff)
downloadbusybox-w32-74324c86663f57a19c1de303ee8c8e5449db9ef2.tar.gz
busybox-w32-74324c86663f57a19c1de303ee8c8e5449db9ef2.tar.bz2
busybox-w32-74324c86663f57a19c1de303ee8c8e5449db9ef2.zip
Audit bb_common_bufsiz usage, add script which looks for misuse.
tr: stop using globals needlessly. code: -103 bytes
Diffstat (limited to 'networking/telnet.c')
-rw-r--r--networking/telnet.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/networking/telnet.c b/networking/telnet.c
index caca89d2d..a634d7a2b 100644
--- a/networking/telnet.c
+++ b/networking/telnet.c
@@ -52,7 +52,6 @@ enum {
52 52
53typedef unsigned char byte; 53typedef unsigned char byte;
54 54
55
56struct globals { 55struct globals {
57 int netfd; /* console fd:s are 0 and 1 (and 2) */ 56 int netfd; /* console fd:s are 0 and 1 (and 2) */
58 short iaclen; /* could even use byte */ 57 short iaclen; /* could even use byte */
@@ -78,9 +77,13 @@ struct globals {
78 struct termios termios_def; 77 struct termios termios_def;
79 struct termios termios_raw; 78 struct termios termios_raw;
80}; 79};
81
82#define G (*(struct globals*)&bb_common_bufsiz1) 80#define G (*(struct globals*)&bb_common_bufsiz1)
83 81void BUG_telnet_globals_too_big(void);
82#define INIT_G() do { \
83 if (sizeof(G) > COMMON_BUFSIZE) \
84 BUG_telnet_globals_too_big(); \
85 /* memset(&G, 0, sizeof G); - already is */ \
86} while (0)
84 87
85/* Function prototypes */ 88/* Function prototypes */
86static void rawmode(void); 89static void rawmode(void);
@@ -547,8 +550,6 @@ static void cookmode(void)
547 tcsetattr(0, TCSADRAIN, &G.termios_def); 550 tcsetattr(0, TCSADRAIN, &G.termios_def);
548} 551}
549 552
550void BUG_telnet_globals_too_big(void);
551
552int telnet_main(int argc, char** argv); 553int telnet_main(int argc, char** argv);
553int telnet_main(int argc, char** argv) 554int telnet_main(int argc, char** argv)
554{ 555{
@@ -562,9 +563,7 @@ int telnet_main(int argc, char** argv)
562 int maxfd; 563 int maxfd;
563#endif 564#endif
564 565
565 if (sizeof(G) > sizeof(bb_common_bufsiz1)) 566 INIT_G();
566 BUG_telnet_globals_too_big();
567 /* memset(&G, 0, sizeof G); - already is */
568 567
569#if ENABLE_FEATURE_AUTOWIDTH 568#if ENABLE_FEATURE_AUTOWIDTH
570 get_terminal_width_height(0, &G.win_width, &G.win_height); 569 get_terminal_width_height(0, &G.win_width, &G.win_height);