diff options
| -rw-r--r-- | arch/x86/mm/kmemcheck/kmemcheck.c | 2 | ||||
| -rw-r--r-- | arch/x86/mm/kmemcheck/shadow.c | 16 | ||||
| -rw-r--r-- | arch/x86/mm/kmemcheck/shadow.h | 2 |
3 files changed, 17 insertions, 3 deletions
diff --git a/arch/x86/mm/kmemcheck/kmemcheck.c b/arch/x86/mm/kmemcheck/kmemcheck.c index 8cc183344140..b3b531a4f8e5 100644 --- a/arch/x86/mm/kmemcheck/kmemcheck.c +++ b/arch/x86/mm/kmemcheck/kmemcheck.c | |||
| @@ -337,7 +337,7 @@ bool kmemcheck_is_obj_initialized(unsigned long addr, size_t size) | |||
| 337 | if (!shadow) | 337 | if (!shadow) |
| 338 | return true; | 338 | return true; |
| 339 | 339 | ||
| 340 | status = kmemcheck_shadow_test(shadow, size); | 340 | status = kmemcheck_shadow_test_all(shadow, size); |
| 341 | 341 | ||
| 342 | return status == KMEMCHECK_SHADOW_INITIALIZED; | 342 | return status == KMEMCHECK_SHADOW_INITIALIZED; |
| 343 | } | 343 | } |
diff --git a/arch/x86/mm/kmemcheck/shadow.c b/arch/x86/mm/kmemcheck/shadow.c index 3f66b82076a3..aec124214d97 100644 --- a/arch/x86/mm/kmemcheck/shadow.c +++ b/arch/x86/mm/kmemcheck/shadow.c | |||
| @@ -125,12 +125,12 @@ void kmemcheck_mark_initialized_pages(struct page *p, unsigned int n) | |||
| 125 | 125 | ||
| 126 | enum kmemcheck_shadow kmemcheck_shadow_test(void *shadow, unsigned int size) | 126 | enum kmemcheck_shadow kmemcheck_shadow_test(void *shadow, unsigned int size) |
| 127 | { | 127 | { |
| 128 | #ifdef CONFIG_KMEMCHECK_PARTIAL_OK | ||
| 128 | uint8_t *x; | 129 | uint8_t *x; |
| 129 | unsigned int i; | 130 | unsigned int i; |
| 130 | 131 | ||
| 131 | x = shadow; | 132 | x = shadow; |
| 132 | 133 | ||
| 133 | #ifdef CONFIG_KMEMCHECK_PARTIAL_OK | ||
| 134 | /* | 134 | /* |
| 135 | * Make sure _some_ bytes are initialized. Gcc frequently generates | 135 | * Make sure _some_ bytes are initialized. Gcc frequently generates |
| 136 | * code to access neighboring bytes. | 136 | * code to access neighboring bytes. |
| @@ -139,13 +139,25 @@ enum kmemcheck_shadow kmemcheck_shadow_test(void *shadow, unsigned int size) | |||
| 139 | if (x[i] == KMEMCHECK_SHADOW_INITIALIZED) | 139 | if (x[i] == KMEMCHECK_SHADOW_INITIALIZED) |
| 140 | return x[i]; | 140 | return x[i]; |
| 141 | } | 141 | } |
| 142 | |||
| 143 | return x[0]; | ||
| 142 | #else | 144 | #else |
| 145 | return kmemcheck_shadow_test_all(shadow, size); | ||
| 146 | #endif | ||
| 147 | } | ||
| 148 | |||
| 149 | enum kmemcheck_shadow kmemcheck_shadow_test_all(void *shadow, unsigned int size) | ||
| 150 | { | ||
| 151 | uint8_t *x; | ||
| 152 | unsigned int i; | ||
| 153 | |||
| 154 | x = shadow; | ||
| 155 | |||
| 143 | /* All bytes must be initialized. */ | 156 | /* All bytes must be initialized. */ |
| 144 | for (i = 0; i < size; ++i) { | 157 | for (i = 0; i < size; ++i) { |
| 145 | if (x[i] != KMEMCHECK_SHADOW_INITIALIZED) | 158 | if (x[i] != KMEMCHECK_SHADOW_INITIALIZED) |
| 146 | return x[i]; | 159 | return x[i]; |
| 147 | } | 160 | } |
| 148 | #endif | ||
| 149 | 161 | ||
| 150 | return x[0]; | 162 | return x[0]; |
| 151 | } | 163 | } |
diff --git a/arch/x86/mm/kmemcheck/shadow.h b/arch/x86/mm/kmemcheck/shadow.h index af46d9ab9d86..ff0b2f70fbcb 100644 --- a/arch/x86/mm/kmemcheck/shadow.h +++ b/arch/x86/mm/kmemcheck/shadow.h | |||
| @@ -11,6 +11,8 @@ enum kmemcheck_shadow { | |||
| 11 | void *kmemcheck_shadow_lookup(unsigned long address); | 11 | void *kmemcheck_shadow_lookup(unsigned long address); |
| 12 | 12 | ||
| 13 | enum kmemcheck_shadow kmemcheck_shadow_test(void *shadow, unsigned int size); | 13 | enum kmemcheck_shadow kmemcheck_shadow_test(void *shadow, unsigned int size); |
| 14 | enum kmemcheck_shadow kmemcheck_shadow_test_all(void *shadow, | ||
| 15 | unsigned int size); | ||
| 14 | void kmemcheck_shadow_set(void *shadow, unsigned int size); | 16 | void kmemcheck_shadow_set(void *shadow, unsigned int size); |
| 15 | 17 | ||
| 16 | #endif | 18 | #endif |
