Actions
Bug #309
closedMitigate dangerous macros: util-mem.h, decode.h, suricata.h, stream-tcp.c
Status:
Closed
Priority:
Normal
Assignee:
-
Target version:
-
Affected Versions:
Effort:
Difficulty:
Label:
Description
The attached patches address several unsafe or broken macros in 1.1beta2 (rev 2f2eb72)
- SCStrdup with -DDBG_MEM_ALLOC broken/unsafe: references a "len" variable not in private scope
- Several macro replacement lists are not parenthesized
- Many, many macro parameters are not parenthesized when referenced
- Some statement-style macros were not do/while(0) idioms, and so could not be used anywhere a statement could
No. 2 is of course a problem when we
#define FOO default_packet_size - 1and later compute
FOO * 5.
No. 3 are especially dangerous breakages waiting to happen, and are what the CERT C Secure Coding Standard calls PRE01-C. Example:
#define SCCalloc(nm, a) \ ... \ global_mem += a*nm \ <-- wrong for SCCalloc(1024, 2 + 0) ... \
And similarly for pointer dereferences in macros, etc. In all, these patches bring some macros in line with the better-written macros in Suricata.
Files
Updated by Mike Pomraning over 13 years ago
- File suricata-1.1beta2-fcac26e-revised-macro-parens.patch suricata-1.1beta2-fcac26e-revised-macro-parens.patch added
Updated patch for safe macros: decode.h, defrag.c, flow.c, queue.h, stream-tcp.c, suricata.h, tm-threads.c, util-cuda.c, util-mem.h, util-mpm-ac-gfbs.c, util-mpm-ac.c, util-mpm-b2g-cuda.c
Updated by Victor Julien about 13 years ago
Thanks Mike. Can you submit the patch as a git patch?
Updated by Mike Pomraning about 13 years ago
- File 0001-Safer-macro-parenthesization-and-do-while-use.patch 0001-Safer-macro-parenthesization-and-do-while-use.patch added
Re-attaching updated patch.
Updated by Victor Julien about 13 years ago
- Status changed from New to Closed
- % Done changed from 0 to 100
Applied, thanks Mike!
Actions