Module Name: src Committed By: kiyohara Date: Sat Jun 22 13:32:54 UTC 2013
Modified Files: src/sys/arch/epoc32/epoc32: external_io.c external_io_asm.S Log Message: Fix bus_space_{read,write}_region_2. Remove bus_space_{read,write}_2. ARM7 can't read/write half word access. To generate a diff of this commit: cvs rdiff -u -r1.1 -r1.2 src/sys/arch/epoc32/epoc32/external_io.c \ src/sys/arch/epoc32/epoc32/external_io_asm.S Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/arch/epoc32/epoc32/external_io.c diff -u src/sys/arch/epoc32/epoc32/external_io.c:1.1 src/sys/arch/epoc32/epoc32/external_io.c:1.2 --- src/sys/arch/epoc32/epoc32/external_io.c:1.1 Sun Apr 28 12:11:26 2013 +++ src/sys/arch/epoc32/epoc32/external_io.c Sat Jun 22 13:32:54 2013 @@ -1,4 +1,4 @@ -/* $NetBSD: external_io.c,v 1.1 2013/04/28 12:11:26 kiyohara Exp $ */ +/* $NetBSD: external_io.c,v 1.2 2013/06/22 13:32:54 kiyohara Exp $ */ /* * Copyright (c) 1997 Mark Brinicombe. @@ -37,7 +37,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: external_io.c,v 1.1 2013/04/28 12:11:26 kiyohara Exp $"); +__KERNEL_RCSID(0, "$NetBSD: external_io.c,v 1.2 2013/06/22 13:32:54 kiyohara Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -74,7 +74,7 @@ struct bus_space external_bs_tag = { /* read (single) */ external_bs_r_1, - external_bs_r_2, + bs_notimpl_bs_r_2, external_bs_r_4, bs_notimpl_bs_r_8, @@ -92,7 +92,7 @@ struct bus_space external_bs_tag = { /* write (single) */ external_bs_w_1, - external_bs_w_2, + bs_notimpl_bs_w_2, external_bs_w_4, bs_notimpl_bs_w_8, @@ -130,7 +130,8 @@ struct bus_space external_bs_tag = { /* bus space functions */ int -external_bs_subregion(void *t, bus_space_handle_t bsh, bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp) +external_bs_subregion(void *t, bus_space_handle_t bsh, bus_size_t offset, + bus_size_t size, bus_space_handle_t *nbshp) { *nbshp = bsh + offset; @@ -154,8 +155,13 @@ external_bs_rr_2(void *cookie, bus_space { int i; - for (i = 0; i < count; i++) - datap[i] = external_bs_r_2(cookie, bsh, offset + i); + for (i = 0; count - i > 1 && i < count; i += 2) + *(uint32_t *)(&datap[i]) = + external_bs_r_4(cookie, bsh, offset + (i << 1)); + for (; i < count; i++) + datap[i] = + external_bs_r_1(cookie, bsh, offset + (i << 1)) | + external_bs_r_1(cookie, bsh, offset + (i << 1) + 1); } void @@ -173,9 +179,16 @@ external_bs_wr_2(void *cookie, bus_space bus_size_t offset, uint16_t const *datap, bus_size_t count) { int i; + uint16_t v; - for (i = 0; i < count; i++) - external_bs_w_2(cookie, bsh, offset + i, datap[i]); + for (i = 0; count - i > 1 && i < count; i += 2) + external_bs_w_4(cookie, bsh, offset + (i << 1), + *(const uint32_t *)(&datap[i])); + for (; i < count; i++) { + v = datap[i]; + external_bs_w_1(cookie, bsh, offset + (i << 1), v & 0xff); + external_bs_w_1(cookie, bsh, offset + (i << 1) + 1, v >> 8); + } } void @@ -194,6 +207,11 @@ external_bs_sr_2(void *cookie, bus_space { int i; - for (i = 0; i < count; i++) - external_bs_w_2(cookie, bsh, offset + i, value); + for (i = 0; count - i > 1 && i < count; i += 2) + external_bs_w_4(cookie, bsh, offset + (i << 1), + value | (value << 16)); + for (; i < count; i++) { + external_bs_w_1(cookie, bsh, offset + (i << 1), value & 0xff); + external_bs_w_1(cookie, bsh, offset + (i << 1) + 1, value >> 8); + } } Index: src/sys/arch/epoc32/epoc32/external_io_asm.S diff -u src/sys/arch/epoc32/epoc32/external_io_asm.S:1.1 src/sys/arch/epoc32/epoc32/external_io_asm.S:1.2 --- src/sys/arch/epoc32/epoc32/external_io_asm.S:1.1 Sun Apr 28 12:11:26 2013 +++ src/sys/arch/epoc32/epoc32/external_io_asm.S Sat Jun 22 13:32:54 2013 @@ -1,4 +1,4 @@ -/* $NetBSD: external_io_asm.S,v 1.1 2013/04/28 12:11:26 kiyohara Exp $ */ +/* $NetBSD: external_io_asm.S,v 1.2 2013/06/22 13:32:54 kiyohara Exp $ */ /* * Copyright (c) 1997 Mark Brinicombe. @@ -47,13 +47,6 @@ ENTRY(external_bs_r_1) ldrb r0, [r1, r2] mov pc, lr -ENTRY(external_bs_r_2) - mov r2, r2, lsl r0 - ldr r0, [r1, r2] - bic r0, r0, #0xff000000 - bic r0, r0, #0x00ff0000 - mov pc, lr - ENTRY(external_bs_r_4) mov r2, r2, lsl r0 ldr r0, [r1, r2] @@ -68,13 +61,6 @@ ENTRY(external_bs_w_1) strb r3, [r1, r2] mov pc, lr -ENTRY(external_bs_w_2) - mov r3, r3, lsl #16 - orr r3, r3, r3, lsr #16 - mov r2, r2, lsl r0 - str r3, [r1, r2] - mov pc, lr - ENTRY(external_bs_w_4) mov r2, r2, lsl r0 str r3, [r1, r2]