mirror of https://github.com/wb2osz/direwolf.git
				
				
				
			Better error checking.
This commit is contained in:
		
							parent
							
								
									37cb5440a6
								
							
						
					
					
						commit
						e6c721a58d
					
				
							
								
								
									
										56
									
								
								config.c
								
								
								
								
							
							
						
						
									
										56
									
								
								config.c
								
								
								
								
							|  | @ -79,8 +79,6 @@ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| //#include "tq.h"
 |  | ||||||
| 
 |  | ||||||
| /* 
 | /* 
 | ||||||
|  * Conversions from various units to meters. |  * Conversions from various units to meters. | ||||||
|  * There is some disagreement about the exact values for some of these.  |  * There is some disagreement about the exact values for some of these.  | ||||||
|  | @ -902,7 +900,7 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 
 | 
 | ||||||
| 	p_misc_config->maxframe_extended = AX25_K_MAXFRAME_EXTENDED_DEFAULT;	/* Max frames to send before ACK.  mod 128 "Window" size. */ | 	p_misc_config->maxframe_extended = AX25_K_MAXFRAME_EXTENDED_DEFAULT;	/* Max frames to send before ACK.  mod 128 "Window" size. */ | ||||||
| 
 | 
 | ||||||
| 	p_misc_config->maxv22 = AX25_N2_RETRY_DEFAULT / 2;	/* Max SABME before falling back to SABM. */ | 	p_misc_config->maxv22 = AX25_N2_RETRY_DEFAULT / 3;	/* Max SABME before falling back to SABM. */ | ||||||
| 	p_misc_config->v20_addrs = NULL;			/* Go directly to v2.0 for stations listed. */ | 	p_misc_config->v20_addrs = NULL;			/* Go directly to v2.0 for stations listed. */ | ||||||
| 	p_misc_config->v20_count = 0; | 	p_misc_config->v20_count = 0; | ||||||
| 	p_misc_config->noxid_addrs = NULL;			/* Don't send XID to these stations. */ | 	p_misc_config->noxid_addrs = NULL;			/* Don't send XID to these stations. */ | ||||||
|  | @ -1592,7 +1590,9 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| /*
 | /*
 | ||||||
|  * FIX_BITS  n  [ APRS | AX25 | NONE ] [ PASSALL ] |  * FIX_BITS  n  [ APRS | AX25 | NONE ] [ PASSALL ] | ||||||
|  * |  * | ||||||
|  *	- Attempt to fix frames with bad FCS.  |  *	- Attempt to fix frames with bad FCS. | ||||||
|  |  *	- n is maximum number of bits to attempt fixing. | ||||||
|  |  *	- Optional sanity check & allow everything even with bad FCS. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| 	  else if (strcasecmp(t, "FIX_BITS") == 0) { | 	  else if (strcasecmp(t, "FIX_BITS") == 0) { | ||||||
|  | @ -1614,16 +1614,10 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 			line, n, p_audio_config->achan[channel].fix_bits); | 			line, n, p_audio_config->achan[channel].fix_bits); | ||||||
| 	    } | 	    } | ||||||
| 
 | 
 | ||||||
| 	    if (p_audio_config->achan[channel].fix_bits > RETRY_INVERT_SINGLE) { | 	    if (p_audio_config->achan[channel].fix_bits > DEFAULT_FIX_BITS) { | ||||||
| 	      text_color_set(DW_COLOR_INFO); | 	      text_color_set(DW_COLOR_INFO); | ||||||
|               dw_printf ("Line %d: Using a FIX_BITS value greater than %d is not recommended for normal operation.\n", |               dw_printf ("Line %d: Using a FIX_BITS value greater than %d is not recommended for normal operation.\n", | ||||||
| 			line, RETRY_INVERT_SINGLE); | 			line, DEFAULT_FIX_BITS); | ||||||
| 	    } |  | ||||||
| 
 |  | ||||||
| 	    if (p_audio_config->achan[channel].fix_bits >= RETRY_INVERT_TWO_SEP) { |  | ||||||
| 	      text_color_set(DW_COLOR_INFO); |  | ||||||
|               dw_printf ("Line %d: Using a FIX_BITS value of %d will waste a lot of CPU power and produce wrong results.\n", |  | ||||||
| 			line, RETRY_INVERT_TWO_SEP); |  | ||||||
| 	    } | 	    } | ||||||
| 
 | 
 | ||||||
| 	    t = split(NULL,0); | 	    t = split(NULL,0); | ||||||
|  | @ -2209,6 +2203,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for FROM-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    from_chan = atoi(t); | 	    from_chan = atoi(t); | ||||||
| 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | @ -2233,6 +2233,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for TO-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    to_chan = atoi(t); | 	    to_chan = atoi(t); | ||||||
| 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | @ -2317,7 +2323,7 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	  } | 	  } | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * DEDUPE 		- Time to suppress digipeating of duplicate packets. |  * DEDUPE 		- Time to suppress digipeating of duplicate APRS packets. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| 	  else if (strcasecmp(t, "DEDUPE") == 0) { | 	  else if (strcasecmp(t, "DEDUPE") == 0) { | ||||||
|  | @ -2354,6 +2360,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for FROM-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    from_chan = atoi(t); | 	    from_chan = atoi(t); | ||||||
| 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | @ -2377,6 +2389,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for TO-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    to_chan = atoi(t); | 	    to_chan = atoi(t); | ||||||
| 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | @ -2416,6 +2434,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing FROM-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for FROM-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    from_chan = atoi(t); | 	    from_chan = atoi(t); | ||||||
| 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | 	    if (from_chan < 0 || from_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | @ -2443,6 +2467,12 @@ void config_init (char *fname, struct audio_s *p_audio_config, | ||||||
| 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | 	      dw_printf ("Config file: Missing TO-channel on line %d.\n", line); | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    } | 	    } | ||||||
|  | 	    if ( ! alldigits(t)) { | ||||||
|  | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  | 	      dw_printf ("Config file, line %d: '%s' is not allowed for TO-channel.  It must be a number.\n", | ||||||
|  | 							 line, t); | ||||||
|  | 	      continue; | ||||||
|  | 	    } | ||||||
| 	    to_chan = atoi(t); | 	    to_chan = atoi(t); | ||||||
| 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | 	    if (to_chan < 0 || to_chan >= MAX_CHANS) { | ||||||
| 	      text_color_set(DW_COLOR_ERROR); | 	      text_color_set(DW_COLOR_ERROR); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue