]> CyberLeo.Net >> Repos - FreeBSD/releng/10.0.git/blob - sys/boot/uboot/lib/copy.c
- Copy stable/10 (r259064) to releng/10.0 as part of the
[FreeBSD/releng/10.0.git] / sys / boot / uboot / lib / copy.c
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$");
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
41 void *
42 uboot_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
74 ssize_t
75 uboot_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
81 ssize_t
82 uboot_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
88 ssize_t
89 uboot_readin(const int fd, vm_offset_t dest, const size_t len)
90 {
91         return (read(fd, uboot_vm_translate(dest), len));
92 }