diff options
Diffstat (limited to 'qemu/roms/SLOF/slof/helpers.c')
-rw-r--r-- | qemu/roms/SLOF/slof/helpers.c | 150 |
1 files changed, 0 insertions, 150 deletions
diff --git a/qemu/roms/SLOF/slof/helpers.c b/qemu/roms/SLOF/slof/helpers.c deleted file mode 100644 index 48c34a65c..000000000 --- a/qemu/roms/SLOF/slof/helpers.c +++ /dev/null @@ -1,150 +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 - *****************************************************************************/ -/* - * All functions concerning interface to slof - */ - -#include <stdio.h> -#include <string.h> -#include <cpu.h> -#include "helpers.h" -#include "paflof.h" - -/** - * get msec-timer value - * access to HW register - * overrun will occur if boot exceeds 1.193 hours (49 days) - * - * @param - - * @return actual timer value in ms as 32bit - */ -uint32_t SLOF_GetTimer(void) -{ - forth_eval("get-msecs"); - return (uint32_t) forth_pop(); -} - -void SLOF_msleep(uint32_t time) -{ - time = SLOF_GetTimer() + time; - while (time > SLOF_GetTimer()) - cpu_relax(); -} - -void SLOF_usleep(uint32_t time) -{ - forth_push(time); - forth_eval("us"); -} - -void *SLOF_dma_alloc(long size) -{ - forth_push(size); - forth_eval("dma-alloc"); - return (void *)forth_pop(); -} - -void SLOF_dma_free(void *virt, long size) -{ - forth_push((long)virt); - forth_push(size); - forth_eval("dma-free"); -} - -void *SLOF_alloc_mem(long size) -{ - forth_push(size); - forth_eval("alloc-mem"); - return (void *)forth_pop(); -} - -void *SLOF_alloc_mem_aligned(long size, long align) -{ - unsigned long addr = (unsigned long)SLOF_alloc_mem(size + align - 1); - addr = addr + align - 1; - addr = addr & ~(align - 1); - - return (void *)addr; -} - -void SLOF_free_mem(void *addr, long size) -{ - forth_push((long)addr); - forth_push(size); - forth_eval("free-mem"); -} - -long SLOF_dma_map_in(void *virt, long size, int cacheable) -{ - forth_push((long)virt); - forth_push(size); - forth_push(cacheable); - forth_eval("dma-map-in"); - return forth_pop(); -} - -void SLOF_dma_map_out(long phys, void *virt, long size) -{ - forth_push((long)virt); - forth_push((long)phys); - forth_push(size); - forth_eval("dma-map-out"); -} - -long SLOF_pci_config_read32(long offset) -{ - forth_push(offset); - forth_eval("config-l@"); - return forth_pop(); -} - -long SLOF_pci_config_read16(long offset) -{ - forth_push(offset); - forth_eval("config-w@"); - return forth_pop(); -} - -long SLOF_pci_config_read8(long offset) -{ - forth_push(offset); - forth_eval("config-b@"); - return forth_pop(); -} - -void SLOF_pci_config_write32(long offset, long value) -{ - forth_push(value); - forth_push(offset); - forth_eval("config-l!"); -} - -void SLOF_pci_config_write16(long offset, long value) -{ - forth_push(value); - forth_push(offset); - forth_eval("config-w!"); -} - -void SLOF_pci_config_write8(long offset, long value) -{ - forth_push(value); - forth_push(offset); - forth_eval("config-b!"); -} - -void *SLOF_translate_my_address(void *addr) -{ - forth_push((long)addr); - forth_eval("translate-my-address"); - return (void *)forth_pop(); -} |