Deleted Added
full compact
copy.c (177152) copy.c (235694)
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:

--- 12 unchanged lines hidden (view full) ---

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>
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:

--- 12 unchanged lines hidden (view full) ---

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 177152 2008-03-13 17:54:21Z obrien $");
29__FBSDID("$FreeBSD: head/sys/boot/uboot/lib/copy.c 235694 2012-05-20 18:07:35Z kientzle $");
30
31#include <stand.h>
30
31#include <stand.h>
32#include <stdint.h>
32
33
34#include "api_public.h"
35#include "glue.h"
36
33/*
34 * MD primitives supporting placement of module data
37/*
38 * MD primitives supporting placement of module data
35 *
36 * XXX should check load address/size against memory top.
37 */
38
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 0x%08jX bigger than size 0x%08X\n",
70 (intmax_t)o, size);
71 return (void *)(start + o);
72}
73
39ssize_t
40uboot_copyin(const void *src, vm_offset_t dest, const size_t len)
41{
74ssize_t
75uboot_copyin(const void *src, vm_offset_t dest, const size_t len)
76{
42
43 bcopy(src, (void *)dest, len);
77 bcopy(src, uboot_vm_translate(dest), len);
44 return (len);
45}
46
47ssize_t
48uboot_copyout(const vm_offset_t src, void *dest, const size_t len)
49{
78 return (len);
79}
80
81ssize_t
82uboot_copyout(const vm_offset_t src, void *dest, const size_t len)
83{
50
51 bcopy((void *)src, dest, len);
84 bcopy(uboot_vm_translate(src), dest, len);
52 return (len);
53}
54
55ssize_t
56uboot_readin(const int fd, vm_offset_t dest, const size_t len)
57{
85 return (len);
86}
87
88ssize_t
89uboot_readin(const int fd, vm_offset_t dest, const size_t len)
90{
58
59 return (read(fd, (void *) dest, len));
91 return (read(fd, uboot_vm_translate(dest), len));
60}
92}