af19cc59ca
New version is not compatible on supervisor mode with v1.9.1 (previous version). Highlights: o BBL (Berkeley Boot Loader) provides no initial page tables anymore allowing us to choose VM, to build page tables manually and enable MMU in S-mode. o SBI interface changed. o GENERIC kernel. FDT is now chosen standard for RISC-V hardware description. DTB is now provided by Spike (golden model simulator). This allows us to introduce GENERIC kernel. However, description for console and timer devices is not provided in DTB, so move these devices temporary to nexus bus. o Supervisor can't access userspace by default. Solution is to set SUM (permit Supervisor User Memory access) bit in sstatus register. o Compressed extension is now turned on by default. o External GCC 7.1 compiler used. o _gp renamed to __global_pointer$ o Compiler -march= string is now in use allowing us to choose required extensions (compressed, FPU, atomic, etc). Sponsored by: DARPA, AFRL Differential Revision: https://reviews.freebsd.org/D11800
93 lines
2.9 KiB
C
93 lines
2.9 KiB
C
/* LINTLIBRARY */
|
|
/*-
|
|
* Copyright 1996-1998 John D. Polstra.
|
|
* Copyright (c) 2015-2017 Ruslan Bukin <br@bsdpad.com>
|
|
* All rights reserved.
|
|
*
|
|
* Portions of this software were developed by SRI International and the
|
|
* University of Cambridge Computer Laboratory under DARPA/AFRL contract
|
|
* FA8750-10-C-0237 ("CTSRD"), as part of the DARPA CRASH research programme.
|
|
*
|
|
* Portions of this software were developed by the University of Cambridge
|
|
* Computer Laboratory as part of the CTSRD Project, with support from the
|
|
* UK Higher Education Innovation Fund (HEIF).
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#include <sys/cdefs.h>
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "libc_private.h"
|
|
#include "crtbrand.c"
|
|
#include "ignore_init.c"
|
|
|
|
typedef void (*fptr)(void);
|
|
|
|
#ifdef GCRT
|
|
extern void _mcleanup(void);
|
|
extern void monstartup(void *, void *);
|
|
extern int eprol;
|
|
extern int etext;
|
|
#endif
|
|
|
|
void __start(int argc, char **argv, char **env, void (*cleanup)(void));
|
|
|
|
/* The entry function. */
|
|
__asm(" .text \n"
|
|
" .align 0 \n"
|
|
" .globl _start \n"
|
|
" _start: \n"
|
|
" mv a3, a2 \n" /* cleanup */
|
|
" addi a1, a0, 8 \n" /* get argv */
|
|
" ld a0, 0(a0) \n" /* load argc */
|
|
" slli t0, a0, 3 \n" /* mult by arg size */
|
|
" add a2, a1, t0 \n" /* env is after argv */
|
|
" addi a2, a2, 8 \n" /* argv is null terminated */
|
|
" .option push \n"
|
|
" .option norelax \n"
|
|
" lla gp, __global_pointer$\n"
|
|
" .option pop \n"
|
|
" call __start");
|
|
|
|
void
|
|
__start(int argc, char **argv, char **env, void (*cleanup)(void))
|
|
{
|
|
|
|
handle_argv(argc, argv, env);
|
|
|
|
if (&_DYNAMIC != NULL)
|
|
atexit(cleanup);
|
|
else
|
|
_init_tls();
|
|
|
|
#ifdef GCRT
|
|
atexit(_mcleanup);
|
|
monstartup(&eprol, &etext);
|
|
__asm__("eprol:");
|
|
#endif
|
|
|
|
handle_static_init(argc, argv, env);
|
|
exit(main(argc, argv, env));
|
|
}
|