mirror of
https://github.com/apache/nuttx.git
synced 2026-06-04 14:53:47 +08:00
mm/kasan: fix kasan false positives
When using memset via __asan_storeN check, not checking if all memory is accessible Signed-off-by: yinshengkai <yinshengkai@xiaomi.com>
This commit is contained in:
+35
-1
@@ -202,9 +202,43 @@ bool kasan_is_poisoned(FAR const void *addr, size_t size)
|
|||||||
{
|
{
|
||||||
FAR uintptr_t *p;
|
FAR uintptr_t *p;
|
||||||
unsigned int bit;
|
unsigned int bit;
|
||||||
|
unsigned int nbit;
|
||||||
|
uintptr_t mask;
|
||||||
|
|
||||||
p = kasan_mem_to_shadow(addr, size, &bit);
|
p = kasan_mem_to_shadow(addr, size, &bit);
|
||||||
return p && ((*p >> bit) & 1);
|
if (p == NULL)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
nbit = KASAN_BITS_PER_WORD - bit % KASAN_BITS_PER_WORD;
|
||||||
|
mask = KASAN_FIRST_WORD_MASK(bit);
|
||||||
|
size /= KASAN_SHADOW_SCALE;
|
||||||
|
|
||||||
|
while (size >= nbit)
|
||||||
|
{
|
||||||
|
if ((*p++ & mask) != 0)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bit += nbit;
|
||||||
|
size -= nbit;
|
||||||
|
|
||||||
|
nbit = KASAN_BITS_PER_WORD;
|
||||||
|
mask = UINTPTR_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (size)
|
||||||
|
{
|
||||||
|
mask &= KASAN_LAST_WORD_MASK(bit + size);
|
||||||
|
if ((*p & mask) != 0)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void kasan_poison(FAR const void *addr, size_t size)
|
void kasan_poison(FAR const void *addr, size_t size)
|
||||||
|
|||||||
Reference in New Issue
Block a user