So I have a problem that I can not figure out. I am writing some code in C. I kept winding up with issues where reading from the network would seemly randomly work.
I finally traced it down to the number of strings in the code. I cant believe it but I have verified it pretty in depth.
The code base is rather massive so I am not sure of the overall number of strings parity. However I know that if i add an odd number then the program works, and if i add an even number it doesnt.
Just to clarify when I say it doesnt work, It does still build and execute, but everytime I try to read anything over the network all i get is 0's. When its working I get the correct data.
has anyone ever heard of anything like this? Or have any idea what could be causing this? I could see if the data portion of the program was getting too large and starting to impede on other code's space but the fact that its an odd/even thing completely confuses me.
thanks
EDIT (Adding more info):
The platform is a custom designed device. the code base is redboot but its been altered significantly for the custom device.
snipped for example:
//This will work because its an odd number of strings.
char* str1 = "test";
char* str2 = "test2";
char* str3 = "test3";
int i = strlen(str1) + strlen(str2) + strlen(str3);
......................................
if i were to change the last line to
int i = strlen(str1) + str(len2);
so that str3 gets optimized out by the compiler then the code will no longer work. I have tested this many times with various lenghts of strings all result in the same odd/even behavior. (i is just sent to a debug log so that its not optimized out. nothing fancy is done with it).
Edit2: The above code can be placed anywhere in the codebase and it causes the same problem. It doesnt matter if its been executed or not, which leads me to believe its not a stack overflow.