Home | History | Annotate | Line # | Download | only in hpcboot
      1  1.6  martin /*	$NetBSD: load_coff.cpp,v 1.6 2008/04/28 20:23:20 martin Exp $	*/
      2  1.1     uch 
      3  1.1     uch /*-
      4  1.1     uch  * Copyright (c) 2001 The NetBSD Foundation, Inc.
      5  1.1     uch  * All rights reserved.
      6  1.1     uch  *
      7  1.1     uch  * This code is derived from software contributed to The NetBSD Foundation
      8  1.1     uch  * by UCHIYAMA Yasushi.
      9  1.1     uch  *
     10  1.1     uch  * Redistribution and use in source and binary forms, with or without
     11  1.1     uch  * modification, are permitted provided that the following conditions
     12  1.1     uch  * are met:
     13  1.1     uch  * 1. Redistributions of source code must retain the above copyright
     14  1.1     uch  *    notice, this list of conditions and the following disclaimer.
     15  1.1     uch  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.1     uch  *    notice, this list of conditions and the following disclaimer in the
     17  1.1     uch  *    documentation and/or other materials provided with the distribution.
     18  1.1     uch  *
     19  1.1     uch  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20  1.1     uch  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21  1.1     uch  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22  1.1     uch  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23  1.1     uch  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24  1.1     uch  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25  1.1     uch  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26  1.1     uch  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27  1.1     uch  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28  1.1     uch  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29  1.1     uch  * POSSIBILITY OF SUCH DAMAGE.
     30  1.1     uch  */
     31  1.1     uch 
     32  1.1     uch #include <load.h>
     33  1.1     uch #include <load_coff.h>
     34  1.1     uch #undef DPRINTF // trash coff_machdep.h 's define.
     35  1.1     uch #include <console.h>
     36  1.1     uch #include <memory.h>
     37  1.1     uch #include <file.h>
     38  1.1     uch 
     39  1.1     uch CoffLoader::CoffLoader(Console *&cons, MemoryManager *&mem)
     40  1.1     uch 	: Loader(cons, mem)
     41  1.1     uch {
     42  1.1     uch 	memset(&_eh, 0, sizeof(struct coff_exechdr));
     43  1.1     uch 	_fh = &_eh.f;
     44  1.1     uch 	_ah = &_eh.a;
     45  1.1     uch 
     46  1.1     uch 	DPRINTF((TEXT("Loader: COFF\n")));
     47  1.1     uch }
     48  1.1     uch 
     49  1.1     uch CoffLoader::~CoffLoader(void)
     50  1.1     uch {
     51  1.1     uch }
     52  1.1     uch 
     53  1.1     uch BOOL
     54  1.1     uch CoffLoader::setFile(File *&file)
     55  1.1     uch {
     56  1.1     uch 	Loader::setFile(file);
     57  1.1     uch 
     58  1.1     uch 	/* read COFF header and check it */
     59  1.1     uch 	return read_header();
     60  1.1     uch }
     61  1.1     uch 
     62  1.1     uch size_t
     63  1.1     uch CoffLoader::memorySize()
     64  1.1     uch {
     65  1.1     uch 	size_t sz = _ah->a_tsize + _ah->a_dsize;
     66  1.1     uch 
     67  1.1     uch 	DPRINTF((TEXT("file size: text 0x%x + data 0x%x = 0x%x byte\n"),
     68  1.2     uch 	    _ah->a_tsize, _ah->a_dsize, sz));
     69  1.1     uch 	return sz;
     70  1.1     uch }
     71  1.1     uch 
     72  1.1     uch kaddr_t
     73  1.1     uch CoffLoader::jumpAddr()
     74  1.1     uch {
     75  1.3     uch 
     76  1.1     uch 	DPRINTF((TEXT("kernel entry address: 0x%08x\n"), _ah->a_entry));
     77  1.3     uch 
     78  1.1     uch 	return _ah->a_entry;
     79  1.1     uch }
     80  1.1     uch 
     81  1.1     uch BOOL
     82  1.1     uch CoffLoader::load()
     83  1.1     uch {
     84  1.1     uch 	size_t filesz;
     85  1.1     uch 	size_t memsz;
     86  1.1     uch 	vaddr_t kv;
     87  1.1     uch 	off_t fileofs;
     88  1.4     uch 
     89  1.1     uch 	/* start tag chain */
     90  1.1     uch 	_load_segment_start();
     91  1.1     uch 
     92  1.1     uch 	/* text */
     93  1.1     uch 	filesz = memsz = _ah->a_tsize;
     94  1.1     uch 	kv = _ah->a_tstart;
     95  1.1     uch 	fileofs = COFF_ROUND(N_TXTOFF(_fh, _ah), 16);
     96  1.1     uch 	DPRINTF((TEXT("[text]")));
     97  1.1     uch 	_load_segment(kv, memsz, fileofs, filesz);
     98  1.1     uch 	/* data */
     99  1.1     uch 	fileofs += filesz;
    100  1.1     uch 	filesz = memsz = _ah->a_dsize;
    101  1.1     uch 	kv = _ah->a_dstart;
    102  1.1     uch 	DPRINTF((TEXT("[data]")));
    103  1.1     uch 	_load_segment(kv, memsz, fileofs, filesz);
    104  1.1     uch 	/* bss */
    105  1.1     uch 	filesz = 0;
    106  1.1     uch 	memsz = _ah->a_bsize;
    107  1.1     uch 	kv = _ah->a_dstart + _ah->a_dsize;
    108  1.1     uch 	fileofs = 0;
    109  1.1     uch 	DPRINTF((TEXT("[bss ]")));
    110  1.1     uch 	_load_segment(kv, memsz, fileofs, filesz);
    111  1.1     uch 
    112  1.1     uch 	/* tag chain still opening */
    113  1.3     uch 	return _load_success();
    114  1.1     uch }
    115  1.1     uch 
    116  1.1     uch BOOL
    117  1.1     uch CoffLoader::read_header(void)
    118  1.1     uch {
    119  1.1     uch #ifndef COFF_BADMAG
    120  1.1     uch 	DPRINTF((TEXT("coff loader not implemented.\n")));
    121  1.1     uch 	return FALSE;
    122  1.1     uch #else
    123  1.1     uch 	// read COFF header
    124  1.1     uch 	_file->read(&_eh, sizeof(struct coff_exechdr), 0);
    125  1.1     uch 
    126  1.1     uch 	// check COFF Magic.
    127  1.1     uch 	if (COFF_BADMAG(_fh)) {
    128  1.1     uch 		DPRINTF((TEXT("not a COFF file.\n")));
    129  1.1     uch 		return FALSE;
    130  1.1     uch 	}
    131  1.1     uch 
    132  1.1     uch 	return TRUE;
    133  1.1     uch #endif
    134  1.1     uch }
    135