diff options
author | RajithaY <rajithax.yerrumsetty@intel.com> | 2017-04-25 03:31:15 -0700 |
---|---|---|
committer | Rajitha Yerrumchetty <rajithax.yerrumsetty@intel.com> | 2017-05-22 06:48:08 +0000 |
commit | bb756eebdac6fd24e8919e2c43f7d2c8c4091f59 (patch) | |
tree | ca11e03542edf2d8f631efeca5e1626d211107e3 /qemu/roms/SLOF/include | |
parent | a14b48d18a9ed03ec191cf16b162206998a895ce (diff) |
Adding qemu as a submodule of KVMFORNFV
This Patch includes the changes to add qemu as a submodule to
kvmfornfv repo and make use of the updated latest qemu for the
execution of all testcase
Change-Id: I1280af507a857675c7f81d30c95255635667bdd7
Signed-off-by:RajithaY<rajithax.yerrumsetty@intel.com>
Diffstat (limited to 'qemu/roms/SLOF/include')
-rw-r--r-- | qemu/roms/SLOF/include/allocator.h | 23 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/byteorder.h | 96 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/calculatecrc.h | 66 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/helpers.h | 44 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/libelf.h | 99 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/macros.h | 58 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/memmap.h | 26 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/netdriver.h | 24 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/pcd.h | 58 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/ppc970/cache.h | 128 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/ppc970/cpu.h | 113 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/ppcp7/cache.h | 155 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/ppcp7/cpu.h | 66 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/romfs.h | 60 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/rtas.h | 42 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/rtas_table.h | 32 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/termctrl.h | 62 | ||||
-rw-r--r-- | qemu/roms/SLOF/include/xvect.h | 21 |
18 files changed, 0 insertions, 1173 deletions
diff --git a/qemu/roms/SLOF/include/allocator.h b/qemu/roms/SLOF/include/allocator.h deleted file mode 100644 index 0f75fce35..000000000 --- a/qemu/roms/SLOF/include/allocator.h +++ /dev/null @@ -1,23 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2007, 2012, 2013 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef _ALLOCATOR_H -#define _ALLOCATOR_H - -extern void SLOF_bm_print(unsigned long handle); -extern unsigned long SLOF_bm_allocator_init(unsigned long start, - unsigned long size, - unsigned long blocksize); -extern unsigned long SLOF_bm_alloc(unsigned long handle, unsigned long size); -extern void SLOF_bm_free(unsigned long handle, unsigned long ptr, unsigned long size); - -#endif /* _ALLOCATOR_H */ diff --git a/qemu/roms/SLOF/include/byteorder.h b/qemu/roms/SLOF/include/byteorder.h deleted file mode 100644 index d4a2c8ca7..000000000 --- a/qemu/roms/SLOF/include/byteorder.h +++ /dev/null @@ -1,96 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2011 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -/* - * Common byteorder (endianness) macros - */ - -#ifndef BYTEORDER_H -#define BYTEORDER_H - -#include <stdint.h> - -typedef uint16_t le16; -typedef uint32_t le32; -typedef uint64_t le64; - -static inline uint16_t bswap_16 (uint16_t x) -{ - return __builtin_bswap16(x); -} - -static inline uint32_t bswap_32 (uint32_t x) -{ - return __builtin_bswap32(x); -} - -static inline uint64_t bswap_64 (uint64_t x) -{ - return __builtin_bswap64(x); -} - -static inline void bswap_16p (uint16_t *x) -{ - *x = __builtin_bswap16(*x); -} - -static inline void bswap_32p (uint32_t *x) -{ - *x = __builtin_bswap32(*x); -} - -static inline void bswap_64p (uint64_t *x) -{ - *x = __builtin_bswap64(*x); -} - - -/* gcc defines __BIG_ENDIAN__ on big endian targets */ -#ifdef __BIG_ENDIAN__ - -#define cpu_to_be16(x) (x) -#define cpu_to_be32(x) (x) -#define cpu_to_be64(x) (x) - -#define be16_to_cpu(x) (x) -#define be32_to_cpu(x) (x) -#define be64_to_cpu(x) (x) - -#define le16_to_cpu(x) bswap_16(x) -#define le32_to_cpu(x) bswap_32(x) -#define le64_to_cpu(x) bswap_64(x) - -#define cpu_to_le16(x) bswap_16(x) -#define cpu_to_le32(x) bswap_32(x) -#define cpu_to_le64(x) bswap_64(x) - -#else - -#define cpu_to_be16(x) bswap_16(x) -#define cpu_to_be32(x) bswap_32(x) -#define cpu_to_be64(x) bswap_64(x) - -#define be16_to_cpu(x) bswap_16(x) -#define be32_to_cpu(x) bswap_32(x) -#define be64_to_cpu(x) bswap_64(x) - -#define le16_to_cpu(x) (x) -#define le32_to_cpu(x) (x) -#define le64_to_cpu(x) (x) - -#define cpu_to_le16(x) (x) -#define cpu_to_le32(x) (x) -#define cpu_to_le64(x) (x) - -#endif /* __BIG_ENDIAN__ */ - -#endif /* BYTEORDER_H */ diff --git a/qemu/roms/SLOF/include/calculatecrc.h b/qemu/roms/SLOF/include/calculatecrc.h deleted file mode 100644 index 216847813..000000000 --- a/qemu/roms/SLOF/include/calculatecrc.h +++ /dev/null @@ -1,66 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -#ifndef CALCULATECRC_H -#define CALCULATECRC_H - - #define FLASHFS_DATADDR 0x18 // uint64_t position of pointer to data - #define FLASHFS_FILE_SIZE_ADDR 0x08 // uint64_t pos of total flashimage size value relative to data - #define FLASHFS_HEADER_SIZE_ADDR 0x08 // uint64_t position of total flash header size value - - #ifdef __ASSEMBLER__ - // "CRC_GENERATOR" must contain equal inforamtion as "CRC_METHODE" - #define CRC_GENERATOR 0x0000000004C11DB7 - #define CRC_REGISTERMASK 0x00000000FFFFFFFF - #define CRC_REGISTERLENGTH 32 - #endif /* __ASSEMBLER__ */ - - #ifndef __ASSEMBLER__ - #define FLASHFS_ROMADDR 0x00 // uint64_t position of pointer to next file - #define FLASHFS_HEADER_DATA_SIZE 0x68 // 104 bytes of total header data size - #define CRC_METHODE Ethernet_32 // define the CRc genarator (CRC 16 bit to 64 is supported) - - //--- header format --------------------------------- - struct stH { - char magic[8]; // (generic!) headerfile - uint64_t flashlen; // dyn - char version[16]; // $DRIVER_INFO alignment! - char platform_name[32]; // (hardware) headerfile - char date[6]; // dyn (format -> JB) - char padding1[2]; // padding byte - char mdate[6]; // modify date - char padding2[2]; // padding byte - char platform_revision[4];// (hardware) headerfile - uint32_t padding; - uint64_t ui64CRC; // insert calculated CRC here - uint64_t ui64FileEnd; // = 0xFFFF FFFF FFFF FFFF - }; - #endif /* __ASSEMBLER__ */ - -#endif /* CALCULATECRC_H */ - -/*--- supported CRC Generators ------------------------- -+ Name length usage Generator -+ Tap_16 16 bit Tape 0x00008005 -+ Floppy_16 16 bit Floppy 0x00001021 -+ Ethernet_32 32 bit Ethernet 0x04C11DB7 -+ SPTrEMBL_64 64 bit white noise like date 0x0000001B -+ SPTrEMBL_improved_64 64 bit DNA code like date 0xAD93D23594C9362D -+ DLT1_64 64 bit Tape 0x42F0E1EBA9EA3693 -+ -+ CRC_REGISTERLENGTH = bit length -+ CRC_REGISTERMASK = -1 for a n-bit numer where n = bit length -+ example TAP_16: CRC_REGSISTERLENGTH = 16 -+ CRC_REGISTERMASK = 0xFFFFFFFF = (-1 if 16 bit number is used) -+ -+ TrEMBL see also http://www.cs.ud.ac.uk/staff/D.Jones/crcbote.pdf -+ DLT1 se also http://www.ecma-international.org/publications/files/ECMA-ST/Ecma-182.pdf -+--------------------------------------------------------*/ diff --git a/qemu/roms/SLOF/include/helpers.h b/qemu/roms/SLOF/include/helpers.h deleted file mode 100644 index 5b3d711ac..000000000 --- a/qemu/roms/SLOF/include/helpers.h +++ /dev/null @@ -1,44 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2007, 2012, 2013 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -/* - * USB SLOF Prototypes - */ - -#ifndef _USB_SLOF_H -#define _USB_SLOF_H - -#include <stdint.h> - -extern uint32_t SLOF_GetTimer(void); -extern void SLOF_msleep(uint32_t time); -extern void SLOF_usleep(uint32_t time); -extern void *SLOF_dma_alloc(long size); -extern void SLOF_dma_free(void *virt, long size); -extern void *SLOF_alloc_mem(long size); -extern void *SLOF_alloc_mem_aligned(long size, long align); -extern void SLOF_free_mem(void *addr, long size); -extern long SLOF_dma_map_in(void *virt, long size, int cacheable); -extern void SLOF_dma_map_out(long phys, void *virt, long size); -extern long SLOF_pci_config_read32(long offset); -extern long SLOF_pci_config_read16(long offset); -extern long SLOF_pci_config_read8(long offset); -extern void SLOF_pci_config_write32(long offset, long value); -extern void SLOF_pci_config_write16(long offset, long value); -extern void SLOF_pci_config_write8(long offset, long value); -extern void *SLOF_translate_my_address(void *addr); - -#define offset_of(type, member) ((long) &((type *)0)->member) -#define container_of(ptr, type, member) ({ \ - const typeof(((type *)0)->member)* struct_ptr = (ptr); \ - (type *)((char *)struct_ptr - offset_of(type, member)); }) - -#endif diff --git a/qemu/roms/SLOF/include/libelf.h b/qemu/roms/SLOF/include/libelf.h deleted file mode 100644 index 5fbf27927..000000000 --- a/qemu/roms/SLOF/include/libelf.h +++ /dev/null @@ -1,99 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2011 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -/* - * ELF loader library - */ - -#ifndef __LIBELF_H -#define __LIBELF_H - -#include <stdint.h> - -/* ELF object file types */ -#define ET_NONE 0 /* No file type */ -#define ET_REL 1 /* Relocatable file */ -#define ET_EXEC 2 /* Executable file */ -#define ET_DYN 3 /* Shared object file */ -#define ET_CORE 4 /* Core file */ - -/* ELF object endian */ -#define ELFDATA2LSB 1 /* 2's complement, little endian */ -#define ELFDATA2MSB 2 /* 2's complement, big endian */ - -/* Generic ELF header */ -struct ehdr { - uint32_t ei_ident; - uint8_t ei_class; - uint8_t ei_data; - uint8_t ei_version; - uint8_t ei_pad[9]; - uint16_t e_type; - uint16_t e_machine; - uint32_t e_version; -}; - -/* Section types (sh_type) */ -#define SHT_NULL 0 /* Unused section header */ -#define SHT_PROGBITS 1 /* Information defined by the program */ -#define SHT_SYMTAB 2 /* Linker symbol table */ -#define SHT_STRTAB 3 /* String table */ -#define SHT_RELA 4 /* "Rela" type relocation entries */ -#define SHT_HASH 5 /* Symbol hash table */ -#define SHT_DYNAMIC 6 /* Dynamic linking tables */ -#define SHT_NOTE 7 /* Note information */ -#define SHT_NOBITS 8 /* Uninitialized space */ -#define SHT_REL 9 /* "Rel" type relocation entries */ -#define SHT_SHLIB 10 /* Reserved */ -#define SHT_DYNSYM 11 /* Dynamic loader symbol table */ - -/* Section attributs (sh_flags) */ -#define SHF_WRITE 0x1 -#define SHF_ALLOC 0x2 -#define SHF_EXECINSTR 0x4 - -/* Segment types (p_type) */ -#define PT_NULL 0 /* Unused entry */ -#define PT_LOAD 1 /* Loadable segment */ -#define PT_DYNAMIC 2 /* Dynamic linking tables */ -#define PT_INTERP 3 /* Program interpreter path name */ -#define PT_NOTE 4 /* Note sections */ - - -int elf_load_file(void *file_addr, unsigned long *entry, - int (*pre_load)(void*, long), - void (*post_load)(void*, long)); -int elf_load_file_to_addr(void *file_addr, void *addr, unsigned long *entry, - int (*pre_load)(void*, long), - void (*post_load)(void*, long)); - -void elf_byteswap_header32(void *file_addr); -void elf_byteswap_header64(void *file_addr); - -unsigned int elf_load_segments32(void *file_addr, signed long offset, - int (*pre_load)(void*, long), - void (*post_load)(void*, long)); -unsigned long elf_load_segments64(void *file_addr, signed long offset, - int (*pre_load)(void*, long), - void (*post_load)(void*, long)); - -long elf_get_base_addr(void *file_addr); -long elf_get_base_addr32(void *file_addr); -long elf_get_base_addr64(void *file_addr); -uint32_t elf_get_eflags_32(void *file_addr); -uint32_t elf_get_eflags_64(void *file_addr); - -void elf_relocate64(void *file_addr, signed long offset); - -int elf_forth_claim(void *addr, long size); - -#endif /* __LIBELF_H */ diff --git a/qemu/roms/SLOF/include/macros.h b/qemu/roms/SLOF/include/macros.h deleted file mode 100644 index f519bb8a7..000000000 --- a/qemu/roms/SLOF/include/macros.h +++ /dev/null @@ -1,58 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#define LOAD64(rn,name) \ - lis rn,name##@highest; \ - ori rn,rn,name##@higher; \ - rldicr rn,rn,32,31; \ - oris rn,rn,name##@h; \ - ori rn,rn,name##@l - -#define LOAD32(rn, name) \ - lis rn,name##@h; \ - ori rn,rn,name##@l - -// load 32 bit constant in little endian order -#define LOAD32le(rn,name) \ - lis rn,(((name>>8)&0x00FF)|((name<<8)&0xFF00)); \ - ori rn,rn,(((name>>24)&0x00FF)|((name>>8)&0xFF00)) - -// load 16 bit constant in little endian order -#define LOAD16le(rn,name) \ - li rn,(((name>>8)&0x00FF)|((name<<8)&0xFF00)) - -#define ENTRY(func_name) \ - .text; \ - .align 2; \ - .globl .func_name; \ - .func_name: \ - .globl func_name; \ - func_name: - -#define C_ENTRY(func_name) \ - .section ".text"; \ - .align 2; \ - .globl func_name; \ - .section ".opd","aw"; \ - .align 3; \ - func_name: \ - .quad .func_name,.TOC.@tocbase,0; \ - .previous; \ - .size func_name,24; \ - .type .func_name,@function; \ - .globl .func_name; \ - .func_name: - -#define ASM_ENTRY(fn) \ - .globl fn; \ -fn: - diff --git a/qemu/roms/SLOF/include/memmap.h b/qemu/roms/SLOF/include/memmap.h deleted file mode 100644 index abf3c1f03..000000000 --- a/qemu/roms/SLOF/include/memmap.h +++ /dev/null @@ -1,26 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -#ifndef MEMMAP_H -#define MEMMAP_H - -#define MEG 0x100000 - -#define SLAVELOOP_LOADBASE 0x0000000000003f00 -#define STAGE2_LOADBASE (60 * MEG) -#define OF_LOADBASE 0x000000000000a000 - -#define MEM_HALF (512 * MEG) - -/* BE Engines Offsets */ -#define BE_MIC_BASE 0x50A000 - -#endif diff --git a/qemu/roms/SLOF/include/netdriver.h b/qemu/roms/SLOF/include/netdriver.h deleted file mode 100644 index d81134eac..000000000 --- a/qemu/roms/SLOF/include/netdriver.h +++ /dev/null @@ -1,24 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2013 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - ******************************************************************************/ - -#ifndef _NETDRIVER_H -#define _NETDRIVER_H - -#include <stdint.h> - -typedef struct net_driver { - uint8_t mac_addr[6]; - uint32_t reg; - int running; -} net_driver_t; - -#endif diff --git a/qemu/roms/SLOF/include/pcd.h b/qemu/roms/SLOF/include/pcd.h deleted file mode 100644 index 9794b767f..000000000 --- a/qemu/roms/SLOF/include/pcd.h +++ /dev/null @@ -1,58 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -#ifndef PCD_H -#define PCD_H - -#define PCD_START_ADDR 0xFF00000 // FIXME: this should not interfere with - // other parts of the firmware -#define PCD_HDR_SIZE (6 * 8) /* only use for ctrl file */ - -/* PCD File Definition ****************************************/ -/* File = "p:ctrl" 0x703a6374726c0000 */ -/* Data : */ -/* [00:07] - pointer to header of last file which was created */ -/* [08:0f] - pointer to header of next file for creation */ -/**************************************************************/ -#define PCDF_CTRL_LAST 0 -#define PCDF_CTRL_NEXT 8 - -/* PCD File Definition ****************************************/ -/* File = "p:pXmem" */ -/* Data : */ -/* [00:07] - number of memory segments */ -/* [08:0f] - real base of memory segment #n */ -/* [10:17] - real size of memory segment #n */ -/* [18:1f] - real base of memory segment #n+1 */ -/* [20:27] - real size of memory segment #n+1 */ -/* ... and so on.. */ -/**************************************************************/ -#define PCDF_MEM_NUM 0 -#define PCDF_MEMN_BASE(N) (8 + ((N) * 16)) -#define PCDF_MEMN_SIZE(M) (PCDF_MEMN_BASE(M) + 8) - -/* PCD File Definition ****************************************/ -/* File = "p:pXcfg" */ -/* Data : */ -/* [00:07] - number of memory segments */ -/* [08:0f] - real base of memory segment #n */ -/* [10:17] - real size of memory segment #n */ -/* [18:1f] - real base of memory segment #n+1 */ -/* [20:27] - real size of memory segment #n+1 */ -/* ... and so on.. */ -/**************************************************************/ -#define PCDF_PCFG_IOCBASE (0 * 8) -#define PCDF_PCFG_BPBASE (1 * 8) -#define PCDF_PCFG_SPUMAP (2 * 8) -#define PCDF_PCFG_TIMEBASE (3 * 8) -#define PCDF_PCFG_CPUFREQ (4 * 8) - -#endif diff --git a/qemu/roms/SLOF/include/ppc970/cache.h b/qemu/roms/SLOF/include/ppc970/cache.h deleted file mode 100644 index 500182ea6..000000000 --- a/qemu/roms/SLOF/include/ppc970/cache.h +++ /dev/null @@ -1,128 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __CACHE_H -#define __CACHE_H - -#include <cpu.h> -#include <stdint.h> - -#define cache_inhibited_access(type,name) \ - static inline type ci_read_##name(type * addr) \ - { \ - type val; \ - set_ci(); \ - val = *addr; \ - clr_ci(); \ - return val; \ - } \ - static inline void ci_write_##name(type * addr, type data) \ - { \ - set_ci(); \ - *addr = data; \ - clr_ci(); \ - } - -cache_inhibited_access(uint8_t, 8) -cache_inhibited_access(uint16_t, 16) -cache_inhibited_access(uint32_t, 32) -cache_inhibited_access(uint64_t, 64) - -#define _FWOVERLAP(s, d, size) ((d >= s) && ((type_u)d < ((type_u)s + size))) - -// 3.1 -#define _FWMOVE(s, d, size, t) \ - { t *s1=(t *)s, *d1=(t *)d; \ - while (size > 0) { *d1++ = *s1++; size -= sizeof(t); } } - -#define _BWMOVE(s, d, size, t) { \ - t *s1=(t *)((char *)s+size), *d1=(t *)((char *)d+size); \ - while (size > 0) { *--d1 = *--s1; size -= sizeof(t); } \ -} - - -#define _MOVE(s, d, size, t) if _FWOVERLAP(s, d, size) _BWMOVE(s, d, size, t) else _FWMOVE(s, d, size, t) - -#define _FASTMOVE(s, d, size) \ - switch (((type_u)s | (type_u)d | size) & (sizeof(type_u)-1)) { \ - case 0: _MOVE(s, d, size, type_u); break; \ - case 4: _MOVE(s, d, size, type_l); break; \ - case 2: case 6: _MOVE(s, d, size, type_w); break; \ - default: _MOVE(s, d, size, type_c); break; \ - } - -// Device IO block data helpers -#define _FWRMOVE(s, d, size, t) \ - { t *s1=(t *)s, *d1=(t *)d; SET_CI; \ - while (size > 0) { *d1++ = *s1++; size -= sizeof(t); } \ - CLR_CI; \ -} - -#define _BWRMOVE(s, d, size, t) { \ - t *s1=(t *)((char *)s+size), *d1=(t *)((char *)d+size); SET_CI; \ - while (size > 0) { *--d1 = *--s1; size -= sizeof(t); } \ - CLR_CI; \ -} - -#define _RMOVE(s, d, size, t) if _FWOVERLAP(s, d, size) _BWRMOVE(s, d, size, t) else _FWRMOVE(s, d, size, t) - -#define _FASTRMOVE(s, d, size) \ - switch (((type_u)s | (type_u)d | size) & (sizeof(type_u)-1)) { \ - case 0: _RMOVE(s, d, size, type_u); break; \ - case 4: _RMOVE(s, d, size, type_l); break; \ - case 2: case 6: _RMOVE(s, d, size, type_w); break; \ - default: _RMOVE(s, d, size, type_c); break; \ - } - -/* main RAM to IO memory move */ -#define FAST_MRMOVE_TYPED(s, d, size, t) \ -{ \ - t *s1 = (s), *d1 = (d); \ - register t tmp; \ - while (size > 0) { \ - tmp = *s1++; SET_CI; *d1++ = tmp; CLR_CI; size -= sizeof(t); \ - } \ -} - -#define FAST_MRMOVE(s, d, size) \ - switch (((type_u)(s) | (type_u)(d) | (size)) & (sizeof(type_u)-1)) { \ - case 0: FAST_MRMOVE_TYPED(s, d, size, type_u); break; \ - case 4: FAST_MRMOVE_TYPED(s, d, size, type_l); break; \ - case 2: case 6: FAST_MRMOVE_TYPED(s, d, size, type_w); break; \ - default: FAST_MRMOVE_TYPED(s, d, size, type_c); break; \ - } - -/* fill IO memory with pattern */ -#define FAST_RFILL_TYPED(dst, size, pat, t) \ -{ \ - t *d1 = (dst); \ - register t tmp = 0; \ - int i = sizeof(t); \ - while (i-- > 0) { \ - tmp <<= 8; tmp |= pat & 0xff; \ - } \ - SET_CI; \ - while (size > 0) { \ - *d1++ = tmp; size -= sizeof(t); \ - } \ - CLR_CI; \ -} - -#define FAST_RFILL(dst, size, pat) \ - switch (((type_u)dst | size) & (sizeof(type_u)-1)) { \ - case 0: FAST_RFILL_TYPED(dst, size, pat, type_u); break; \ - case 4: FAST_RFILL_TYPED(dst, size, pat, type_l); break; \ - case 2: case 6: FAST_RFILL_TYPED(dst, size, pat, type_w); break; \ - default: FAST_RFILL_TYPED(dst, size, pat, type_c); break; \ - } - -#endif diff --git a/qemu/roms/SLOF/include/ppc970/cpu.h b/qemu/roms/SLOF/include/ppc970/cpu.h deleted file mode 100644 index 0e66dff36..000000000 --- a/qemu/roms/SLOF/include/ppc970/cpu.h +++ /dev/null @@ -1,113 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __PPC970_H -#define __PPC970_H - -/* SPRs numbers */ - -#define CTRL_RD 136 -#define CTRL_WR 152 -#define PVR 287 -#define HSPRG0 304 -#define HSPRG1 305 -#define HIOR 311 -#define HID0 1008 -#define HID1 1009 -#define HID4 1012 -#define HID6 1017 -#define PIR 1023 - -#define SETCI(r) sync; \ - mfspr r, HID4; \ - sync; \ - rldicl r, r, 32,0; \ - ori r, r, 0x0100; \ - rldicl r, r, 32,0; \ - sync; \ - slbia; \ - mtspr HID4, r; \ - isync; \ - eieio; - -#define CLRCI(r) sync; \ - mfspr r, HID4; \ - sync; \ - rldicl r, r, 32, 0; \ - ori r, r, 0x0100; \ - xori r, r, 0x0100; \ - rldicl r, r, 32, 0; \ - sync; \ - slbia; \ - mtspr HID4, r; \ - isync; \ - eieio; - -/* This macro uses r0 */ -#define FLUSH_CACHE(r, n) add n, n, r; \ - addi n, n, 127; \ - rlwinm r, r, 0,0,24; \ - rlwinm n, n, 0,0,24; \ - sub n, n, r; \ - srwi n, n, 7; \ - mtctr n; \ - 0: dcbst 0, r; \ - sync; \ - icbi 0, r; \ - sync; \ - isync; \ - addi r, r, 128; \ - bdnz 0b; - -#ifndef __ASSEMBLER__ -#define STRINGIFY(x...) #x -#define EXPAND(x) STRINGIFY(x) - -static inline void -set_ci(void) -{ - unsigned long tmp; - asm volatile(EXPAND(SETCI(%0)) : "=r"(tmp) :: "memory", "cc"); -} - -static inline void -clr_ci(void) -{ - unsigned long tmp; - asm volatile(EXPAND(CLRCI(%0)) : "=r"(tmp) :: "memory", "cc"); -} - -static inline void eieio(void) -{ - asm volatile ("eieio":::"memory"); -} - -static inline void barrier(void) -{ - asm volatile("" : : : "memory"); -} -#define cpu_relax() barrier() - -static inline void sync(void) -{ - asm volatile ("sync" ::: "memory"); -} -#define mb() sync() - -static inline void flush_cache(void* r, long n) -{ - asm volatile(EXPAND(FLUSH_CACHE(%0, %1)) : "+r"(r), "+r"(n) :: "memory", "cc", "r0", "ctr"); -} - -#endif /* __ASSEMBLER__ */ - -#endif diff --git a/qemu/roms/SLOF/include/ppcp7/cache.h b/qemu/roms/SLOF/include/ppcp7/cache.h deleted file mode 100644 index 3c02bb10d..000000000 --- a/qemu/roms/SLOF/include/ppcp7/cache.h +++ /dev/null @@ -1,155 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __CACHE_H -#define __CACHE_H - -#include <cpu.h> -#include <stdint.h> - -// XXX FIXME: Use proper CI load/store */ -#define cache_inhibited_access(type,size) \ - static inline type ci_read_##size(type * addr) \ - { \ - register uint64_t arg0 asm ("r3"); \ - register uint64_t arg1 asm ("r4"); \ - register uint64_t arg2 asm ("r5"); \ - \ - arg0 = 0x3c; /* H_LOGICAL_CI_LOAD*/ \ - arg1 = size / 8; \ - arg2 = (uint64_t)addr; \ - \ - asm volatile( \ - ".long 0x44000022 \n" /* HVCALL */ \ - : "=&r" (arg0), "=&r"(arg1), "=&r"(arg2) \ - : "0"(arg0), "1"(arg1), "2"(arg2) \ - : "r0", "r6", "r7", "r8", "r9", "r10", "r11", \ - "r12", "memory", "cr0", "cr1", "cr5", \ - "cr6", "cr7", "ctr", "xer"); \ - return arg0 ? (type)-1 : arg1; \ - } \ - static inline void ci_write_##size(type * addr, type data) \ - { \ - register uint64_t arg0 asm ("r3"); \ - register uint64_t arg1 asm ("r4"); \ - register uint64_t arg2 asm ("r5"); \ - register uint64_t arg3 asm ("r6"); \ - \ - arg0 = 0x40; /* H_LOGICAL_CI_STORE*/ \ - arg1 = size / 8; \ - arg2 = (uint64_t)addr; \ - arg3 = (uint64_t)data; \ - \ - asm volatile( \ - ".long 0x44000022 \n" /* HVCALL */ \ - : "=&r"(arg0),"=&r"(arg1),"=&r"(arg2),"=&r"(arg3) \ - : "0"(arg0),"1"(arg1),"2"(arg2),"3"(arg3) \ - : "r0", "r7", "r8", "r9", "r10", "r11", \ - "r12", "memory", "cr0", "cr1", "cr5", \ - "cr6", "cr7", "ctr", "xer"); \ - } - -cache_inhibited_access(uint8_t, 8) -cache_inhibited_access(uint16_t, 16) -cache_inhibited_access(uint32_t, 32) -cache_inhibited_access(uint64_t, 64) - -#define _FWOVERLAP(s, d, size) ((d >= s) && ((type_u)d < ((type_u)s + size))) - -// 3.1 -#define _FWMOVE(s, d, size, t) \ - { t *s1=(t *)s, *d1=(t *)d; \ - while (size > 0) { *d1++ = *s1++; size -= sizeof(t); } } - -#define _BWMOVE(s, d, size, t) { \ - t *s1=(t *)((char *)s+size), *d1=(t *)((char *)d+size); \ - while (size > 0) { *--d1 = *--s1; size -= sizeof(t); } \ -} - - -#define _MOVE(s, d, size, t) if _FWOVERLAP(s, d, size) _BWMOVE(s, d, size, t) else _FWMOVE(s, d, size, t) - -#define _FASTMOVE(s, d, size) \ - switch (((type_u)s | (type_u)d | size) & (sizeof(type_u)-1)) { \ - case 0: _MOVE(s, d, size, type_u); break; \ - case 4: _MOVE(s, d, size, type_l); break; \ - case 2: case 6: _MOVE(s, d, size, type_w); break; \ - default: _MOVE(s, d, size, type_c); break; \ - } - -static inline void ci_rmove(void *dst, void *src, unsigned long esize, - unsigned long count) -{ - register uint64_t arg0 asm ("r3"); - register uint64_t arg1 asm ("r4"); - register uint64_t arg2 asm ("r5"); - register uint64_t arg3 asm ("r6"); - register uint64_t arg4 asm ("r7"); - register uint64_t arg5 asm ("r8"); - - arg0 = 0xf001; /* KVMPPC_H_LOGICAL_MEMOP */ - arg1 = (uint64_t)dst; - arg2 = (uint64_t)src; - arg3 = esize; - arg4 = count; - arg5 = 0; /* 0 = copy */ - - asm volatile(".long 0x44000022 \n" /* HVCALL */ - : "=&r"(arg0),"=&r"(arg1),"=&r"(arg2), - "=&r"(arg3),"=&r"(arg4),"=&r"(arg5) - : "0"(arg0),"1"(arg1),"2"(arg2), - "3"(arg3),"4"(arg4),"5"(arg5) - : "r0", "r9", "r10", "r11", - "r12", "memory", "cr0", "cr1", "cr5", - "cr6", "cr7", "ctr", "xer"); -} - -#define _FASTRMOVE(s, d, size) do { \ - switch (((type_u)s | (type_u)d | size) & (sizeof(type_u)-1)) {\ - case 0: ci_rmove(d,s,3,size>>3); break; \ - case 4: ci_rmove(d,s,2,size>>2); break; \ - case 2: case 6: ci_rmove(d,s,1,size>>1); break; \ - default: ci_rmove(d,s,0,size); break; \ - } \ - } while(0) - -#define FAST_MRMOVE(s, d, size) _FASTRMOVE(s, d, size) - -extern void fast_rfill(char *dst, long size, char pat); -#define FAST_RFILL(dst, size, pat) fast_rfill(dst, size, pat) - -static inline uint16_t bswap16_load(uint64_t addr) -{ - unsigned int val; - asm volatile ("lhbrx %0, 0, %1":"=r" (val):"r"(addr)); - return val; -} - -static inline uint32_t bswap32_load(uint64_t addr) -{ - unsigned int val; - asm volatile ("lwbrx %0, 0, %1":"=r" (val):"r"(addr)); - return val; -} - -static inline void bswap16_store(uint64_t addr, uint16_t val) -{ - asm volatile ("sthbrx %0, 0, %1"::"r" (val), "r"(addr)); -} - -static inline void bswap32_store(uint64_t addr, uint32_t val) -{ - asm volatile ("stwbrx %0, 0, %1"::"r" (val), "r"(addr)); -} - -#endif /* __CACHE_H */ - diff --git a/qemu/roms/SLOF/include/ppcp7/cpu.h b/qemu/roms/SLOF/include/ppcp7/cpu.h deleted file mode 100644 index 1b1fadd82..000000000 --- a/qemu/roms/SLOF/include/ppcp7/cpu.h +++ /dev/null @@ -1,66 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __CPU_H -#define __CPU_H - -/* Used in boot_abort.S, will need something better for KVM */ -#define HSPRG0 304 - -/* XXX FIXME: Can be more efficient, no dcbst nor loop needed on P7 */ -/* This macro uses r0 */ -#define FLUSH_CACHE(r, n) add n, n, r; \ - addi n, n, 127; \ - rlwinm r, r, 0,0,24; \ - rlwinm n, n, 0,0,24; \ - sub n, n, r; \ - srwi n, n, 7; \ - mtctr n; \ - 0: dcbst 0, r; \ - sync; \ - icbi 0, r; \ - sync; \ - isync; \ - addi r, r, 128; \ - bdnz 0b; - -#ifndef __ASSEMBLER__ -#define STRINGIFY(x...) #x -#define EXPAND(x) STRINGIFY(x) - -static inline void flush_cache(void* r, long n) -{ - asm volatile(EXPAND(FLUSH_CACHE(%0, %1)) - : "+r"(r), "+r"(n) - :: "memory", "cc", "r0", "ctr"); -} - -static inline void eieio(void) -{ - asm volatile ("eieio":::"memory"); -} - -static inline void barrier(void) -{ - asm volatile("" : : : "memory"); -} -#define cpu_relax() barrier() - -static inline void sync(void) -{ - asm volatile ("sync" ::: "memory"); -} -#define mb() sync() - -#endif /* __ASSEMBLER__ */ - -#endif diff --git a/qemu/roms/SLOF/include/romfs.h b/qemu/roms/SLOF/include/romfs.h deleted file mode 100644 index 7228502c9..000000000 --- a/qemu/roms/SLOF/include/romfs.h +++ /dev/null @@ -1,60 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -#ifndef ROMFS_H -#define ROMFS_H - -#define RFS_T_SIZE 0x00 -#define RFS_T_FLAGS 0x08 -#define RFS_T_FILEADDR 0x10 -#define RFS_T_NEXT 0x18 -#define RFS_T_NAME 0x20 -#define RFS_T_DATA 0x28 - -#define RFS_H_NEXT 0x00 -#define RFS_H_SIZE 0x08 -#define RFS_H_FLAGS 0x10 -#define RFS_H_DATA 0x18 -#define RFS_H_NAME 0x20 - -#define ROMFS_HDR_NEXT (0 * 8) -#define ROMFS_HDR_LEN (1 * 8) -#define ROMFS_HDR_FLAG (2 * 8) -#define ROMFS_HDR_DPTR (3 * 8) -#define ROMFS_HDR_NAME (4 * 8) - -#ifndef __ASSEMBLER__ -/* no not change except if you change romfs.S */ -struct romfs_t { - unsigned long size; - unsigned long flags; - unsigned long fileaddr; - unsigned long nexfile; - unsigned char *namep; - unsigned char *datap; -}; - -struct romfs_lookup_t { - unsigned long addr_header; - unsigned long addr_data; - unsigned long size_data; - unsigned long flags; -}; - -int romfs_stat(char *filename, struct romfs_t *hnd); - -int romfs_stat_file(char *filename, struct romfs_t *hnd); - -int c_romfs_lookup(char *filename, unsigned long rombase, - struct romfs_lookup_t *ret); - -#endif /* __ASSEMBLER__ */ -#endif /* ROMFS_H */ diff --git a/qemu/roms/SLOF/include/rtas.h b/qemu/roms/SLOF/include/rtas.h deleted file mode 100644 index e44dedb1e..000000000 --- a/qemu/roms/SLOF/include/rtas.h +++ /dev/null @@ -1,42 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __RTAS_H -#define __RTAS_H - -#ifndef __ASSEMBLER__ - -#include <stddef.h> - -typedef int rtas_arg_t; -typedef struct { - int token; - int nargs; - int nret; - rtas_arg_t args[16]; -} rtas_args_t; - -#else - -#define RTAS_STACKSIZE 0x1000 - -#define RTAS_PARM_0 0x0c -#define RTAS_PARM_1 0x10 -#define RTAS_PARM_2 0x14 -#define RTAS_PARM_3 0x18 -#define RTAS_PARM_4 0x1C -#define RTAS_PARM_5 0x20 -#define RTAS_PARM_6 0x24 -#define RTAS_PARM_7 0x28 - -#endif /* __ASSEMBLER__ */ -#endif /* __RTAS_H */ diff --git a/qemu/roms/SLOF/include/rtas_table.h b/qemu/roms/SLOF/include/rtas_table.h deleted file mode 100644 index cdf9db7cd..000000000 --- a/qemu/roms/SLOF/include/rtas_table.h +++ /dev/null @@ -1,32 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __RTAS_TABLE_H -#define __RTAS_TABLE_H - - -typedef struct { - char *name; - void (*func)(rtas_args_t *args); - unsigned long flags; -} rtas_funcdescr_t; - - -// Flags for the RTAS table: -#define RTAS_TBLFLG_INTERNAL 1 - - -extern const rtas_funcdescr_t rtas_func_tab[]; -extern const int rtas_func_tab_size; - - -#endif // __RTAS_TABLE_H diff --git a/qemu/roms/SLOF/include/termctrl.h b/qemu/roms/SLOF/include/termctrl.h deleted file mode 100644 index 502ecae4c..000000000 --- a/qemu/roms/SLOF/include/termctrl.h +++ /dev/null @@ -1,62 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ -#ifndef TERMCTRL_H -#define TERMCTRL_H - -/* foreground colors */ -#define TERM_FG_BLACK "[30m" -#define TERM_FG_RED "[31m" -#define TERM_FG_GREEN "[32m" -#define TERM_FG_YELLOW "[33m" -#define TERM_FG_BLUE "[34m" -#define TERM_FG_MAGENTA "[35m" -#define TERM_FG_CYAN "[36m" -#define TERM_FG_WHITE "[37m" - -/* background colors */ -#define TERM_BG_BLACK "[40m" -#define TERM_BG_RED "[41m" -#define TERM_BG_GREEN "[42m" -#define TERM_BG_YELLOW "[43m" -#define TERM_BG_BLUE "[44m" -#define TERM_BG_MAGENTA "[45m" -#define TERM_BG_CYAN "[46m" -#define TERM_BG_WHITE "[47m" - -/* control */ -#define TERM_CTRL_RESET "[0m" -#define TERM_CTRL_BRIGHT "[1m" -#define TERM_CTRL_DIM "[2m" -#define TERM_CTRL_UNDERSCORE "[3m" -#define TERM_CTRL_BLINK "[4m" -#define TERM_CTRL_REVERSE "[5m" -#define TERM_CTRL_HIDDEN "[6m" -#define TERM_CTRL_CLEAR "[2J" -#define TERM_CTRL_HOME "[H" - -#define TERM_CTRL_1UP "[1A" -#define TERM_CTRL_1BACK "[1D" -#define TERM_CTRL_SAVECRS "[s" -#define TERM_CTRL_RESTCRS "[u" -#define TERM_CTRL_CRSON "[?25h" -#define TERM_CTRL_CRSOFF "[?25l" -#define TERM_CTRL_CRSFWDN "[%dC" -#define TERM_CTRL_CRSX "[%dC" -#define TERM_CTRL_CRSY "[%dB" -#define TERM_CTRL_CRSXY "[%d;%dH" /* y,x */ - -/* keys */ -#define KEY_CTRL 0x1b -#define KEY_UP 0x41 -#define KEY_DN 0x42 - -#endif diff --git a/qemu/roms/SLOF/include/xvect.h b/qemu/roms/SLOF/include/xvect.h deleted file mode 100644 index 5926b1869..000000000 --- a/qemu/roms/SLOF/include/xvect.h +++ /dev/null @@ -1,21 +0,0 @@ -/****************************************************************************** - * Copyright (c) 2004, 2008 IBM Corporation - * All rights reserved. - * This program and the accompanying materials - * are made available under the terms of the BSD License - * which accompanies this distribution, and is available at - * http://www.opensource.org/licenses/bsd-license.php - * - * Contributors: - * IBM Corporation - initial implementation - *****************************************************************************/ - -#ifndef __XVECT_H -#define __XVECT_H - -#define XVECT_M_HANDLER 0x2ff0 /* Master Handler */ -#define XVECT_S_HANDLER 0x2ff8 /* Slave Handler */ -#define XVECT_TOPADDR 0x3fff -#define XVECT_SLP_ENTRY SLAVELOOP_LOADBASE - -#endif |