[PATCH] Custom wrappers for DFSanitizing sprintf & snprintf
    Peter Collingbourne 
    peter at pcc.me.uk
       
    Wed Oct  1 13:42:10 PDT 2014
    
    
  
> Note that internal_vsnprintf does not implement the full spec of vsnprintf
Looks like a naming conflict -- the code does end up calling the libc vsnprintf. I've asked for the name to be changed to avoid this confusion.
================
Comment at: lib/dfsan/dfsan_custom.cc:878
@@ +877,3 @@
+// input.
+static int internal_snprintf(char *str, size_t off, bool has_size, size_t size,
+                             const char *format, size_t format_size, ...) {
----------------
It is confusing to give this function the same name as an existing function in `sanitizer_common`.
================
Comment at: lib/dfsan/dfsan_custom.cc:909
@@ +908,3 @@
+// propagate labels more precisely.
+static int internal_vsnprintf(char *str, bool has_size, size_t size,
+                              const char *format, va_list ap) {
----------------
Likewise, this should probably have a different name.
================
Comment at: lib/dfsan/dfsan_custom.cc:1101
@@ +1100,3 @@
+
+  dfsan_label *ret_label_ptr = (dfsan_label *) va_arg(ap, dfsan_label_va *);
+  *ret_label_ptr = 0;
----------------
This can just be `va_arg(ap, dfsan_label *)` as pointer types are not affected by default argument promotion.
================
Comment at: test/dfsan/custom.c:777
@@ -776,1 +776,3 @@
 
+void test_sprintf() {
+  char buf[2048];
----------------
Please add a test for each occurrence of the `PRINTF` macro in the implementation.
http://reviews.llvm.org/D5561
    
    
More information about the llvm-commits
mailing list