Login
User Name:

Password:



Register

Forgot your password?
void nanny_get_new_race -- comm.c
Mar 13, 2025 7:08 am
By Elwood
IPv6
Jan 25, 2025 10:45 pm
By Samson
mudstrlcpy and mudstrlcat
Jan 18, 2025 5:23 pm
By Samson
I3 and IMC
Jan 17, 2025 9:35 pm
By Samson
AFKMud 2.5.1
Jan 17, 2025 2:22 pm
By Samson
SWFotEFUSS 1.5.3
Author: Various
Submitted by: Samson
SWRFUSS 1.4.3
Author: Various
Submitted by: Samson
SmaugFUSS 1.9.8
Author: Various
Submitted by: Samson
AFKMud 2.5.2
Author: AFKMud Team
Submitted by: Samson
SmaugFUSS 1.9.7
Author: Various
Submitted by: Samson
Users Online
Anthropic, Sogou, AhrefsBot, Yandex, Bytespider

Members: 0
Guests: 9
Stats
Files
Topics
Posts
Members
Newest Member
507
3,812
19,722
591
TracySpencer

» SmaugMuds » Bugfix Lists » SmaugFUSS Bugfix List » [Bug] Telnet control characte...
Forum Rules | Mark all | Recent Posts

[Bug] Telnet control character arrays are of the wrong type.
< Newer Topic :: Older Topic >

Pages:<< prev 1 next >>
Post is unread #1 Oct 16, 2010 12:09 am   Last edited Oct 16, 2010 12:10 am by Samson
Go to the top of the page
Go to the bottom of the page

Samson
Black Hand
GroupAdministrators
Posts3,707
JoinedJan 1, 2002

 
Bug: Telnet control character arrays are of the wrong type.
Danger: Low - May or may not be interfering with the use of the telnet IAC command.
Found by: Bobo
Fixed by: David/Samson

---

comm.c

Locate:
const char echo_off_str[] = { ( char )IAC, ( char )WILL, TELOPT_ECHO, '\0' };
const char echo_on_str[] = { ( char )IAC, ( char )WONT, TELOPT_ECHO, '\0' };
const char go_ahead_str[] = { ( char )IAC, ( char )GA, '\0' };


Replace with:
const unsigned char echo_off_str[] = { IAC, WILL, TELOPT_ECHO, '\0' };
const unsigned char echo_on_str[] = { IAC, WONT, TELOPT_ECHO, '\0' };
const unsigned char go_ahead_str[] = { IAC, GA, '\0' };


In new_descriptor, locate:
   write_to_buffer( dnew, will_compress2_str, 0 );


Change to:
   write_to_buffer( dnew, (const char *)will_compress2_str, 0 );


In flush_buffer, locate:
         write_to_buffer( d, go_ahead_str, 0 );


Change to:
         write_to_buffer( d, (const char *)go_ahead_str, 0 );


In nanny_get_name, locate:
      write_to_buffer( d, echo_off_str, 0 );


Change to:
      write_to_buffer( d, (const char *)echo_off_str, 0 );


In nanny_get_old_password, locate:
   write_to_buffer( d, echo_on_str, 0 );


Change to:
   write_to_buffer( d, (const char *)echo_on_str, 0 );


In nanny_confirm_new_password, locate:
   write_to_buffer( d, echo_on_str, 0 );


Change to:
   write_to_buffer( d, (const char *)echo_on_str, 0 );


mccp.c

Locate:
char will_compress2_str[] = { ( char )IAC, ( char )WILL, TELOPT_COMPRESS2, '\0' };
char start_compress2_str[] = { ( char )IAC, ( char )SB, TELOPT_COMPRESS2, ( char )IAC, ( char )SE, '\0' };


Change to:
const unsigned char will_compress2_str[] = { IAC, WILL, TELOPT_COMPRESS2, '\0' };
const unsigned char start_compress2_str[] = { IAC, SB, TELOPT_COMPRESS2, IAC, SE, '\0' };


In compressStart, locate:
   write_to_descriptor( d, start_compress2_str, 0 );


Change to:
   write_to_descriptor( d, (const char *)start_compress2_str, 0 );


mccp.h

Locate:
extern char will_compress2_str[];
extern char start_compress2_str[];


Change to:
extern const unsigned char will_compress2_str[];
extern const unsigned char start_compress2_str[];


Telnet opt codes exist in the high range of an unsigned char. The arrays as defined were set up as signed chars, and therefore it was entirely possible the values could be interpreted wrong when assigned.

This was originally reported here: http://www.gammon.com.au/forum/?id=10662

Pages:<< prev 1 next >>