diff options
author | Marcin Wojtas <mw@FreeBSD.org> | 2021-04-06 15:00:05 +0000 |
---|---|---|
committer | Marcin Wojtas <mw@FreeBSD.org> | 2021-04-06 15:00:05 +0000 |
commit | 1c1ead9b94a1a731646327ec3b09e8f3acd577b8 (patch) | |
tree | 278cf0fd87e5be29d243143dc14b9dfb7e3c3c93 | |
parent | 57dbb3c25936f0d61fef152eb224ca86a73af0e9 (diff) | |
download | src-1c1ead9b94a1a731646327ec3b09e8f3acd577b8.tar.gz src-1c1ead9b94a1a731646327ec3b09e8f3acd577b8.zip |
pciconf: Use VM_MEMATTR_DEVICE on supported architectures
Some architectures - armv7, armv8 and riscv use VM_MEMATTR_DEVICE
when mapping device registers in kernel. Do the same in pciconf.
On armada8k SoC all reads from BARs mapped with hitherto attribute
(VM_MEMATTR_UNCACHEABLE) return 0xff's.
Submitted by: Kornel Duleba <mindal@semihalf.com>
Reviewed by: kib
Obtained from: Semihalf
Sponsored by: Marvell
Differential revision: https://reviews.freebsd.org/D29603
-rw-r--r-- | usr.sbin/pciconf/pciconf.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/usr.sbin/pciconf/pciconf.c b/usr.sbin/pciconf/pciconf.c index 817de6ec09ed..6b54687d7c79 100644 --- a/usr.sbin/pciconf/pciconf.c +++ b/usr.sbin/pciconf/pciconf.c @@ -1126,7 +1126,11 @@ dump_bar(const char *name, const char *reg, const char *bar_start, if (*reg == '\0' || *el != '\0') errx(1, "Invalid bar specification %s", reg); pbm.pbm_flags = 0; - pbm.pbm_memattr = VM_MEMATTR_UNCACHEABLE; /* XXX */ +#ifdef VM_MEMATTR_DEVICE + pbm.pbm_memattr = VM_MEMATTR_DEVICE; +#else + pbm.pbm_memattr = VM_MEMATTR_UNCACHEABLE; +#endif fd = open(_PATH_DEVPCI, O_RDWR, 0); if (fd < 0) |