diff options
author | imp <imp@FreeBSD.org> | 2016-01-16 05:47:34 +0000 |
---|---|---|
committer | imp <imp@FreeBSD.org> | 2016-01-16 05:47:34 +0000 |
commit | 6d123b64fddbb202e7e3ab097ed7683bf26ac30a (patch) | |
tree | 864a9897087c379da42ab13053680b0a44b6c4d0 | |
parent | a097ef8c36a4258ae5739c3a6a01ae02d06b039f (diff) | |
download | FreeBSD-src-6d123b64fddbb202e7e3ab097ed7683bf26ac30a.zip FreeBSD-src-6d123b64fddbb202e7e3ab097ed7683bf26ac30a.tar.gz |
We don't need at91_bs_tag. arm_base_bs_tag works now that we have
better dynamic device mapping that didn't exit when we started this
port. Remove it, since everything works w/o it.
-rw-r--r-- | sys/arm/at91/at91.c | 163 | ||||
-rw-r--r-- | sys/arm/at91/at91_common.c | 2 | ||||
-rw-r--r-- | sys/arm/at91/at91_machdep.c | 2 | ||||
-rw-r--r-- | sys/arm/at91/files.at91 | 3 | ||||
-rw-r--r-- | sys/arm/at91/uart_cpu_at91usart.c | 5 |
5 files changed, 8 insertions, 167 deletions
diff --git a/sys/arm/at91/at91.c b/sys/arm/at91/at91.c index 209a119..8b94dc6 100644 --- a/sys/arm/at91/at91.c +++ b/sys/arm/at91/at91.c @@ -54,54 +54,6 @@ __FBSDID("$FreeBSD$"); uint32_t at91_master_clock; -static int -at91_bs_map(bus_space_tag_t tag, bus_addr_t bpa, bus_size_t size, int flags, - bus_space_handle_t *bshp) -{ - vm_paddr_t pa, endpa; - - pa = trunc_page(bpa); - if (pa >= AT91_PA_BASE + 0xff00000) { - *bshp = bpa - AT91_PA_BASE + AT91_BASE; - return (0); - } - if (pa >= AT91_BASE + 0xff00000) { - *bshp = bpa; - return (0); - } - endpa = round_page(bpa + size); - - *bshp = (vm_offset_t)pmap_mapdev(pa, endpa - pa) + (bpa - pa); - - return (0); -} - -static void -at91_bs_unmap(bus_space_tag_t tag, bus_space_handle_t h, bus_size_t size) -{ - vm_offset_t va; - - va = (vm_offset_t)h; - if (va >= AT91_BASE && va <= AT91_BASE + 0xff00000) - return; - pmap_unmapdev(va, size); -} - -static int -at91_bs_subregion(bus_space_tag_t tag, bus_space_handle_t bsh, bus_size_t offset, - bus_size_t size, bus_space_handle_t *nbshp) -{ - - *nbshp = bsh + offset; - return (0); -} - -static void -at91_barrier(bus_space_tag_t tag, bus_space_handle_t bsh, bus_size_t size, bus_size_t b, - int a) -{ -} - struct arm32_dma_range * bus_dma_get_range(void) { @@ -115,115 +67,6 @@ bus_dma_get_range_nb(void) return (0); } -bs_protos(generic); - -struct bus_space at91_bs_tag = { - /* privdata is whatever the implementer wants; unused in base tag */ - .bs_privdata = NULL, - - /* mapping/unmapping */ - .bs_map = at91_bs_map, - .bs_unmap = at91_bs_unmap, - .bs_subregion = at91_bs_subregion, - - /* allocation/deallocation */ - .bs_alloc = generic_bs_alloc, - .bs_free = generic_bs_free, - - /* barrier */ - .bs_barrier = at91_barrier, - - /* read (single) */ - .bs_r_1 = NULL, /* Use inline code in bus.h */ - .bs_r_2 = NULL, /* Use inline code in bus.h */ - .bs_r_4 = NULL, /* Use inline code in bus.h */ - .bs_r_8 = NULL, /* Use inline code in bus.h */ - - /* read multiple */ - .bs_rm_1 = generic_bs_rm_1, - .bs_rm_2 = generic_bs_rm_2, - .bs_rm_4 = generic_bs_rm_4, - .bs_rm_8 = BS_UNIMPLEMENTED, - - /* read region */ - .bs_rr_1 = generic_bs_rr_1, - .bs_rr_2 = generic_bs_rr_2, - .bs_rr_4 = generic_bs_rr_4, - .bs_rr_8 = BS_UNIMPLEMENTED, - - /* write (single) */ - .bs_w_1 = NULL, /* Use inline code in bus.h */ - .bs_w_2 = NULL, /* Use inline code in bus.h */ - .bs_w_4 = NULL, /* Use inline code in bus.h */ - .bs_w_8 = NULL, /* Use inline code in bus.h */ - - /* write multiple */ - .bs_wm_1 = generic_bs_wm_1, - .bs_wm_2 = generic_bs_wm_2, - .bs_wm_4 = generic_bs_wm_4, - .bs_wm_8 = BS_UNIMPLEMENTED, - - /* write region */ - .bs_wr_1 = generic_bs_wr_1, - .bs_wr_2 = generic_bs_wr_2, - .bs_wr_4 = generic_bs_wr_4, - .bs_wr_8 = BS_UNIMPLEMENTED, - - /* set multiple */ - .bs_sm_1 = BS_UNIMPLEMENTED, - .bs_sm_2 = BS_UNIMPLEMENTED, - .bs_sm_4 = BS_UNIMPLEMENTED, - .bs_sm_8 = BS_UNIMPLEMENTED, - - /* set region */ - .bs_sr_1 = generic_bs_sr_1, - .bs_sr_2 = generic_bs_sr_2, - .bs_sr_4 = generic_bs_sr_4, - .bs_sr_8 = BS_UNIMPLEMENTED, - - /* copy */ - .bs_c_1 = BS_UNIMPLEMENTED, - .bs_c_2 = generic_bs_c_2, - .bs_c_4 = BS_UNIMPLEMENTED, - .bs_c_8 = BS_UNIMPLEMENTED, - - /* read stream (single) */ - .bs_r_1_s = NULL, /* Use inline code in bus.h */ - .bs_r_2_s = NULL, /* Use inline code in bus.h */ - .bs_r_4_s = NULL, /* Use inline code in bus.h */ - .bs_r_8_s = NULL, /* Use inline code in bus.h */ - - /* read multiple stream */ - .bs_rm_1_s = generic_bs_rm_1, - .bs_rm_2_s = generic_bs_rm_2, - .bs_rm_4_s = generic_bs_rm_4, - .bs_rm_8_s = BS_UNIMPLEMENTED, - - /* read region stream */ - .bs_rr_1_s = generic_bs_rr_1, - .bs_rr_2_s = generic_bs_rr_2, - .bs_rr_4_s = generic_bs_rr_4, - .bs_rr_8_s = BS_UNIMPLEMENTED, - - /* write stream (single) */ - .bs_w_1_s = NULL, /* Use inline code in bus.h */ - .bs_w_2_s = NULL, /* Use inline code in bus.h */ - .bs_w_4_s = NULL, /* Use inline code in bus.h */ - .bs_w_8_s = NULL, /* Use inline code in bus.h */ - - /* write multiple stream */ - .bs_wm_1_s = generic_bs_wm_1, - .bs_wm_2_s = generic_bs_wm_2, - .bs_wm_4_s = generic_bs_wm_4, - .bs_wm_8_s = BS_UNIMPLEMENTED, - - /* write region stream */ - .bs_wr_1_s = generic_bs_wr_1, - .bs_wr_2_s = generic_bs_wr_2, - .bs_wr_4_s = generic_bs_wr_4, - .bs_wr_8_s = BS_UNIMPLEMENTED, -}; - #ifndef FDT static struct at91_softc *at91_softc; @@ -265,7 +108,7 @@ at91_attach(device_t dev) arm_post_filter = at91_eoi; at91_softc = sc; - sc->sc_st = &at91_bs_tag; + sc->sc_st = arm_base_bs_tag; sc->sc_sh = AT91_BASE; sc->sc_aic_sh = AT91_BASE + AT91_SYS_BASE; sc->dev = dev; @@ -336,9 +179,9 @@ at91_alloc_resource(device_t dev, device_t child, int type, int *rid, rle->res = rman_reserve_resource(&sc->sc_mem_rman, start, end, count, flags, child); if (rle->res != NULL) { - bus_space_map(&at91_bs_tag, start, + bus_space_map(arm_base_bs_tag, start, rman_get_size(rle->res), 0, &bsh); - rman_set_bustag(rle->res, &at91_bs_tag); + rman_set_bustag(rle->res, arm_base_bs_tag); rman_set_bushandle(rle->res, bsh); } break; diff --git a/sys/arm/at91/at91_common.c b/sys/arm/at91/at91_common.c index 4153366..9f960f6 100644 --- a/sys/arm/at91/at91_common.c +++ b/sys/arm/at91/at91_common.c @@ -48,8 +48,6 @@ __FBSDID("$FreeBSD$"); #include <machine/fdt.h> extern const struct arm_devmap_entry at91_devmap[]; -extern struct bus_space at91_bs_tag; -bus_space_tag_t fdtbus_bs_tag = &at91_bs_tag; struct fdt_fixup_entry fdt_fixup_table[] = { { NULL, NULL } diff --git a/sys/arm/at91/at91_machdep.c b/sys/arm/at91/at91_machdep.c index 2d5dda2..936f145 100644 --- a/sys/arm/at91/at91_machdep.c +++ b/sys/arm/at91/at91_machdep.c @@ -114,8 +114,6 @@ __FBSDID("$FreeBSD$"); /* this should be evenly divisable by PAGE_SIZE / L2_TABLE_SIZE_REAL (or 4) */ #define NUM_KERNEL_PTS (KERNEL_PT_AFKERNEL + KERNEL_PT_AFKERNEL_NUM) -extern struct bus_space at91_bs_tag; - struct pv_addr kernel_pt_table[NUM_KERNEL_PTS]; /* Static device mappings. */ diff --git a/sys/arm/at91/files.at91 b/sys/arm/at91/files.at91 index 46b2045..57c21ad 100644 --- a/sys/arm/at91/files.at91 +++ b/sys/arm/at91/files.at91 @@ -68,3 +68,6 @@ dev/usb/controller/at91dci.c optional at91_dci dev/usb/controller/at91dci_atmelarm.c optional at91_dci ! fdt dev/usb/controller/at91dci_fdt.c optional at91_dci fdt +# We need this for both FDT and !FDT since we use arm_base_bs_ta +# files.arm picks it up for FDT. +arm/arm/bus_space_base.c optional !fdt diff --git a/sys/arm/at91/uart_cpu_at91usart.c b/sys/arm/at91/uart_cpu_at91usart.c index 57c4a5a..39f146c 100644 --- a/sys/arm/at91/uart_cpu_at91usart.c +++ b/sys/arm/at91/uart_cpu_at91usart.c @@ -50,7 +50,6 @@ __FBSDID("$FreeBSD$"); bus_space_tag_t uart_bus_space_io; bus_space_tag_t uart_bus_space_mem; -extern struct bus_space at91_bs_tag; extern struct uart_class at91_usart_class; int @@ -69,7 +68,7 @@ uart_cpu_getdev(int devtype, struct uart_devinfo *di) class->uc_rclk = at91_master_clock; di->ops = uart_getops(class); di->bas.chan = 0; - di->bas.bst = &at91_bs_tag; + di->bas.bst = arm_base_bs_tag; /* * XXX: Not pretty, but will work because we map the needed addresses * early. At least we probed this so that the console will work on @@ -82,7 +81,7 @@ uart_cpu_getdev(int devtype, struct uart_devinfo *di) di->databits = 8; di->stopbits = 1; di->parity = UART_PARITY_NONE; - uart_bus_space_io = &at91_bs_tag; + uart_bus_space_io = arm_base_bs_tag; uart_bus_space_mem = NULL; /* Check the environment for overrides */ uart_getenv(devtype, di, class); |