/* $NetBSD: arcemu.h,v 1.13 2016/07/07 06:55:38 msaitoh Exp $ */ /* * Copyright (c) 2004 Steve Rumble * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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. */ #ifndef _ARCEMU_H_ #include #include #include #include int arcemu_init(const char **); #ifdef _ARCEMU_PRIVATE /* Platform identification */ static int arcemu_identify(void); /* Helper functions */ static boolean_t extractenv(const char **, const char *, char *, int); /* * IP6, IP12 ARCS Emulation */ /* Prom Emulators */ static void arcemu_ipN_init(const char **); static void * arcemu_GetPeer(void *); static void * arcemu_GetChild(void *); static const char * arcemu_GetEnvironmentVariable(const char *); static void * arcemu_ip6_GetMemoryDescriptor(void *mem); static void * arcemu_ip12_GetMemoryDescriptor(void *mem); static void arcemu_eeprom_read(void); static void arcemu_prom_putc(dev_t, int); #define ARCEMU_ENVOK(_x) \ (MIPS_PHYS_TO_KSEG1((_x)) >= 0xa0000000 && \ MIPS_PHYS_TO_KSEG1((_x)) < 0xa0800000) /* ARCBIOS Component Tree. Represented in linear fashion. */ static struct arcbios_component arcemu_component_tree[] = { { COMPONENT_CLASS_ProcessorClass, COMPONENT_TYPE_CPU, -1, -1, -1, -1, -1, -1, -1, 0 }, /* end of list */ { -1, -1, -1, -1, -1, -1, -1, -1, -1, 0 } }; /* Unimplmented Vector */ #define ARCEMU_UNIMPL ((int32_t)(intptr_t)arcemu_unimpl) static void arcemu_unimpl(void); /* * EEPROM bit access functions. */ static inline void ip6_set_pre(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) |= 0x10; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) &= ~0x10; DELAY(4); } static inline void ip6_set_cs(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) |= 0x20; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) &= ~0x20; DELAY(4); } static inline void ip6_set_sk(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) |= 0x40; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f8e0000) &= ~0x40; DELAY(4); } static inline int ip6_get_do(void) { DELAY(4); if (*(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1f800001) & 0x01) return (1); return (0); } static inline void ip6_set_di(int raise) { if (raise) *(volatile uint16_t *)MIPS_PHYS_TO_KSEG1(0x1f880002) |= 0x0100; else *(volatile uint16_t *)MIPS_PHYS_TO_KSEG1(0x1f880002) &= ~0x0100; DELAY(4); } static inline void ip12_set_pre(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) |= 0x01; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) &= ~0x01; DELAY(4); } static inline void ip12_set_cs(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) |= 0x02; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) &= ~0x02; DELAY(4); } static inline void ip12_set_sk(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) |= 0x04; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) &= ~0x04; DELAY(4); } static inline int ip12_get_do(void) { DELAY(4); if (*(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) & 0x08) return (1); return (0); } static inline void ip12_set_di(int raise) { if (raise) *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) |= 0x10; else *(volatile uint8_t *)MIPS_PHYS_TO_KSEG1(0x1fbd0000) &= ~0x10; DELAY(4); } #endif /* _ARCEMU_PRIVATE */ #endif /* _ARCEMU_H_ */