14ecca339SDan Handley /* 24ecca339SDan Handley * Copyright (c) 2013-2014, ARM Limited and Contributors. All rights reserved. 34ecca339SDan Handley * 44ecca339SDan Handley * Redistribution and use in source and binary forms, with or without 54ecca339SDan Handley * modification, are permitted provided that the following conditions are met: 64ecca339SDan Handley * 74ecca339SDan Handley * Redistributions of source code must retain the above copyright notice, this 84ecca339SDan Handley * list of conditions and the following disclaimer. 94ecca339SDan Handley * 104ecca339SDan Handley * Redistributions in binary form must reproduce the above copyright notice, 114ecca339SDan Handley * this list of conditions and the following disclaimer in the documentation 124ecca339SDan Handley * and/or other materials provided with the distribution. 134ecca339SDan Handley * 144ecca339SDan Handley * Neither the name of ARM nor the names of its contributors may be used 154ecca339SDan Handley * to endorse or promote products derived from this software without specific 164ecca339SDan Handley * prior written permission. 174ecca339SDan Handley * 184ecca339SDan Handley * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 194ecca339SDan Handley * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 204ecca339SDan Handley * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 214ecca339SDan Handley * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 224ecca339SDan Handley * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 234ecca339SDan Handley * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 244ecca339SDan Handley * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 254ecca339SDan Handley * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 264ecca339SDan Handley * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 274ecca339SDan Handley * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 284ecca339SDan Handley * POSSIBILITY OF SUCH DAMAGE. 294ecca339SDan Handley */ 304ecca339SDan Handley 314ecca339SDan Handley #ifndef __MMIO_H__ 324ecca339SDan Handley #define __MMIO_H__ 334ecca339SDan Handley 344ecca339SDan Handley #include <stdint.h> 354ecca339SDan Handley 36*5e113753SAndrew Thoelke static inline void mmio_write_8(uintptr_t addr, uint8_t value) 37*5e113753SAndrew Thoelke { 38*5e113753SAndrew Thoelke *(volatile uint8_t*)addr = value; 39*5e113753SAndrew Thoelke } 404ecca339SDan Handley 41*5e113753SAndrew Thoelke static inline uint8_t mmio_read_8(uintptr_t addr) 42*5e113753SAndrew Thoelke { 43*5e113753SAndrew Thoelke return *(volatile uint8_t*)addr; 44*5e113753SAndrew Thoelke } 454ecca339SDan Handley 46*5e113753SAndrew Thoelke static inline void mmio_write_32(uintptr_t addr, uint32_t value) 47*5e113753SAndrew Thoelke { 48*5e113753SAndrew Thoelke *(volatile uint32_t*)addr = value; 49*5e113753SAndrew Thoelke } 50*5e113753SAndrew Thoelke 51*5e113753SAndrew Thoelke static inline uint32_t mmio_read_32(uintptr_t addr) 52*5e113753SAndrew Thoelke { 53*5e113753SAndrew Thoelke return *(volatile uint32_t*)addr; 54*5e113753SAndrew Thoelke } 55*5e113753SAndrew Thoelke 56*5e113753SAndrew Thoelke static inline void mmio_write_64(uintptr_t addr, uint64_t value) 57*5e113753SAndrew Thoelke { 58*5e113753SAndrew Thoelke *(volatile uint64_t*)addr = value; 59*5e113753SAndrew Thoelke } 60*5e113753SAndrew Thoelke 61*5e113753SAndrew Thoelke static inline uint64_t mmio_read_64(uintptr_t addr) 62*5e113753SAndrew Thoelke { 63*5e113753SAndrew Thoelke return *(volatile uint64_t*)addr; 64*5e113753SAndrew Thoelke } 654ecca339SDan Handley 664ecca339SDan Handley #endif /* __MMIO_H__ */ 67