Author: fireball
Date: Wed Feb 16 11:49:51 2011
New Revision: 50730

URL: http://svn.reactos.org/svn/reactos?rev=50730&view=rev
Log:
[RTL/DPH]
- Use better names for validation information flags based on application 
verifier messages.
- Implement a simple RtlpDphReportCorruptedBlock routine which just prints the 
problem description for now, without any additional info.

Modified:
    trunk/reactos/lib/rtl/heappage.c

Modified: trunk/reactos/lib/rtl/heappage.c
URL: 
http://svn.reactos.org/svn/reactos/trunk/reactos/lib/rtl/heappage.c?rev=50730&r1=50729&r2=50730&view=diff
==============================================================================
--- trunk/reactos/lib/rtl/heappage.c [iso-8859-1] (original)
+++ trunk/reactos/lib/rtl/heappage.c [iso-8859-1] Wed Feb 16 11:49:51 2011
@@ -150,10 +150,16 @@
 #define DPH_FILL_BLOCK_END     0xD0
 
 /* Validation info flags */
-#define DPH_VALINFO_BAD_START_STAMP 0x01
-#define DPH_VALINFO_BAD_END_STAMP   0x02
-#define DPH_VALINFO_BAD_POINTER     0x04
-#define DPH_VALINFO_BAD_END_FILL    0x10
+#define DPH_VALINFO_BAD_START_STAMP      0x01
+#define DPH_VALINFO_BAD_END_STAMP        0x02
+#define DPH_VALINFO_BAD_POINTER          0x04
+#define DPH_VALINFO_BAD_PREFIX_PATTERN   0x08
+#define DPH_VALINFO_BAD_SUFFIX_PATTERN   0x10
+#define DPH_VALINFO_EXCEPTION            0x20
+#define DPH_VALINFO_1                    0x40
+#define DPH_VALINFO_BAD_INFIX_PATTERN    0x80
+#define DPH_VALINFO_ALREADY_FREED        0x100
+#define DPH_VALINFO_CORRUPTED_AFTER_FREE 0x200
 
 /* Signatures */
 #define DPH_SIGNATURE 0xFFEEDDCC
@@ -908,7 +914,54 @@
                             PVOID Block,
                             ULONG ValidationInfo)
 {
-    UNIMPLEMENTED;
+    //RtlpDphGetBlockSizeFromCorruptedBlock();
+
+    if (ValidationInfo & DPH_VALINFO_CORRUPTED_AFTER_FREE)
+    {
+        DPRINT1("block corrupted after having been freed\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_ALREADY_FREED)
+    {
+        DPRINT1("block already freed\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_INFIX_PATTERN)
+    {
+        DPRINT1("corrupted infix pattern for freed block\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_POINTER)
+    {
+        DPRINT1("corrupted heap pointer or using wrong heap\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_SUFFIX_PATTERN)
+    {
+        DPRINT1("corrupted suffix pattern\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_PREFIX_PATTERN)
+    {
+        DPRINT1("corrupted prefix pattern\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_START_STAMP)
+    {
+        DPRINT1("corrupted start stamp\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_BAD_END_STAMP)
+    {
+        DPRINT1("corrupted end stamp\n");
+    }
+
+    if (ValidationInfo & DPH_VALINFO_EXCEPTION)
+    {
+        DPRINT1("exception raised while verifying block\n");
+    }
+
+    DPRINT1("Corrupted heap block %p\n", Block);
 }
 
 BOOLEAN NTAPI
@@ -964,7 +1017,7 @@
         {
             if (*Byte != DPH_FILL_BLOCK_END)
             {
-                *ValidationInformation |= DPH_VALINFO_BAD_END_FILL;
+                *ValidationInformation |= DPH_VALINFO_BAD_SUFFIX_PATTERN;
                 SomethingWrong = TRUE;
                 break;
             }


Reply via email to