diff options
author | alc <alc@FreeBSD.org> | 2004-04-18 06:24:51 +0000 |
---|---|---|
committer | alc <alc@FreeBSD.org> | 2004-04-18 06:24:51 +0000 |
commit | ae325280137656bd4e673f82eab180c65d99d06b (patch) | |
tree | cb36421001abc704bf582a03cefed56fab7ed676 /sys/alpha/include | |
parent | a35fc6d0e44949294546f8cf33461b272b662f13 (diff) | |
download | FreeBSD-src-ae325280137656bd4e673f82eab180c65d99d06b.zip FreeBSD-src-ae325280137656bd4e673f82eab180c65d99d06b.tar.gz |
MFamd64
Simplify the sf_buf implementation. In short, make it a veneer
over the direct virtual-to-physical mapping.
Diffstat (limited to 'sys/alpha/include')
-rw-r--r-- | sys/alpha/include/sf_buf.h | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/sys/alpha/include/sf_buf.h b/sys/alpha/include/sf_buf.h index 8c7d7a6..d000e30 100644 --- a/sys/alpha/include/sf_buf.h +++ b/sys/alpha/include/sf_buf.h @@ -29,29 +29,30 @@ #ifndef _MACHINE_SF_BUF_H_ #define _MACHINE_SF_BUF_H_ -#include <sys/queue.h> - #include <vm/vm.h> #include <vm/vm_param.h> #include <vm/vm_page.h> -struct sf_buf { - SLIST_ENTRY(sf_buf) free_list; /* list of free buffer slots */ - vm_page_t m; /* currently mapped page */ -}; +/* + * On this machine, the only purpose for which sf_buf is used is to implement + * an opaque pointer required by the machine-independent parts of the kernel. + * That pointer references the vm_page that is "mapped" by the sf_buf. The + * actual mapping is provided by the direct virtual-to-physical mapping. + */ +struct sf_buf; static __inline vm_offset_t sf_buf_kva(struct sf_buf *sf) { - return (ALPHA_PHYS_TO_K0SEG(sf->m->phys_addr)); + return (ALPHA_PHYS_TO_K0SEG(VM_PAGE_TO_PHYS((vm_page_t)sf))); } static __inline vm_page_t sf_buf_page(struct sf_buf *sf) { - return (sf->m); + return ((vm_page_t)sf); } #endif /* !_MACHINE_SF_BUF_H_ */ |