kernelnewbies.kernelnewbies.org archive mirror
 help / color / mirror / Atom feed
* Mapping IO memory read-write
@ 2016-01-12 23:10 Jethro Beekman
  2016-01-13 14:34 ` Kenneth Adam Miller
  0 siblings, 1 reply; 3+ messages in thread
From: Jethro Beekman @ 2016-01-12 23:10 UTC (permalink / raw)
  To: kernelnewbies

I'm writing a device driver for a memory-mapped device on x86-64. I'm mapping
the device in the kernel using ioremap_cache(). My file_operations.mmap function
is as follows:

static int dev_mmap(struct file *filep, struct vm_area_struct *vma) {
	vma->vm_page_prot.pgprot|=_PAGE_BIT_RW;
	return vm_iomap_memory(vma,START,LEN);
}

The user process calls mmap(..,PROT_READ|PROT_WRITE|PROT_EXEC,..). The mapping
in /proc/[pid]/maps shows the write bit. However, when looking at the actual
page table entry does not have the RW bit set. For example:

virtual address = 0000_0001_8000_0000
cr3 = 0000_0000_700a_e000
phys:0000_0000_700a_e000 = 0000_0000_7e05_5067 (P|RW|US|A|D)
phys:0000_0000_7e05_5030 = 0000_0001_66e2_9067 (P|RW|US|A|D)
phys:0000_0001_66e2_9000 = 0000_0001_69db_3067 (P|RW|US|A|D)
phys:0000_0001_69db_3000 = 0000_0000_8020_0225 (P|US|A|SOFTW1)

Am I doing something wrong?

Jethro

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2016-01-13 18:06 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-01-12 23:10 Mapping IO memory read-write Jethro Beekman
2016-01-13 14:34 ` Kenneth Adam Miller
2016-01-13 18:06   ` Jethro Beekman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).