VM: Add PTF_READ page table flag
This commit is contained in:
parent
fc9b3f9bdd
commit
7ca1ce7968
3 changed files with 7 additions and 3 deletions
|
@ -10,6 +10,7 @@ i386/vm.h
|
||||||
/* i386 paging constants */
|
/* i386 paging constants */
|
||||||
#define I386_VM_PRESENT 0x001 /* Page is present */
|
#define I386_VM_PRESENT 0x001 /* Page is present */
|
||||||
#define I386_VM_WRITE 0x002 /* Read/write access allowed */
|
#define I386_VM_WRITE 0x002 /* Read/write access allowed */
|
||||||
|
#define I386_VM_READ 0x000 /* Read access only */
|
||||||
#define I386_VM_USER 0x004 /* User access allowed */
|
#define I386_VM_USER 0x004 /* User access allowed */
|
||||||
#define I386_VM_PWT 0x008 /* Write through */
|
#define I386_VM_PWT 0x008 /* Write through */
|
||||||
#define I386_VM_PCD 0x010 /* Cache disable */
|
#define I386_VM_PCD 0x010 /* Cache disable */
|
||||||
|
|
|
@ -26,6 +26,7 @@ typedef struct {
|
||||||
|
|
||||||
/* Mapping flags. */
|
/* Mapping flags. */
|
||||||
#define PTF_WRITE I386_VM_WRITE
|
#define PTF_WRITE I386_VM_WRITE
|
||||||
|
#define PTF_READ I386_VM_READ
|
||||||
#define PTF_PRESENT I386_VM_PRESENT
|
#define PTF_PRESENT I386_VM_PRESENT
|
||||||
#define PTF_USER I386_VM_USER
|
#define PTF_USER I386_VM_USER
|
||||||
#define PTF_GLOBAL I386_VM_GLOBAL
|
#define PTF_GLOBAL I386_VM_GLOBAL
|
||||||
|
@ -35,7 +36,7 @@ typedef struct {
|
||||||
/* For arch-specific PT routines to check if no bits outside
|
/* For arch-specific PT routines to check if no bits outside
|
||||||
* the regular flags are set.
|
* the regular flags are set.
|
||||||
*/
|
*/
|
||||||
#define PTF_ALLFLAGS (PTF_WRITE|PTF_PRESENT|PTF_USER|PTF_GLOBAL|PTF_NOCACHE)
|
#define PTF_ALLFLAGS (PTF_READ|PTF_WRITE|PTF_PRESENT|PTF_USER|PTF_GLOBAL|PTF_NOCACHE)
|
||||||
|
|
||||||
#if SANITYCHECKS
|
#if SANITYCHECKS
|
||||||
#define PT_SANE(p) { pt_sanitycheck((p), __FILE__, __LINE__); }
|
#define PT_SANE(p) { pt_sanitycheck((p), __FILE__, __LINE__); }
|
||||||
|
|
|
@ -196,7 +196,7 @@ static int map_sanitycheck_pt(struct vmproc *vmp,
|
||||||
if(WRITABLE(vr, pb))
|
if(WRITABLE(vr, pb))
|
||||||
rw = PTF_WRITE;
|
rw = PTF_WRITE;
|
||||||
else
|
else
|
||||||
rw = 0;
|
rw = PTF_READ;
|
||||||
|
|
||||||
r = pt_writemap(vmp, &vmp->vm_pt, vr->vaddr + pr->offset,
|
r = pt_writemap(vmp, &vmp->vm_pt, vr->vaddr + pr->offset,
|
||||||
pb->phys, pb->length, PTF_PRESENT | PTF_USER | rw, WMF_VERIFY);
|
pb->phys, pb->length, PTF_PRESENT | PTF_USER | rw, WMF_VERIFY);
|
||||||
|
@ -375,7 +375,7 @@ static int map_ph_writept(struct vmproc *vmp, struct vir_region *vr,
|
||||||
if(WRITABLE(vr, pb))
|
if(WRITABLE(vr, pb))
|
||||||
rw = PTF_WRITE;
|
rw = PTF_WRITE;
|
||||||
else
|
else
|
||||||
rw = 0;
|
rw = PTF_READ;
|
||||||
|
|
||||||
if(pt_writemap(vmp, &vmp->vm_pt, vr->vaddr + pr->offset,
|
if(pt_writemap(vmp, &vmp->vm_pt, vr->vaddr + pr->offset,
|
||||||
pb->phys, pb->length, PTF_PRESENT | PTF_USER | rw,
|
pb->phys, pb->length, PTF_PRESENT | PTF_USER | rw,
|
||||||
|
@ -2112,6 +2112,8 @@ static int do_map_memory(struct vmproc *vms, struct vmproc *vmd,
|
||||||
*/
|
*/
|
||||||
if(flag > 0)
|
if(flag > 0)
|
||||||
pt_flag |= PTF_WRITE;
|
pt_flag |= PTF_WRITE;
|
||||||
|
else
|
||||||
|
pt_flag |= PTF_READ;
|
||||||
|
|
||||||
/* Map phys blocks in the source process to the destination process. */
|
/* Map phys blocks in the source process to the destination process. */
|
||||||
end = offset_d + length;
|
end = offset_d + length;
|
||||||
|
|
Loading…
Reference in a new issue