diff options
author | Andrew Thoelke <andrew.thoelke@arm.com> | 2014-06-26 23:02:28 +0100 |
---|---|---|
committer | Andrew Thoelke <andrew.thoelke@arm.com> | 2014-06-26 23:02:28 +0100 |
commit | 5e0f9bde13c4b10fd7545f47cb75046fcd94d16f (patch) | |
tree | a9eb0b94460e2815d91d75c0f37596c86569944f | |
parent | b1240733906f3570c836de890cefa6948919537f (diff) | |
parent | 5e11375398803a0e81003984f051ec436d0fbb46 (diff) | |
download | arm-trusted-firmware-master.tar.gz |
Inline the mmio accessor functions
-rw-r--r-- | include/lib/mmio.h | 33 | ||||
-rw-r--r-- | lib/mmio.c | 61 | ||||
-rw-r--r-- | plat/fvp/platform.mk | 1 |
3 files changed, 27 insertions, 68 deletions
diff --git a/include/lib/mmio.h b/include/lib/mmio.h index 5d33c59..cb37a1c 100644 --- a/include/lib/mmio.h +++ b/include/lib/mmio.h @@ -33,13 +33,34 @@ #include <stdint.h> -void mmio_write_8(uintptr_t addr, uint8_t value); -uint8_t mmio_read_8(uintptr_t addr); +static inline void mmio_write_8(uintptr_t addr, uint8_t value) +{ + *(volatile uint8_t*)addr = value; +} -void mmio_write_32(uintptr_t addr, uint32_t value); -uint32_t mmio_read_32(uintptr_t addr); +static inline uint8_t mmio_read_8(uintptr_t addr) +{ + return *(volatile uint8_t*)addr; +} -void mmio_write_64(uintptr_t addr, uint64_t value); -uint64_t mmio_read_64(uintptr_t addr); +static inline void mmio_write_32(uintptr_t addr, uint32_t value) +{ + *(volatile uint32_t*)addr = value; +} + +static inline uint32_t mmio_read_32(uintptr_t addr) +{ + return *(volatile uint32_t*)addr; +} + +static inline void mmio_write_64(uintptr_t addr, uint64_t value) +{ + *(volatile uint64_t*)addr = value; +} + +static inline uint64_t mmio_read_64(uintptr_t addr) +{ + return *(volatile uint64_t*)addr; +} #endif /* __MMIO_H__ */ diff --git a/lib/mmio.c b/lib/mmio.c deleted file mode 100644 index 1350609..0000000 --- a/lib/mmio.c +++ /dev/null @@ -1,61 +0,0 @@ -/* - * Copyright (c) 2013-2014, ARM Limited and Contributors. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * Redistributions of source code must retain the above copyright notice, this - * list of conditions and the following disclaimer. - * - * Redistributions in binary form must reproduce the above copyright notice, - * this list of conditions and the following disclaimer in the documentation - * and/or other materials provided with the distribution. - * - * Neither the name of ARM nor the names of its contributors may be used - * to endorse or promote products derived from this software without specific - * prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ - -#include <stdint.h> - -void mmio_write_8(uintptr_t addr, uint8_t value) -{ - *(volatile uint8_t*)addr = value; -} - -uint8_t mmio_read_8(uintptr_t addr) -{ - return *(volatile uint8_t*)addr; -} - -void mmio_write_32(uintptr_t addr, uint32_t value) -{ - *(volatile uint32_t*)addr = value; -} - -uint32_t mmio_read_32(uintptr_t addr) -{ - return *(volatile uint32_t*)addr; -} - -void mmio_write_64(uintptr_t addr, uint64_t value) -{ - *(volatile uint64_t*)addr = value; -} - -uint64_t mmio_read_64(uintptr_t addr) -{ - return *(volatile uint64_t*)addr; -} diff --git a/plat/fvp/platform.mk b/plat/fvp/platform.mk index 450529b..d200358 100644 --- a/plat/fvp/platform.mk +++ b/plat/fvp/platform.mk @@ -50,7 +50,6 @@ PLAT_BL_COMMON_SOURCES := drivers/arm/pl011/pl011.c \ drivers/io/io_fip.c \ drivers/io/io_memmap.c \ drivers/io/io_semihosting.c \ - lib/mmio.c \ lib/aarch64/xlat_tables.c \ lib/semihosting/semihosting.c \ lib/semihosting/aarch64/semihosting_call.S \ |