Home | History | Annotate | Line # | Download | only in lib
startprog.S revision 1.1.1.1
      1 /*	$NetBSD: startprog.S,v 1.1.1.1 1997/03/14 02:40:33 perry Exp $	*/
      2 
      3 /* starts program in protected mode / flat space
      4  with given stackframe
      5  needs global variables flatcodeseg and flatdataseg
      6  (gdt offsets)
      7   derivied from: NetBSD:sys/arch/i386/boot/asm.S
      8  */
      9 
     10 /*
     11  * Ported to boot 386BSD by Julian Elischer (julian (at) tfs.com) Sept 1992
     12  *
     13  * Mach Operating System
     14  * Copyright (c) 1992, 1991 Carnegie Mellon University
     15  * All Rights Reserved.
     16  *
     17  * Permission to use, copy, modify and distribute this software and its
     18  * documentation is hereby granted, provided that both the copyright
     19  * notice and this permission notice appear in all copies of the
     20  * software, derivative works or modified versions, and any portions
     21  * thereof, and that both notices appear in supporting documentation.
     22  *
     23  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     24  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
     25  * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     26  *
     27  * Carnegie Mellon requests users of this software to return to
     28  *
     29  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     30  *  School of Computer Science
     31  *  Carnegie Mellon University
     32  *  Pittsburgh PA 15213-3890
     33  *
     34  * any improvements or extensions that they make and grant Carnegie Mellon
     35  * the rights to redistribute these changes.
     36  */
     37 
     38 /*
     39   Copyright 1988, 1989, 1990, 1991, 1992
     40    by Intel Corporation, Santa Clara, California.
     41 
     42                 All Rights Reserved
     43 
     44 Permission to use, copy, modify, and distribute this software and
     45 its documentation for any purpose and without fee is hereby
     46 granted, provided that the above copyright notice appears in all
     47 copies and that both the copyright notice and this permission notice
     48 appear in supporting documentation, and that the name of Intel
     49 not be used in advertising or publicity pertaining to distribution
     50 of the software without specific, written prior permission.
     51 
     52 INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
     53 INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS,
     54 IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
     55 CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
     56 LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
     57 NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
     58 WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     59 */
     60 
     61 #include <machine/asm.h>
     62 
     63 /*
     64  * startprog(phyaddr,argc,argv,stack)
     65  *	start the program on protected mode where phyaddr is the entry point
     66  */
     67 ENTRY(startprog)
     68 	pushl	%ebp
     69 	movl	%esp, %ebp
     70 
     71 	# prepare a new stack
     72 	movl	$flatdataseg, %ebx
     73 	movw	%bx, %es		# for arg copy
     74 	movl	20(%ebp), %eax	# stack
     75 	subl	$4,%eax
     76 	movl	%eax, %edi
     77 
     78 	# push some number of args onto the stack
     79 	movl	12(%ebp), %ecx		# argc
     80 
     81 	movl	%ecx, %eax
     82 	decl	%eax
     83 	shl	$2, %eax
     84 	addl	16(%ebp), %eax	# ptr to last arg
     85 	movl	%eax, %esi
     86 
     87 	std			# backwards
     88 	rep
     89 	movsl
     90 
     91 	cld		# LynxOS depends on it
     92 
     93 	movl	8(%ebp), %ecx	# entry
     94 
     95 	# set new stackptr (movsl decd sp 1 more -> dummy return address)
     96 	movw	%bx, %ss
     97 	movl	%edi, %esp
     98 
     99 	# push on our entry address
    100 	movl	$flatcodeseg, %ebx		# segment
    101 	pushl	%ebx
    102 	pushl	%ecx			#entry
    103 
    104 	# convert over the other data segs
    105 	movl	$flatdataseg, %ebx
    106 	movl	%bx, %ds
    107 	movl	%bx, %es
    108 
    109 	# convert the PC (and code seg)
    110 	lret
    111