xref: /dragonfly/stand/boot/pc32/libi386/i386_copy.c (revision 479ab7f0)
1*479ab7f0SSascha Wildner /*-
2*479ab7f0SSascha Wildner  * Copyright (c) 1998 Michael Smith <msmith@freebsd.org>
3*479ab7f0SSascha Wildner  * All rights reserved.
4*479ab7f0SSascha Wildner  *
5*479ab7f0SSascha Wildner  * Redistribution and use in source and binary forms, with or without
6*479ab7f0SSascha Wildner  * modification, are permitted provided that the following conditions
7*479ab7f0SSascha Wildner  * are met:
8*479ab7f0SSascha Wildner  * 1. Redistributions of source code must retain the above copyright
9*479ab7f0SSascha Wildner  *    notice, this list of conditions and the following disclaimer.
10*479ab7f0SSascha Wildner  * 2. Redistributions in binary form must reproduce the above copyright
11*479ab7f0SSascha Wildner  *    notice, this list of conditions and the following disclaimer in the
12*479ab7f0SSascha Wildner  *    documentation and/or other materials provided with the distribution.
13*479ab7f0SSascha Wildner  *
14*479ab7f0SSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*479ab7f0SSascha Wildner  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*479ab7f0SSascha Wildner  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*479ab7f0SSascha Wildner  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*479ab7f0SSascha Wildner  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*479ab7f0SSascha Wildner  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*479ab7f0SSascha Wildner  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*479ab7f0SSascha Wildner  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*479ab7f0SSascha Wildner  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*479ab7f0SSascha Wildner  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*479ab7f0SSascha Wildner  * SUCH DAMAGE.
25*479ab7f0SSascha Wildner  *
26*479ab7f0SSascha Wildner  * $FreeBSD: src/sys/boot/i386/libi386/i386_copy.c,v 1.10 2003/08/25 23:28:31 obrien Exp $
27*479ab7f0SSascha Wildner  * $DragonFly: src/sys/boot/pc32/libi386/i386_copy.c,v 1.3 2003/11/10 06:08:36 dillon Exp $
28*479ab7f0SSascha Wildner  */
29*479ab7f0SSascha Wildner 
30*479ab7f0SSascha Wildner /*
31*479ab7f0SSascha Wildner  * MD primitives supporting placement of module data
32*479ab7f0SSascha Wildner  *
33*479ab7f0SSascha Wildner  * XXX should check load address/size against memory top.
34*479ab7f0SSascha Wildner  */
35*479ab7f0SSascha Wildner #include <stand.h>
36*479ab7f0SSascha Wildner 
37*479ab7f0SSascha Wildner #include "libi386.h"
38*479ab7f0SSascha Wildner #include "btxv86.h"
39*479ab7f0SSascha Wildner 
40*479ab7f0SSascha Wildner #define READIN_BUF	(16 * 1024)
41*479ab7f0SSascha Wildner 
42*479ab7f0SSascha Wildner ssize_t
i386_copyin(const void * src,vm_offset_t dest,const size_t len)43*479ab7f0SSascha Wildner i386_copyin(const void *src, vm_offset_t dest, const size_t len)
44*479ab7f0SSascha Wildner {
45*479ab7f0SSascha Wildner     if (dest + len >= memtop) {
46*479ab7f0SSascha Wildner 	errno = EFBIG;
47*479ab7f0SSascha Wildner 	return(-1);
48*479ab7f0SSascha Wildner     }
49*479ab7f0SSascha Wildner 
50*479ab7f0SSascha Wildner     bcopy(src, PTOV(dest), len);
51*479ab7f0SSascha Wildner     return(len);
52*479ab7f0SSascha Wildner }
53*479ab7f0SSascha Wildner 
54*479ab7f0SSascha Wildner ssize_t
i386_copyout(const vm_offset_t src,void * dest,const size_t len)55*479ab7f0SSascha Wildner i386_copyout(const vm_offset_t src, void *dest, const size_t len)
56*479ab7f0SSascha Wildner {
57*479ab7f0SSascha Wildner     if (src + len >= memtop) {
58*479ab7f0SSascha Wildner 	errno = EFBIG;
59*479ab7f0SSascha Wildner 	return(-1);
60*479ab7f0SSascha Wildner     }
61*479ab7f0SSascha Wildner 
62*479ab7f0SSascha Wildner     bcopy(PTOV(src), dest, len);
63*479ab7f0SSascha Wildner     return(len);
64*479ab7f0SSascha Wildner }
65*479ab7f0SSascha Wildner 
66*479ab7f0SSascha Wildner 
67*479ab7f0SSascha Wildner ssize_t
i386_readin(const int fd,vm_offset_t dest,const size_t len)68*479ab7f0SSascha Wildner i386_readin(const int fd, vm_offset_t dest, const size_t len)
69*479ab7f0SSascha Wildner {
70*479ab7f0SSascha Wildner     void	*buf;
71*479ab7f0SSascha Wildner     size_t	resid, chunk, get;
72*479ab7f0SSascha Wildner     ssize_t	got;
73*479ab7f0SSascha Wildner 
74*479ab7f0SSascha Wildner     if (dest + len >= memtop)
75*479ab7f0SSascha Wildner 	return(0);
76*479ab7f0SSascha Wildner 
77*479ab7f0SSascha Wildner     chunk = min(READIN_BUF, len);
78*479ab7f0SSascha Wildner     buf = malloc(chunk);
79*479ab7f0SSascha Wildner     if (buf == NULL)
80*479ab7f0SSascha Wildner 	return(0);
81*479ab7f0SSascha Wildner 
82*479ab7f0SSascha Wildner     for (resid = len; resid > 0; resid -= got, dest += got) {
83*479ab7f0SSascha Wildner 	get = szmin(chunk, resid);
84*479ab7f0SSascha Wildner 	got = read(fd, buf, get);
85*479ab7f0SSascha Wildner 	if (got <= 0)
86*479ab7f0SSascha Wildner 	    break;
87*479ab7f0SSascha Wildner 	bcopy(buf, PTOV(dest), (size_t)got);
88*479ab7f0SSascha Wildner     }
89*479ab7f0SSascha Wildner     free(buf);
90*479ab7f0SSascha Wildner     return(len - resid);
91*479ab7f0SSascha Wildner }
92