2004-01-29 20:01:11 -05:00
|
|
|
$OpenBSD: patch-gputils_dump_c,v 1.3 2004/01/30 01:01:11 naddy Exp $
|
|
|
|
--- gputils/dump.c.orig 2004-01-02 10:29:37.000000000 +1100
|
|
|
|
+++ gputils/dump.c 2004-01-25 20:46:55.000000000 +1100
|
2004-01-14 17:19:28 -05:00
|
|
|
@@ -28,10 +28,12 @@ Boston, MA 02111-1307, USA. */
|
|
|
|
|
|
|
|
int number_of_source_files = 0;
|
|
|
|
|
|
|
|
-char *substr(char *a, char *b, int n)
|
|
|
|
+char *substr(char *a, size_t sizeof_a, char *b, size_t n)
|
|
|
|
{
|
|
|
|
- *a = 0;
|
|
|
|
- return strncat(a,b,n);
|
|
|
|
+ strlcpy(a, b, sizeof_a);
|
|
|
|
+ if (n < sizeof_a)
|
|
|
|
+ a[n] = 0;
|
|
|
|
+ return a;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2004-01-29 20:01:11 -05:00
|
|
|
@@ -283,7 +285,7 @@ void dump_symbols( void )
|
2004-01-14 17:19:28 -05:00
|
|
|
|
|
|
|
if(temp[i*SSYMBOL_SIZE + SR_NAME])
|
|
|
|
printf("%s = %x, type = %s\n",
|
|
|
|
- substr(b,&temp[i*SSYMBOL_SIZE + SR_NAME],12),
|
|
|
|
+ substr(b, sizeof(b), &temp[i*SSYMBOL_SIZE + SR_NAME],12),
|
2004-01-29 20:01:11 -05:00
|
|
|
gp_getu16(&temp[i*SSYMBOL_SIZE + SR_VALUE]),
|
2004-01-14 17:19:28 -05:00
|
|
|
SymbolType4[(unsigned char)temp[i*SSYMBOL_SIZE + SR_TYPE]]
|
|
|
|
);
|
2004-01-29 20:01:11 -05:00
|
|
|
@@ -335,7 +337,7 @@ void dump_lsymbols( void )
|
2004-01-14 17:19:28 -05:00
|
|
|
value = gp_getb32(&s[length+3]);
|
|
|
|
|
|
|
|
printf("%s = %x, type = %s\n",
|
|
|
|
- substr(b,&s[1],length),
|
|
|
|
+ substr(b, sizeof(b), &s[1],length),
|
|
|
|
value,
|
|
|
|
SymbolType4[type]);
|
|
|
|
i += (length + 7);
|
2004-01-29 20:01:11 -05:00
|
|
|
@@ -375,12 +377,14 @@ void dump_source_files( void )
|
2004-01-14 17:19:28 -05:00
|
|
|
for(i=0; i<FILES_PER_BLOCK; i++) {
|
|
|
|
|
|
|
|
offset = i*FILE_SIZE;
|
|
|
|
- substr(b,&temp[offset+1],FILE_SIZE);
|
|
|
|
+ substr(b, sizeof(b), &temp[offset+1],FILE_SIZE);
|
2003-11-02 20:02:34 -05:00
|
|
|
|
|
|
|
if(temp[offset]) {
|
|
|
|
- source_file_names[number_of_source_files] =
|
|
|
|
- (char *)malloc(strlen(b) + 1);
|
|
|
|
- strcpy(source_file_names[number_of_source_files],b);
|
|
|
|
+ source_file_names[number_of_source_files] = strdup(b);
|
|
|
|
+ if (!source_file_names[number_of_source_files]) {
|
|
|
|
+ err(1, NULL);
|
|
|
|
+ exit(1);
|
|
|
|
+ }
|
|
|
|
printf("%s\n",source_file_names[number_of_source_files]);
|
|
|
|
source_files[number_of_source_files] =
|
|
|
|
fopen(source_file_names[number_of_source_files],"rt");
|
2004-01-29 20:01:11 -05:00
|
|
|
@@ -507,7 +511,7 @@ void dump_message_area(void)
|
2004-01-14 17:19:28 -05:00
|
|
|
|
|
|
|
DebugType = temp[j++];
|
|
|
|
|
|
|
|
- substr(DebugMessage,&temp[j],64);
|
|
|
|
+ substr(DebugMessage, sizeof(DebugMessage), &temp[j],64);
|
|
|
|
j += strlen(DebugMessage);
|
|
|
|
|
|
|
|
printf("%8x %2d %s\n",laddress, DebugType, DebugMessage);
|