Page MenuHomeFreeBSD

Add a tool to modify control features in ELF binaries
ClosedPublic

Authored by emaste on Feb 22 2019, 1:00 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 5, 11:46 PM
Unknown Object (File)
Sun, Jan 5, 8:55 AM
Unknown Object (File)
Sun, Jan 5, 8:46 AM
Unknown Object (File)
Sun, Jan 5, 8:44 AM
Unknown Object (File)
Fri, Jan 3, 5:58 AM
Unknown Object (File)
Dec 16 2024, 6:49 PM
Unknown Object (File)
Nov 28 2024, 11:13 AM
Unknown Object (File)
Nov 25 2024, 8:34 PM
Subscribers

Details

Summary

Add a tool to modify control features in ELF binaries.

Submitted by: Bora Ozarslan borako.ozarslan@gmail.com

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

tools/tools/controlelf/Makefile
5

This is not needed, right ?

7

And this.

24

Why this is needed ? Perhaps you should use #include "" instead of <>.

25

And what is this ?

28

Bump WARNS to max, and perhaps make warnings an error. New code should be clean.

tools/tools/controlelf/controlelf.1
2

Really ?

tools/tools/controlelf/controlelf.c
161

Extra blank line.

162

if (elf != NULL)

165

Checking for error from close(2) is almost always pointless, perhaps except for EBADF.

187

Blank line after '{' if no locals.

192

Use bool's ?

200

return (0);

201

I do not understand this loop, in particular the condition inside the if().

213

No initializers in local declarations.

227

nitems()

246

Excess ().

262

return on the next line.

316

Check for error from lseek.

320

Check errors from read, check for short reads.

327

roundup2().

328

sizeof(char) is sillyness. Why do you need calloc at all ?

337

This is yet another incorrect use of strncmp. At least you must check that strlen(name) == 7.

346

Why this cast ? It looks arbitrary.

363

branch statement on the next line.

tools/tools/controlelf/controlelf.c
201

if (gelf_getphdr(elf, i, phdr) == NULL) probably

213

FWIW this is part of style(9) I dislike, but it is what it is.

tools/tools/controlelf/controlelf.1
25–26

These two lines should be replaced with just:

.\" $FreeBSD$
borako.ozarslan_gmail.com added inline comments.
tools/tools/controlelf/controlelf.c
201

Essentially the for loop is going through each program header and finding the one that is of type PT_NOTE and returning that. In libelf, the recommended way to enumerate through the program headers is this way. The program header is returned inside the phdr which is given as a parameter. The function gelf_getphdr gets the ith program header and replaces the values inside the phdr. On success it returns phdr (the address given to it) and on failure it returns NULL. So that's what the first if is checking for, if the function succeeded or not. Then the second if checks if this program header is of type PT_NOTE. I now see that there may be more than 1 PT_NOTE header.

Fixed Makefile.
Changed code to comply with style(9).
Some cleanup.
Check all PT_NOTE headers until one that has feature control note has been found.
Updated copyright notices.
Get rid of control features that haven't been implemented yet (they are in review). Get rid of all mentions/examples of it.

emaste updated this revision to Diff 60170.
emaste edited reviewers, added: borako.ozarslan_gmail.com; removed: emaste.

initial updates incorporating kib feedback

This revision was not accepted when it landed; it landed in state Needs Review.Sep 27 2019, 4:28 PM
This revision was automatically updated to reflect the committed changes.