Я хочу прочитать ячейку памяти, не загрязняя кеш. Я работаю на машине X86 Linux. Я попытался использовать инструкцию ассемблера MOVNTDQA:
asm("movntdqa %[source], %[dest] \n\t"
: [dest] "=x" (my_var) : [source] "m" (my_mem[0]) : "memory");
my_mem — это int*, выделенный с помощью new, my_var — это int.
У меня есть две проблемы с этим подходом:
- Код компилируется, но при его запуске появляется ошибка «Недопустимая инструкция». Есть идеи, почему?
- Я не уверен, какой тип памяти выделяется с помощью new. Я бы предположил, что ВБ. Согласно документации, инструкция MOVNTDQA будет работать только с памятью типа USWC. Как узнать, с каким типом памяти я работаю?
Подводя итог, мой вопрос:
Как я могу прочитать ячейку памяти, не загрязняя кеш на машине X86? Мой подход в правильном направлении, и можно ли его исправить?
Спасибо.