annotate libdha/mtrr.c @ 6069:8e88e92fe331

Initial support for dxr2. Based on patch from Tobias Diedrich <ranma@gmx.at>.
author albeu
date Mon, 13 May 2002 13:15:40 +0000
parents 5f020e2dc745
children e9bd97d5c5cc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
1 /*
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
2 mtrr.c - Stuff for optimizing memory access
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
3 Copyrights:
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
4 2002 - Linux version by Nick Kurshev
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
5 Licence: GPL
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
6 */
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
7
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
8 #include "config.h"
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
9
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
10 #include <stdio.h>
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
11 #include <errno.h>
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
12 #include "libdha.h"
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
13 #include "AsmMacros.h"
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
14
5872
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
15 #if defined (__i386__) && defined (__NetBSD__)
6011
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
16 #include <sys/param.h>
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
17 #if __NetBSD_Version__ > 105240000
5872
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
18 #include <stdint.h>
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
19 #include <stdlib.h>
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
20 #include <machine/mtrr.h>
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
21 #include <machine/sysarch.h>
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
22 #endif
6011
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
23 #endif
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
24
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
25 #if defined( __i386__ )
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
26 int mtrr_set_type(unsigned base,unsigned size,int type)
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
27 {
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
28 #ifdef linux
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
29 FILE * mtrr_fd;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
30 char * stype;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
31 switch(type)
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
32 {
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
33 case MTRR_TYPE_UNCACHABLE: stype = "uncachable"; break;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
34 case MTRR_TYPE_WRCOMB: stype = "write-combining"; break;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
35 case MTRR_TYPE_WRTHROUGH: stype = "write-through"; break;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
36 case MTRR_TYPE_WRPROT: stype = "write-protect"; break;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
37 case MTRR_TYPE_WRBACK: stype = "write-back"; break;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
38 default: return EINVAL;
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
39 }
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
40 mtrr_fd = fopen("/proc/mtrr","wt");
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
41 if(mtrr_fd)
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
42 {
4495
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
43 char sout[256];
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
44 unsigned wr_len;
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
45 sprintf(sout,"base=0x%08X size=0x%08X type=%s\n",base,size,stype);
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
46 wr_len = fprintf(mtrr_fd,sout);
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
47 /*printf("MTRR: %s\n",sout);*/
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
48 fclose(mtrr_fd);
4495
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
49 return wr_len == strlen(sout) ? 0 : EPERM;
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
50 }
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
51 return ENOSYS;
5872
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
52 #elif defined (__NetBSD__)
6011
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
53 #if __NetBSD_Version__ > 105240000
5872
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
54 struct mtrr *mtrrp;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
55 int n;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
56
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
57 mtrrp = malloc(sizeof (struct mtrr));
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
58 mtrrp->base = base;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
59 mtrrp->len = size;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
60 mtrrp->type = type;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
61 mtrrp->flags = MTRR_VALID | MTRR_PRIVATE;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
62 n = 1;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
63
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
64 if (i386_set_mtrr(mtrrp, &n) < 0) {
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
65 free(mtrrp);
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
66 return errno;
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
67 }
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
68 free(mtrrp);
02576893af2a OpenBSD, NetBSD portability patches by
arpi
parents: 4510
diff changeset
69 return 0;
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
70 #else
6011
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
71 /* NetBSD prior to 1.5Y doesn't have MTRR support */
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
72 return ENOSYS;
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
73 #endif
5f020e2dc745 patchs for NetBSD by Bernd Ernesti <mplayer@lists.veego.de>:
pl
parents: 5872
diff changeset
74 #else
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
75 #warning Please port MTRR stuff!!!
4510
1f0282f9a723 fix typo
nexus
parents: 4495
diff changeset
76 return ENOSYS;
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
77 #endif
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
78 }
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
79 #else
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
80 int mtrr_set_type(unsigned base,unsigned size,int type)
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
81 {
4495
0e4cffa369e4 Be more precise
nick
parents: 4476
diff changeset
82 return ENOSYS;
4476
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
83 }
0d9a096cfd46 MTRR configuring
nick
parents:
diff changeset
84 #endif