2008-02-23 17:56:17 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 2008 Semihalf, Rafal Jaworowski <raj@semihalf.com>
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* 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 AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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.
|
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is the header file for conveniency wrapper routines (API glue)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _API_GLUE_H_
|
|
|
|
#define _API_GLUE_H_
|
|
|
|
|
2008-09-03 15:39:50 +00:00
|
|
|
#include "api_public.h"
|
|
|
|
|
2016-02-29 07:27:49 +00:00
|
|
|
/*
|
|
|
|
* Mask used to align the start address for API signature search to 1MiB
|
|
|
|
*/
|
|
|
|
#define API_SIG_SEARCH_MASK ~0x000fffff
|
|
|
|
|
|
|
|
#ifdef __mips__
|
|
|
|
/*
|
|
|
|
* On MIPS, U-Boot passes us a hint address, which is very close to the end of
|
|
|
|
* RAM (less than 1MiB), so searching for the API signature within more than
|
|
|
|
* that leads to exception.
|
|
|
|
*/
|
|
|
|
#define API_SIG_SEARCH_LEN 0x00100000
|
|
|
|
#else
|
|
|
|
/*
|
|
|
|
* Search for the API signature within 3MiB of the 1MiB-aligned address that
|
|
|
|
* U-Boot has hinted us.
|
|
|
|
*/
|
|
|
|
#define API_SIG_SEARCH_LEN 0x00300000
|
|
|
|
#endif
|
|
|
|
|
2008-09-03 17:48:41 +00:00
|
|
|
int syscall(int, int *, ...);
|
|
|
|
void *syscall_ptr;
|
2008-02-23 17:56:17 +00:00
|
|
|
|
Improve U-Boot API detection
Until now, ubldr has been trying to locate the U-Boot API using a hint
address (U-Boot's current stack pointer), aligning it to 1MiB and going
over a 3MiB (or 1MiB in case of MIPS) memory region searching for a
valid API signature.
This change introduces an alternative way of doing this, namely the
following:
- both U-Boot's bootelf and go commands actually pass argc and argv to
the entry point (e.g., ubldr's start function, but they should also
be passed over to main() transparently)
- so, instead of trying to go and look for a valid API signature, we
look at the parameters passed to main()
- if there's an option '-a' with argument, which is a valid hexadecimal
unsigned long number (x), we try to verify whether we have a valid
API signature at address x. If so - we use it. If not - we fallback
to the original way of locating the API signature.
The U-Boot change, which causes the API structure address to be
exported as an environment variable, was committed to mainline U-Boot
as commit 22aa61f707574dd569296f521fcfc46a05f51c48
Reviewed by: andrew, adrian
Approved by: adrian (mentor)
Sponsored by: Smartcom - Bulgaria AD
Differential Revision: https://reviews.freebsd.org/D5492
2016-03-09 11:45:48 +00:00
|
|
|
int api_parse_cmdline_sig(int argc, char **argv, struct api_signature **sig);
|
2008-09-03 17:48:41 +00:00
|
|
|
int api_search_sig(struct api_signature **sig);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
2015-03-17 21:15:24 +00:00
|
|
|
#define UB_MAX_MR 16 /* max mem regions number */
|
2008-10-04 13:10:38 +00:00
|
|
|
#define UB_MAX_DEV 6 /* max devices number */
|
|
|
|
|
2008-02-23 17:56:17 +00:00
|
|
|
/*
|
|
|
|
* The ub_ library calls are part of the application, not U-Boot code! They
|
|
|
|
* are front-end wrappers that are used by the consumer application: they
|
|
|
|
* prepare arguments for particular syscall and jump to the low level
|
|
|
|
* syscall()
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* console */
|
2008-09-03 17:48:41 +00:00
|
|
|
int ub_getc(void);
|
|
|
|
int ub_tstc(void);
|
2008-10-04 13:19:15 +00:00
|
|
|
void ub_putc(char);
|
|
|
|
void ub_puts(const char *);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
|
|
|
/* system */
|
2018-01-26 21:50:59 +00:00
|
|
|
void ub_reset(void) __dead2;
|
2008-09-03 15:39:50 +00:00
|
|
|
struct sys_info *ub_get_sys_info(void);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
|
|
|
/* time */
|
2008-09-03 17:48:41 +00:00
|
|
|
void ub_udelay(unsigned long);
|
|
|
|
unsigned long ub_get_timer(unsigned long);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
|
|
|
/* env vars */
|
2008-10-04 13:19:15 +00:00
|
|
|
char *ub_env_get(const char *);
|
|
|
|
void ub_env_set(const char *, char *);
|
|
|
|
const char *ub_env_enum(const char *);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
|
|
|
/* devices */
|
2008-09-03 17:48:41 +00:00
|
|
|
int ub_dev_enum(void);
|
2008-10-04 13:19:15 +00:00
|
|
|
int ub_dev_open(int);
|
|
|
|
int ub_dev_close(int);
|
|
|
|
int ub_dev_read(int, void *, lbasize_t, lbastart_t, lbasize_t *);
|
|
|
|
int ub_dev_send(int, void *, int);
|
|
|
|
int ub_dev_recv(int, void *, int, int *);
|
|
|
|
struct device_info *ub_dev_get(int);
|
2008-02-23 17:56:17 +00:00
|
|
|
|
2008-09-03 17:48:41 +00:00
|
|
|
void ub_dump_di(int);
|
|
|
|
void ub_dump_si(struct sys_info *);
|
|
|
|
char *ub_mem_type(int);
|
2008-11-19 17:34:28 +00:00
|
|
|
char *ub_stor_type(int);
|
2008-09-03 17:48:41 +00:00
|
|
|
|
2008-02-23 17:56:17 +00:00
|
|
|
#endif /* _API_GLUE_H_ */
|