Home | History | Annotate | Line # | Download | only in libsa
exec_mvme.c revision 1.14.64.1
      1  1.14.64.1    bouyer /*	$NetBSD: exec_mvme.c,v 1.14.64.1 2008/01/19 12:14:35 bouyer Exp $ */
      2        1.1     chuck 
      3        1.1     chuck /*-
      4        1.1     chuck  * Copyright (c) 1982, 1986, 1990, 1993
      5        1.1     chuck  *	The Regents of the University of California.  All rights reserved.
      6        1.1     chuck  *
      7        1.1     chuck  * Redistribution and use in source and binary forms, with or without
      8        1.1     chuck  * modification, are permitted provided that the following conditions
      9        1.1     chuck  * are met:
     10        1.1     chuck  * 1. Redistributions of source code must retain the above copyright
     11        1.1     chuck  *    notice, this list of conditions and the following disclaimer.
     12        1.1     chuck  * 2. Redistributions in binary form must reproduce the above copyright
     13        1.1     chuck  *    notice, this list of conditions and the following disclaimer in the
     14        1.1     chuck  *    documentation and/or other materials provided with the distribution.
     15       1.12       agc  * 3. Neither the name of the University nor the names of its contributors
     16        1.1     chuck  *    may be used to endorse or promote products derived from this software
     17        1.1     chuck  *    without specific prior written permission.
     18        1.1     chuck  *
     19        1.1     chuck  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20        1.1     chuck  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21        1.1     chuck  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22        1.1     chuck  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23        1.1     chuck  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24        1.1     chuck  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25        1.1     chuck  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26        1.1     chuck  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27        1.1     chuck  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28        1.1     chuck  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29        1.1     chuck  * SUCH DAMAGE.
     30        1.1     chuck  *
     31        1.1     chuck  * 	@(#)boot.c	8.1 (Berkeley) 6/10/93
     32        1.1     chuck  */
     33        1.1     chuck 
     34        1.1     chuck #include <sys/param.h>
     35        1.1     chuck #include <sys/reboot.h>
     36        1.1     chuck #include <machine/prom.h>
     37       1.10       scw 
     38       1.10       scw #include "loadfile.h"
     39        1.1     chuck 
     40       1.13  junyoung #include <lib/libsa/stand.h>
     41        1.1     chuck #include "libsa.h"
     42        1.8       scw 
     43       1.10       scw /* These must agree with what locore.s expects */
     44       1.10       scw #define	KERN_LOADADDR	0x0
     45       1.10       scw typedef void (*kentry_t)(int, u_int, u_int, u_int, int, u_long);
     46        1.8       scw 
     47        1.8       scw 
     48        1.1     chuck /*ARGSUSED*/
     49        1.1     chuck void
     50  1.14.64.1    bouyer exec_mvme(char *file, int flag, int part)
     51        1.1     chuck {
     52       1.10       scw 	kentry_t	entry;
     53       1.10       scw 	u_long		marks[MARK_MAX];
     54       1.10       scw 	int		fd;
     55       1.10       scw 	int		lflags;
     56       1.10       scw 
     57       1.10       scw 	lflags = LOAD_KERNEL;
     58       1.11       scw 	if ((flag & RB_NOSYM) != 0 )
     59       1.10       scw 		lflags &= ~LOAD_SYM;
     60        1.1     chuck 
     61       1.10       scw 	marks[MARK_START] = KERN_LOADADDR;
     62       1.10       scw 	if ((fd = loadfile(file, marks, lflags)) == -1)
     63        1.1     chuck 		return;
     64       1.10       scw 	close(fd);
     65       1.11       scw 
     66       1.11       scw 	marks[MARK_END] = (((u_long) marks[MARK_END] + sizeof(int) - 1)) &
     67       1.11       scw 	    (-sizeof(int));
     68       1.10       scw 
     69       1.10       scw 	printf("Start @ 0x%lx [%ld=0x%lx-0x%lx]...\n",
     70       1.10       scw 	    marks[MARK_ENTRY], marks[MARK_NSYM],
     71       1.10       scw 	    marks[MARK_SYM], marks[MARK_END]);
     72       1.10       scw 
     73  1.14.64.1    bouyer 	entry = (kentry_t)marks[MARK_ENTRY];
     74       1.10       scw 
     75       1.10       scw 	(*entry)(flag, bugargs.ctrl_addr, bugargs.ctrl_lun, bugargs.dev_lun,
     76       1.10       scw 	    part, marks[MARK_END]);
     77        1.1     chuck 
     78        1.1     chuck 	printf("exec: kernel returned!\n");
     79        1.1     chuck }
     80