From 3d3263476ea3c9efbc1896de413e89bb3ca6ac2c Mon Sep 17 00:00:00 2001 From: dfr Date: Sun, 28 May 2000 15:49:55 +0000 Subject: Add a new pmap entry point, pmap_enter_temporary() to be used during dumps to create temporary page mappings. This replaces the use of CADDR1 which is fairly x86 specific. Reviewed by: dillon --- sys/cam/scsi/scsi_da.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'sys/cam') diff --git a/sys/cam/scsi/scsi_da.c b/sys/cam/scsi/scsi_da.c index f7fdd55..f41c038 100644 --- a/sys/cam/scsi/scsi_da.c +++ b/sys/cam/scsi/scsi_da.c @@ -631,11 +631,14 @@ dadump(dev_t dev) blkcnt = howmany(PAGE_SIZE, secsize); while (num > 0) { + vm_offset_t va; if (is_physical_memory(addr)) { - pmap_kenter((vm_offset_t)CADDR1, trunc_page(addr)); + va = pmap_enter_temporary(trunc_page(addr), + VM_PROT_READ); } else { - pmap_kenter((vm_offset_t)CADDR1, trunc_page(0)); + va = pmap_enter_temporary(trunc_page(0), + VM_PROT_READ); } xpt_setup_ccb(&csio.ccb_h, periph->path, /*priority*/1); @@ -649,7 +652,7 @@ dadump(dev_t dev) /*minimum_cmd_size*/ softc->minimum_cmd_size, blknum, blkcnt, - /*data_ptr*/CADDR1, + /*data_ptr*/(u_int8_t *) va, /*dxfer_len*/blkcnt * secsize, /*sense_len*/SSD_FULL_SIZE, DA_DEFAULT_TIMEOUT * 1000); -- cgit v1.1