1974c85b1SJens Wiklander /* 2974c85b1SJens Wiklander * Copyright (c) 2016, Linaro Limited 3974c85b1SJens Wiklander * All rights reserved. 4974c85b1SJens Wiklander * 5974c85b1SJens Wiklander * Redistribution and use in source and binary forms, with or without 6974c85b1SJens Wiklander * modification, are permitted provided that the following conditions are met: 7974c85b1SJens Wiklander * 8974c85b1SJens Wiklander * 1. Redistributions of source code must retain the above copyright notice, 9974c85b1SJens Wiklander * this list of conditions and the following disclaimer. 10974c85b1SJens Wiklander * 11974c85b1SJens Wiklander * 2. Redistributions in binary form must reproduce the above copyright notice, 12974c85b1SJens Wiklander * this list of conditions and the following disclaimer in the documentation 13974c85b1SJens Wiklander * and/or other materials provided with the distribution. 14974c85b1SJens Wiklander * 15974c85b1SJens Wiklander * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 16974c85b1SJens Wiklander * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17974c85b1SJens Wiklander * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18974c85b1SJens Wiklander * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 19974c85b1SJens Wiklander * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 20974c85b1SJens Wiklander * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 21974c85b1SJens Wiklander * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22974c85b1SJens Wiklander * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23974c85b1SJens Wiklander * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 24974c85b1SJens Wiklander * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25974c85b1SJens Wiklander * POSSIBILITY OF SUCH DAMAGE. 26974c85b1SJens Wiklander */ 27974c85b1SJens Wiklander #ifndef __DRIVERS_SERIAL_H 28974c85b1SJens Wiklander #define __DRIVERS_SERIAL_H 29974c85b1SJens Wiklander 30*a26e2529SJerome Forissier #include <assert.h> 31ae8a86d9SJerome Forissier #include <stdbool.h> 32*a26e2529SJerome Forissier #include <types_ext.h> 33*a26e2529SJerome Forissier #include <mm/core_memprot.h> 34*a26e2529SJerome Forissier #include <mm/core_mmu.h> 35ae8a86d9SJerome Forissier 36974c85b1SJens Wiklander struct serial_chip { 37974c85b1SJens Wiklander const struct serial_ops *ops; 38974c85b1SJens Wiklander }; 39974c85b1SJens Wiklander 40974c85b1SJens Wiklander struct serial_ops { 41974c85b1SJens Wiklander void (*putc)(struct serial_chip *chip, int ch); 42974c85b1SJens Wiklander void (*flush)(struct serial_chip *chip); 43974c85b1SJens Wiklander bool (*have_rx_data)(struct serial_chip *chip); 44974c85b1SJens Wiklander int (*getchar)(struct serial_chip *chip); 45974c85b1SJens Wiklander }; 46974c85b1SJens Wiklander 47*a26e2529SJerome Forissier struct io_pa_va { 48*a26e2529SJerome Forissier paddr_t pa; 49*a26e2529SJerome Forissier vaddr_t va; 50*a26e2529SJerome Forissier }; 51*a26e2529SJerome Forissier 52*a26e2529SJerome Forissier /* 53*a26e2529SJerome Forissier * Helper function to return a physical or virtual address for a device, 54*a26e2529SJerome Forissier * depending on whether the MMU is enabled or not 55*a26e2529SJerome Forissier */ 56*a26e2529SJerome Forissier static inline vaddr_t io_pa_or_va(struct io_pa_va *p) 57*a26e2529SJerome Forissier { 58*a26e2529SJerome Forissier assert(p->pa); 59*a26e2529SJerome Forissier if (cpu_mmu_enabled()) { 60*a26e2529SJerome Forissier if (!p->va) 61*a26e2529SJerome Forissier p->va = (vaddr_t)phys_to_virt_io(p->pa); 62*a26e2529SJerome Forissier assert(p->va); 63*a26e2529SJerome Forissier return p->va; 64*a26e2529SJerome Forissier } 65*a26e2529SJerome Forissier return p->pa; 66*a26e2529SJerome Forissier } 67*a26e2529SJerome Forissier 68974c85b1SJens Wiklander #endif /*__DRIVERS_SERIASERIAL_H*/ 69