[SOLVED]Multitasking Bugs

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
simeonz
Member
Member
Posts: 360
Joined: Fri Aug 19, 2016 10:28 pm

Re: Multitasking Bugs

Post by simeonz »

Octocontrabass wrote:
simeonz wrote:What do you mean by "free to optimize"? If you mean that "__attribute__((optimize("-fno-omit-frame-pointer")))" is not ANSI C, then you are obviously correct. But neither is "stack pointer". You couldn't busy loop without going outside the canonical C.
I mean that GCC is free to generate ESP-relative addresses regardless of optimization parameters, and there is no specific guarantee that -fno-omit-frame-pointer will prevent it from doing so.
What do you mean by "no specific guarantee"? Doesn't gcc currently guarantee the exact semantics of those options, even if the disabling flags are not always described explicitly. But take "fno-defer-pop" for example, which is documented. It has strict meaning. Not like say, using "inline" specifier to a function definition. I am not questioning that these options may not be reliable for future use, but even the linux kernel uses "-fno-omit-frame-pointer" to get proper traces, and may be a few other things.
Octocontrabass wrote:
simeonz wrote:You relax the constraint and it happens to work. How could remark about behavior volatility and offer this suggestion? I agree that using the operand constraints is a better fix per se. "=r" would be a stricter constraint, and could/should work.
Relaxing the constraint is an optimization. The bug fix is ensuring that ESP-relative addresses will be calculated correctly if GCC chooses to use them. Intel specifies that POP with a memory operand using ESP as a base register will increment ESP before calculating the effective address. Combined with the previous decrement from PUSH, the result is that an effective address with ESP will be calculated the way GCC expects.
The subtle change didn't capture my attention. Yes, this will work better. Again, undeniably better solution then mine.
davidv1992
Member
Member
Posts: 223
Joined: Thu Jul 05, 2007 8:58 am

Re: Multitasking Bugs

Post by davidv1992 »

simeonz wrote:
Octocontrabass wrote:
simeonz wrote:What do you mean by "free to optimize"? If you mean that "__attribute__((optimize("-fno-omit-frame-pointer")))" is not ANSI C, then you are obviously correct. But neither is "stack pointer". You couldn't busy loop without going outside the canonical C.
I mean that GCC is free to generate ESP-relative addresses regardless of optimization parameters, and there is no specific guarantee that -fno-omit-frame-pointer will prevent it from doing so.
What do you mean by "no specific guarantee"? Doesn't gcc currently guarantee the exact semantics of those options, even if the disabling flags are not always described explicitly. But take "fno-defer-pop" for example, which is documented. It has strict meaning. Not like say, using "inline" specifier to a function definition. I am not questioning that these options may not be reliable for future use, but even the linux kernel uses "-fno-omit-frame-pointer" to get proper traces, and may be a few other things.
GCC does guarantee semantics of those options, at least for the current version. The problem is that the option you currently use does not guarantee what it thinks you guarantees. It only guarantees that ebp functions as the frame pointer. IT DOES NOT guarantee that gcc will actually use ebp to access local variables. If it thinks the resulting code might be more efficient using esp-relative accesses, it will use that as it wants. Hence, you are still not sure it will work correctly.
simeonz
Member
Member
Posts: 360
Joined: Fri Aug 19, 2016 10:28 pm

Re: Multitasking Bugs

Post by simeonz »

davidv1992 wrote:
simeonz wrote:
Octocontrabass wrote: I mean that GCC is free to generate ESP-relative addresses regardless of optimization parameters, and there is no specific guarantee that -fno-omit-frame-pointer will prevent it from doing so.
What do you mean by "no specific guarantee"? Doesn't gcc currently guarantee the exact semantics of those options, even if the disabling flags are not always described explicitly. But take "fno-defer-pop" for example, which is documented. It has strict meaning. Not like say, using "inline" specifier to a function definition. I am not questioning that these options may not be reliable for future use, but even the linux kernel uses "-fno-omit-frame-pointer" to get proper traces, and may be a few other things.
GCC does guarantee semantics of those options, at least for the current version. The problem is that the option you currently use does not guarantee what it thinks you guarantees. It only guarantees that ebp functions as the frame pointer. IT DOES NOT guarantee that gcc will actually use ebp to access local variables. If it thinks the resulting code might be more efficient using esp-relative accesses, it will use that as it wants. Hence, you are still not sure it will work correctly.
I cannot coerce it to fail at the moment, but your statement sounds correct. In other words, there is no way to perform alloca style adjustment to esp midway a C frame. Well, that is unfortunate. There are certain cases where this is convenient (such as dynamically performing stack realignment from C), and I was under the impression that it works, but apparently I got lucky. Looking at the glibc headers, I see that alloca is declared as __builtin_alloca, which explains how it manages to coerce the compiler to do what my use of this option is apparently not able to do. Thanks for the clarification to both of you.

P.S. To the OP if you are reading this. To keep the behavior stable, do remove the function attribute and use some of the other proposed solutions.
Post Reply