copy.c revision 246948
1/*- 2 * Copyright (c) 1998 Michael Smith <msmith@freebsd.org> 3 * Copyright (c) 2007 Semihalf, Rafal Jaworowski <raj@semihalf.com> 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25 * SUCH DAMAGE. 26 */ 27 28#include <sys/cdefs.h> 29__FBSDID("$FreeBSD: head/sys/boot/uboot/lib/copy.c 246948 2013-02-18 20:11:20Z kientzle $"); 30 31#include <stand.h> 32#include <stdint.h> 33 34#include "api_public.h" 35#include "glue.h" 36 37/* 38 * MD primitives supporting placement of module data 39 */ 40 41void * 42uboot_vm_translate(vm_offset_t o) { 43 struct sys_info *si; 44 static uintptr_t start = 0; 45 static size_t size = 0; 46 int i; 47 48 if (size == 0) { 49 if ((si = ub_get_sys_info()) == NULL) 50 panic("could not retrieve system info"); 51 52 /* Find start/size of largest DRAM block. */ 53 for (i = 0; i < si->mr_no; i++) { 54 if (si->mr[i].flags == MR_ATTR_DRAM 55 && si->mr[i].size > size) { 56 start = si->mr[i].start; 57 size = si->mr[i].size; 58 } 59 } 60 61 if (size <= 0) 62 panic("No suitable DRAM?\n"); 63 /* 64 printf("Loading into memory region 0x%08X-0x%08X (%d MiB)\n", 65 start, start + size, size / 1024 / 1024); 66 */ 67 } 68 if (o > size) 69 panic("Address offset 0x%08jX bigger than size 0x%08X\n", 70 (intmax_t)o, size); 71 return (void *)(start + o); 72} 73 74ssize_t 75uboot_copyin(const void *src, vm_offset_t dest, const size_t len) 76{ 77 bcopy(src, uboot_vm_translate(dest), len); 78 return (len); 79} 80 81ssize_t 82uboot_copyout(const vm_offset_t src, void *dest, const size_t len) 83{ 84 bcopy(uboot_vm_translate(src), dest, len); 85 return (len); 86} 87 88ssize_t 89uboot_readin(const int fd, vm_offset_t dest, const size_t len) 90{ 91 return (read(fd, uboot_vm_translate(dest), len)); 92} 93