2002-02-02 13:14:56 +01:00
|
|
|
/*
|
|
|
|
mtrr.c - Stuff for optimizing memory access
|
|
|
|
Copyrights:
|
|
|
|
2002 - Linux version by Nick Kurshev
|
|
|
|
Licence: GPL
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2002-06-08 00:43:29 +02:00
|
|
|
#include <string.h>
|
2002-02-02 13:14:56 +01:00
|
|
|
#include <errno.h>
|
|
|
|
#include "libdha.h"
|
|
|
|
#include "AsmMacros.h"
|
|
|
|
|
2002-04-28 00:42:27 +02:00
|
|
|
#if defined (__i386__) && defined (__NetBSD__)
|
2002-05-07 23:51:47 +02:00
|
|
|
#include <sys/param.h>
|
|
|
|
#if __NetBSD_Version__ > 105240000
|
2002-04-28 00:42:27 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <machine/mtrr.h>
|
|
|
|
#include <machine/sysarch.h>
|
|
|
|
#endif
|
2002-05-07 23:51:47 +02:00
|
|
|
#endif
|
2002-02-02 13:14:56 +01:00
|
|
|
|
|
|
|
int mtrr_set_type(unsigned base,unsigned size,int type)
|
|
|
|
{
|
|
|
|
#ifdef linux
|
|
|
|
FILE * mtrr_fd;
|
|
|
|
char * stype;
|
|
|
|
switch(type)
|
|
|
|
{
|
|
|
|
case MTRR_TYPE_UNCACHABLE: stype = "uncachable"; break;
|
|
|
|
case MTRR_TYPE_WRCOMB: stype = "write-combining"; break;
|
|
|
|
case MTRR_TYPE_WRTHROUGH: stype = "write-through"; break;
|
|
|
|
case MTRR_TYPE_WRPROT: stype = "write-protect"; break;
|
|
|
|
case MTRR_TYPE_WRBACK: stype = "write-back"; break;
|
|
|
|
default: return EINVAL;
|
|
|
|
}
|
|
|
|
mtrr_fd = fopen("/proc/mtrr","wt");
|
|
|
|
if(mtrr_fd)
|
|
|
|
{
|
2002-02-03 10:29:35 +01:00
|
|
|
char sout[256];
|
|
|
|
unsigned wr_len;
|
|
|
|
sprintf(sout,"base=0x%08X size=0x%08X type=%s\n",base,size,stype);
|
|
|
|
wr_len = fprintf(mtrr_fd,sout);
|
|
|
|
/*printf("MTRR: %s\n",sout);*/
|
2002-02-02 13:14:56 +01:00
|
|
|
fclose(mtrr_fd);
|
2002-02-03 10:29:35 +01:00
|
|
|
return wr_len == strlen(sout) ? 0 : EPERM;
|
2002-02-02 13:14:56 +01:00
|
|
|
}
|
|
|
|
return ENOSYS;
|
2005-09-03 21:17:28 +02:00
|
|
|
#elif defined (__i386__ ) && defined (__NetBSD__) && __NetBSD_Version__ > 105240000
|
2002-04-28 00:42:27 +02:00
|
|
|
struct mtrr *mtrrp;
|
|
|
|
int n;
|
|
|
|
|
|
|
|
mtrrp = malloc(sizeof (struct mtrr));
|
|
|
|
mtrrp->base = base;
|
|
|
|
mtrrp->len = size;
|
|
|
|
mtrrp->type = type;
|
|
|
|
mtrrp->flags = MTRR_VALID | MTRR_PRIVATE;
|
|
|
|
n = 1;
|
|
|
|
|
|
|
|
if (i386_set_mtrr(mtrrp, &n) < 0) {
|
|
|
|
free(mtrrp);
|
|
|
|
return errno;
|
|
|
|
}
|
|
|
|
free(mtrrp);
|
|
|
|
return 0;
|
2002-05-07 23:51:47 +02:00
|
|
|
#else
|
|
|
|
/* NetBSD prior to 1.5Y doesn't have MTRR support */
|
|
|
|
return ENOSYS;
|
|
|
|
#endif
|
2002-02-02 13:14:56 +01:00
|
|
|
}
|