> Dear All,
> How can do to disable the L1 cache in linux ?
> Are there some commands or directives to disable it ??
I wrote this some times ago when playing with caches. Compile cctlmod.c as
a module, insert it to kernel, and use con and coff to enable and disable
caches.
Note that the code is quite old, maybe it doesn't work with 2.4 kernels,
and I don't want support it. If it doesn't work, fix it yourself.
Mikulas
#include <errno.h>
#include <asm/unistd.h>
#define __NR_disable_cache 250
#define __NR_enable_cache 251
#define __NR_disable_cache_wt 252
#define __NR_disable_page_cache 253
#define __NR_enable_page_cache 254
_syscall0(int, disable_cache)
_syscall0(int, enable_cache)
_syscall0(int, disable_cache_wt)
_syscall1(int, disable_page_cache, void *, page)
_syscall1(int, enable_page_cache, void *, page)
#define MODULE
#define __KERNEL__
#include <linux/autoconf.h>
#include <linux/module.h>
#include <linux/modversions.h>
#include <linux/mm.h>
#include <linux/sched.h>
#include <asm/pgtable.h>
extern void *sys_call_table[];
flush_t()
{
__asm__ __volatile__ (
"movl %%cr3, %%eax\n\t"
"movl %%eax, %%cr3\n\t"
:::"ax", "cc");
}
disable_cache()
{
__asm__ __volatile__ (
"cli\n\t"
"movl %%cr0, %%eax\n\t"
"orl $0x60000000, %%eax\n\t"
"movl %%eax, %%cr0\n\t"
"wbinvd\n\t"
"sti\n\t"
:::"ax", "cc");
return 0;
}
enable_cache()
{
__asm__ __volatile__ (
"cli\n\t"
"movl %%cr0, %%eax\n\t"
"andl $0x9fffffff, %%eax\n\t"
"movl %%eax, %%cr0\n\t"
"wbinvd\n\t"
"sti\n\t"
:::"ax", "cc");
return 0;
}
disable_cache_wt()
{
__asm__ __volatile__ (
"cli\n\t"
"movl %%cr0, %%eax\n\t"
"andl $0xdfffffff, %%eax\n\t"
"orl $0x40000000, %%eax\n\t"
"movl %%eax, %%cr0\n\t"
"wbinvd\n\t"
"sti\n\t"
:::"ax", "cc");
return 0;
}
disable_page_cache(unsigned long pg)
{
pte_t *pte = pte_offset(pmd_offset(pgd_offset(current->mm, pg), pg), pg);
*(unsigned *)pte |= 0x18;
flush_t();
return 0;
}
enable_page_cache(unsigned long pg)
{
pte_t *pte = pte_offset(pmd_offset(pgd_offset(current->mm, pg), pg), pg);
*(unsigned *)pte &= ~0x18;
flush_t();
return 0;
}
init_module()
{
sys_call_table[250] = disable_cache;
sys_call_table[251] = enable_cache;
sys_call_table[252] = disable_cache_wt;
sys_call_table[253] = disable_page_cache;
sys_call_table[254] = enable_page_cache;
return 0;
}
cleanup_module()
{
sys_call_table[250] = sys_call_table[251] = sys_call_table[252] = 0;
sys_call_table[253] = sys_call_table[254] = 0;
}
#include "cctl.h"
main()
{
if (enable_cache()) perror("enable_cache"), exit(1);
return 0;
}
#include "cctl.h"
main()
{
if (disable_cache()) perror("disable_cache"), exit(1);
return 0;
}