Extended numbering is used for any of these fields overflowing.
Details
Diff Detail
- Lint
No Lint Coverage - Unit
No Test Coverage - Build Status
Buildable 6131 Build 6388: arc lint + arc unit
Event Timeline
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
196 | What's the story with the or in the previous case? |
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
190 | This check should be shnum == 0, not !=. | |
196 | My change to it is slightly wrong. I think the shoff check should just be removed. The directly preceding if statement verifies that extended ELF objects have a section header table (shoff != 0). (Modulo a small bug.) So in this condition, we can just check for an non-extended ELF object directly (shnum != 0 && phnum != PN_XNUM && strndx != SHN_XINDEX) and ignore shoff. |
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
173–176 | I suspect this comment belongs below instead. | |
190 | I think shnum != 0 is correct. We're looking for invalid values or combinations of values.
Or maybe the test should be (shoff == 0 || shnum == 0) && (phnum == PN_XNUM || strndx == SHN_XINDEX) | |
196 | I think if we change to the test suggested above this can be just phnum != PN_XNUM && strndx != SHN_XINDEX |
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
173–176 | Yeah, agreed. | |
190 | I think you're right re: shnum != 0. http://docs.oracle.com/cd/E19253-01/817-1984/chapter6-46512/index.html:
So zero is overloaded and we need shoff to determine whether this is an extended shnum or empty section header table. I don't think the proposed test is correct, since shoff != 0 && shnum == 0 && phnum == PN_XNUM is valid (both shnum and phnum are extended). | |
196 | Both are wrong, I think. We need phnum != PN_XNUM && strndx != SHN_XINDEX and also need to exclude objects with only extended shnum (shnum == 0 && shoff != 0). |
- Move old comment down to a more correct location.
- Revert change in shnum sense. It was right before.
- Fix check for extended values and simplify boolean expression by inverting the sense.
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
200 | Should this be the opposite of the test above, i.e. shoff != 0 && (shnum == 0 || phnum == PN_XNUM || strndx == SHN_XINDEX)? |
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
200 | Those should be functionally identical after the previous if statement/return. |
I believe this is correct. @kaiw if you're going to review as well I'll hold off on committing it to the upstream elftoolchain repo until then.
contrib/elftoolchain/libelf/libelf_ehdr.c | ||
---|---|---|
200 | I was thinking the intent would be more clear with the other formulation, but I suppose shnum == 0 && shoff != 0 is a complete condition for one case of extended numbering. OK. |