avionic design with actual uboot and tooling
submodule of avionic design uboot bootloader and with included tools to get you started , read readme.md and readme-tk1-loader.md
This commit is contained in:
26
u-boot/arch/sandbox/Kconfig
Normal file
26
u-boot/arch/sandbox/Kconfig
Normal file
@@ -0,0 +1,26 @@
|
||||
menu "Sandbox architecture"
|
||||
depends on SANDBOX
|
||||
|
||||
config SYS_ARCH
|
||||
default "sandbox"
|
||||
|
||||
config SYS_BOARD
|
||||
default "sandbox"
|
||||
|
||||
config SYS_CPU
|
||||
default "sandbox"
|
||||
|
||||
config SYS_CONFIG_NAME
|
||||
default "sandbox"
|
||||
|
||||
config PCI
|
||||
bool "PCI support"
|
||||
help
|
||||
Enable support for PCI (Peripheral Interconnect Bus), a type of bus
|
||||
used on some devices to allow the CPU to communicate with its
|
||||
peripherals.
|
||||
|
||||
config DM_KEYBOARD
|
||||
default y
|
||||
|
||||
endmenu
|
||||
8
u-boot/arch/sandbox/Makefile
Normal file
8
u-boot/arch/sandbox/Makefile
Normal file
@@ -0,0 +1,8 @@
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
head-y := arch/sandbox/cpu/start.o
|
||||
|
||||
libs-y += arch/sandbox/cpu/
|
||||
libs-y += arch/sandbox/lib/
|
||||
23
u-boot/arch/sandbox/config.mk
Normal file
23
u-boot/arch/sandbox/config.mk
Normal file
@@ -0,0 +1,23 @@
|
||||
# Copyright (c) 2011 The Chromium OS Authors.
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
|
||||
PLATFORM_CPPFLAGS += -D__SANDBOX__ -U_FORTIFY_SOURCE
|
||||
PLATFORM_CPPFLAGS += -DCONFIG_ARCH_MAP_SYSMEM
|
||||
PLATFORM_LIBS += -lrt
|
||||
|
||||
# Define this to avoid linking with SDL, which requires SDL libraries
|
||||
# This can solve 'sdl-config: Command not found' errors
|
||||
ifneq ($(NO_SDL),)
|
||||
PLATFORM_CPPFLAGS += -DSANDBOX_NO_SDL
|
||||
else
|
||||
ifdef CONFIG_SANDBOX_SDL
|
||||
PLATFORM_LIBS += $(shell sdl-config --libs)
|
||||
PLATFORM_CPPFLAGS += $(shell sdl-config --cflags)
|
||||
endif
|
||||
endif
|
||||
|
||||
cmd_u-boot__ = $(CC) -o $@ -Wl,-T u-boot.lds \
|
||||
-Wl,--start-group $(u-boot-main) -Wl,--end-group \
|
||||
$(PLATFORM_LIBS) -Wl,-Map -Wl,u-boot.map
|
||||
|
||||
CONFIG_ARCH_DEVICE_TREE := sandbox
|
||||
32
u-boot/arch/sandbox/cpu/Makefile
Normal file
32
u-boot/arch/sandbox/cpu/Makefile
Normal file
@@ -0,0 +1,32 @@
|
||||
#
|
||||
# Copyright (c) 2011 The Chromium OS Authors.
|
||||
#
|
||||
# (C) Copyright 2000-2003
|
||||
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
obj-y := cpu.o os.o start.o state.o
|
||||
obj-$(CONFIG_ETH_SANDBOX_RAW) += eth-raw-os.o
|
||||
obj-$(CONFIG_SANDBOX_SDL) += sdl.o
|
||||
|
||||
# os.c is build in the system environment, so needs standard includes
|
||||
# CFLAGS_REMOVE_os.o cannot be used to drop header include path
|
||||
quiet_cmd_cc_os.o = CC $(quiet_modtag) $@
|
||||
cmd_cc_os.o = $(CC) $(filter-out -nostdinc, \
|
||||
$(patsubst -I%,-idirafter%,$(c_flags))) -c -o $@ $<
|
||||
|
||||
$(obj)/os.o: $(src)/os.c FORCE
|
||||
$(call if_changed_dep,cc_os.o)
|
||||
$(obj)/sdl.o: $(src)/sdl.c FORCE
|
||||
$(call if_changed_dep,cc_os.o)
|
||||
|
||||
# eth-raw-os.c is built in the system env, so needs standard includes
|
||||
# CFLAGS_REMOVE_eth-raw-os.o cannot be used to drop header include path
|
||||
quiet_cmd_cc_eth-raw-os.o = CC $(quiet_modtag) $@
|
||||
cmd_cc_eth-raw-os.o = $(CC) $(filter-out -nostdinc, \
|
||||
$(patsubst -I%,-idirafter%,$(c_flags))) -c -o $@ $<
|
||||
|
||||
$(obj)/eth-raw-os.o: $(src)/eth-raw-os.c FORCE
|
||||
$(call if_changed_dep,cc_eth-raw-os.o)
|
||||
138
u-boot/arch/sandbox/cpu/cpu.c
Normal file
138
u-boot/arch/sandbox/cpu/cpu.c
Normal file
@@ -0,0 +1,138 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
#define DEBUG
|
||||
#include <common.h>
|
||||
#include <dm/root.h>
|
||||
#include <os.h>
|
||||
#include <asm/io.h>
|
||||
#include <asm/state.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
/* Enable access to PCI memory with map_sysmem() */
|
||||
static bool enable_pci_map;
|
||||
|
||||
#ifdef CONFIG_PCI
|
||||
/* Last device that was mapped into memory, and length of mapping */
|
||||
static struct udevice *map_dev;
|
||||
unsigned long map_len;
|
||||
#endif
|
||||
|
||||
void sandbox_exit(void)
|
||||
{
|
||||
/* Do this here while it still has an effect */
|
||||
os_fd_restore();
|
||||
if (state_uninit())
|
||||
os_exit(2);
|
||||
|
||||
if (dm_uninit())
|
||||
os_exit(2);
|
||||
|
||||
/* This is considered normal termination for now */
|
||||
os_exit(0);
|
||||
}
|
||||
|
||||
/* delay x useconds */
|
||||
void __udelay(unsigned long usec)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
|
||||
if (!state->skip_delays)
|
||||
os_usleep(usec);
|
||||
}
|
||||
|
||||
int cleanup_before_linux(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cleanup_before_linux_select(int flags)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void *map_physmem(phys_addr_t paddr, unsigned long len, unsigned long flags)
|
||||
{
|
||||
#ifdef CONFIG_PCI
|
||||
unsigned long plen = len;
|
||||
void *ptr;
|
||||
|
||||
map_dev = NULL;
|
||||
if (enable_pci_map && !pci_map_physmem(paddr, &len, &map_dev, &ptr)) {
|
||||
if (plen != len) {
|
||||
printf("%s: Warning: partial map at %x, wanted %lx, got %lx\n",
|
||||
__func__, paddr, len, plen);
|
||||
}
|
||||
map_len = len;
|
||||
return ptr;
|
||||
}
|
||||
#endif
|
||||
|
||||
return (void *)(gd->arch.ram_buf + paddr);
|
||||
}
|
||||
|
||||
void unmap_physmem(const void *vaddr, unsigned long flags)
|
||||
{
|
||||
#ifdef CONFIG_PCI
|
||||
if (map_dev) {
|
||||
pci_unmap_physmem(vaddr, map_len, map_dev);
|
||||
map_dev = NULL;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void sandbox_set_enable_pci_map(int enable)
|
||||
{
|
||||
enable_pci_map = enable;
|
||||
}
|
||||
|
||||
phys_addr_t map_to_sysmem(const void *ptr)
|
||||
{
|
||||
return (u8 *)ptr - gd->arch.ram_buf;
|
||||
}
|
||||
|
||||
void flush_dcache_range(unsigned long start, unsigned long stop)
|
||||
{
|
||||
}
|
||||
|
||||
int sandbox_read_fdt_from_file(void)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
const char *fname = state->fdt_fname;
|
||||
void *blob;
|
||||
loff_t size;
|
||||
int err;
|
||||
int fd;
|
||||
|
||||
blob = map_sysmem(CONFIG_SYS_FDT_LOAD_ADDR, 0);
|
||||
if (!state->fdt_fname) {
|
||||
err = fdt_create_empty_tree(blob, 256);
|
||||
if (!err)
|
||||
goto done;
|
||||
printf("Unable to create empty FDT: %s\n", fdt_strerror(err));
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
err = os_get_filesize(fname, &size);
|
||||
if (err < 0) {
|
||||
printf("Failed to file FDT file '%s'\n", fname);
|
||||
return err;
|
||||
}
|
||||
fd = os_open(fname, OS_O_RDONLY);
|
||||
if (fd < 0) {
|
||||
printf("Failed to open FDT file '%s'\n", fname);
|
||||
return -EACCES;
|
||||
}
|
||||
if (os_read(fd, blob, size) != size) {
|
||||
os_close(fd);
|
||||
return -EIO;
|
||||
}
|
||||
os_close(fd);
|
||||
|
||||
done:
|
||||
gd->fdt_blob = blob;
|
||||
|
||||
return 0;
|
||||
}
|
||||
254
u-boot/arch/sandbox/cpu/eth-raw-os.c
Normal file
254
u-boot/arch/sandbox/cpu/eth-raw-os.c
Normal file
@@ -0,0 +1,254 @@
|
||||
/*
|
||||
* Copyright (c) 2015 National Instruments
|
||||
*
|
||||
* (C) Copyright 2015
|
||||
* Joe Hershberger <joe.hershberger@ni.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#include <asm/eth-raw-os.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <net/if.h>
|
||||
#include <netinet/in.h>
|
||||
#include <netinet/ip.h>
|
||||
#include <netinet/udp.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <sys/socket.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <linux/if_ether.h>
|
||||
#include <linux/if_packet.h>
|
||||
|
||||
static int _raw_packet_start(const char *ifname, unsigned char *ethmac,
|
||||
struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
struct sockaddr_ll *device;
|
||||
struct packet_mreq mr;
|
||||
int ret;
|
||||
int flags;
|
||||
|
||||
/* Prepare device struct */
|
||||
priv->device = malloc(sizeof(struct sockaddr_ll));
|
||||
if (priv->device == NULL)
|
||||
return -ENOMEM;
|
||||
device = priv->device;
|
||||
memset(device, 0, sizeof(struct sockaddr_ll));
|
||||
device->sll_ifindex = if_nametoindex(ifname);
|
||||
device->sll_family = AF_PACKET;
|
||||
memcpy(device->sll_addr, ethmac, 6);
|
||||
device->sll_halen = htons(6);
|
||||
|
||||
/* Open socket */
|
||||
priv->sd = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
|
||||
if (priv->sd < 0) {
|
||||
printf("Failed to open socket: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
/* Bind to the specified interface */
|
||||
ret = setsockopt(priv->sd, SOL_SOCKET, SO_BINDTODEVICE, ifname,
|
||||
strlen(ifname) + 1);
|
||||
if (ret < 0) {
|
||||
printf("Failed to bind to '%s': %d %s\n", ifname, errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
|
||||
/* Make the socket non-blocking */
|
||||
flags = fcntl(priv->sd, F_GETFL, 0);
|
||||
fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
|
||||
|
||||
/* Enable promiscuous mode to receive responses meant for us */
|
||||
mr.mr_ifindex = device->sll_ifindex;
|
||||
mr.mr_type = PACKET_MR_PROMISC;
|
||||
ret = setsockopt(priv->sd, SOL_PACKET, PACKET_ADD_MEMBERSHIP,
|
||||
&mr, sizeof(mr));
|
||||
if (ret < 0) {
|
||||
struct ifreq ifr;
|
||||
|
||||
printf("Failed to set promiscuous mode: %d %s\n"
|
||||
"Falling back to the old \"flags\" way...\n",
|
||||
errno, strerror(errno));
|
||||
if (strlen(ifname) >= IFNAMSIZ) {
|
||||
printf("Interface name %s is too long.\n", ifname);
|
||||
return -EINVAL;
|
||||
}
|
||||
strncpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
||||
if (ioctl(priv->sd, SIOCGIFFLAGS, &ifr) < 0) {
|
||||
printf("Failed to read flags: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
ifr.ifr_flags |= IFF_PROMISC;
|
||||
if (ioctl(priv->sd, SIOCSIFFLAGS, &ifr) < 0) {
|
||||
printf("Failed to write flags: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int _local_inet_start(struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
struct sockaddr_in *device;
|
||||
int ret;
|
||||
int flags;
|
||||
int one = 1;
|
||||
|
||||
/* Prepare device struct */
|
||||
priv->device = malloc(sizeof(struct sockaddr_in));
|
||||
if (priv->device == NULL)
|
||||
return -ENOMEM;
|
||||
device = priv->device;
|
||||
memset(device, 0, sizeof(struct sockaddr_in));
|
||||
device->sin_family = AF_INET;
|
||||
device->sin_addr.s_addr = htonl(INADDR_LOOPBACK);
|
||||
|
||||
/**
|
||||
* Open socket
|
||||
* Since we specify UDP here, any incoming ICMP packets will
|
||||
* not be received, so things like ping will not work on this
|
||||
* localhost interface.
|
||||
*/
|
||||
priv->sd = socket(AF_INET, SOCK_RAW, IPPROTO_UDP);
|
||||
if (priv->sd < 0) {
|
||||
printf("Failed to open socket: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
|
||||
/* Make the socket non-blocking */
|
||||
flags = fcntl(priv->sd, F_GETFL, 0);
|
||||
fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
|
||||
|
||||
/* Include the UDP/IP headers on send and receive */
|
||||
ret = setsockopt(priv->sd, IPPROTO_IP, IP_HDRINCL, &one,
|
||||
sizeof(one));
|
||||
if (ret < 0) {
|
||||
printf("Failed to set header include option: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
priv->local_bind_sd = -1;
|
||||
priv->local_bind_udp_port = 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_eth_raw_os_start(const char *ifname, unsigned char *ethmac,
|
||||
struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
if (priv->local)
|
||||
return _local_inet_start(priv);
|
||||
else
|
||||
return _raw_packet_start(ifname, ethmac, priv);
|
||||
}
|
||||
|
||||
int sandbox_eth_raw_os_send(void *packet, int length,
|
||||
struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
int retval;
|
||||
struct udphdr *udph = packet + sizeof(struct iphdr);
|
||||
|
||||
if (!priv->sd || !priv->device)
|
||||
return -EINVAL;
|
||||
|
||||
/*
|
||||
* This block of code came about when testing tftp on the localhost
|
||||
* interface. When using the RAW AF_INET API, the network stack is still
|
||||
* in play responding to incoming traffic based on open "ports". Since
|
||||
* it is raw (at the IP layer, no Ethernet) the network stack tells the
|
||||
* TFTP server that the port it responded to is closed. This causes the
|
||||
* TFTP transfer to be aborted. This block of code inspects the outgoing
|
||||
* packet as formulated by the u-boot network stack to determine the
|
||||
* source port (that the TFTP server will send packets back to) and
|
||||
* opens a typical UDP socket on that port, thus preventing the network
|
||||
* stack from sending that ICMP message claiming that the port has no
|
||||
* bound socket.
|
||||
*/
|
||||
if (priv->local && (priv->local_bind_sd == -1 ||
|
||||
priv->local_bind_udp_port != udph->source)) {
|
||||
struct iphdr *iph = packet;
|
||||
struct sockaddr_in addr;
|
||||
|
||||
if (priv->local_bind_sd != -1)
|
||||
close(priv->local_bind_sd);
|
||||
|
||||
/* A normal UDP socket is required to bind */
|
||||
priv->local_bind_sd = socket(AF_INET, SOCK_DGRAM, 0);
|
||||
if (priv->local_bind_sd < 0) {
|
||||
printf("Failed to open bind sd: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
priv->local_bind_udp_port = udph->source;
|
||||
|
||||
/**
|
||||
* Bind the UDP port that we intend to use as our source port
|
||||
* so that the kernel will not send an ICMP port unreachable
|
||||
* message to the server
|
||||
*/
|
||||
addr.sin_family = AF_INET;
|
||||
addr.sin_port = udph->source;
|
||||
addr.sin_addr.s_addr = iph->saddr;
|
||||
retval = bind(priv->local_bind_sd, (struct sockaddr *)&addr,
|
||||
sizeof(addr));
|
||||
if (retval < 0)
|
||||
printf("Failed to bind: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
}
|
||||
|
||||
retval = sendto(priv->sd, packet, length, 0,
|
||||
(struct sockaddr *)priv->device,
|
||||
sizeof(struct sockaddr_ll));
|
||||
if (retval < 0) {
|
||||
printf("Failed to send packet: %d %s\n", errno,
|
||||
strerror(errno));
|
||||
return -errno;
|
||||
}
|
||||
return retval;
|
||||
}
|
||||
|
||||
int sandbox_eth_raw_os_recv(void *packet, int *length,
|
||||
const struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
int retval;
|
||||
int saddr_size;
|
||||
|
||||
if (!priv->sd || !priv->device)
|
||||
return -EINVAL;
|
||||
saddr_size = sizeof(struct sockaddr);
|
||||
retval = recvfrom(priv->sd, packet, 1536, 0,
|
||||
(struct sockaddr *)priv->device,
|
||||
(socklen_t *)&saddr_size);
|
||||
*length = 0;
|
||||
if (retval >= 0) {
|
||||
*length = retval;
|
||||
return 0;
|
||||
}
|
||||
/* The socket is non-blocking, so expect EAGAIN when there is no data */
|
||||
if (errno == EAGAIN)
|
||||
return 0;
|
||||
return -errno;
|
||||
}
|
||||
|
||||
void sandbox_eth_raw_os_stop(struct eth_sandbox_raw_priv *priv)
|
||||
{
|
||||
free(priv->device);
|
||||
priv->device = NULL;
|
||||
close(priv->sd);
|
||||
priv->sd = -1;
|
||||
if (priv->local) {
|
||||
if (priv->local_bind_sd != -1)
|
||||
close(priv->local_bind_sd);
|
||||
priv->local_bind_sd = -1;
|
||||
priv->local_bind_udp_port = 0;
|
||||
}
|
||||
}
|
||||
559
u-boot/arch/sandbox/cpu/os.c
Normal file
559
u-boot/arch/sandbox/cpu/os.c
Normal file
@@ -0,0 +1,559 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <dirent.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <getopt.h>
|
||||
#include <stdio.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <termios.h>
|
||||
#include <time.h>
|
||||
#include <unistd.h>
|
||||
#include <sys/mman.h>
|
||||
#include <sys/stat.h>
|
||||
#include <sys/time.h>
|
||||
#include <sys/types.h>
|
||||
#include <linux/types.h>
|
||||
|
||||
#include <asm/getopt.h>
|
||||
#include <asm/sections.h>
|
||||
#include <asm/state.h>
|
||||
#include <os.h>
|
||||
#include <rtc_def.h>
|
||||
|
||||
/* Operating System Interface */
|
||||
|
||||
struct os_mem_hdr {
|
||||
size_t length; /* number of bytes in the block */
|
||||
};
|
||||
|
||||
ssize_t os_read(int fd, void *buf, size_t count)
|
||||
{
|
||||
return read(fd, buf, count);
|
||||
}
|
||||
|
||||
ssize_t os_read_no_block(int fd, void *buf, size_t count)
|
||||
{
|
||||
const int flags = fcntl(fd, F_GETFL, 0);
|
||||
|
||||
fcntl(fd, F_SETFL, flags | O_NONBLOCK);
|
||||
return os_read(fd, buf, count);
|
||||
}
|
||||
|
||||
ssize_t os_write(int fd, const void *buf, size_t count)
|
||||
{
|
||||
return write(fd, buf, count);
|
||||
}
|
||||
|
||||
off_t os_lseek(int fd, off_t offset, int whence)
|
||||
{
|
||||
if (whence == OS_SEEK_SET)
|
||||
whence = SEEK_SET;
|
||||
else if (whence == OS_SEEK_CUR)
|
||||
whence = SEEK_CUR;
|
||||
else if (whence == OS_SEEK_END)
|
||||
whence = SEEK_END;
|
||||
else
|
||||
os_exit(1);
|
||||
return lseek(fd, offset, whence);
|
||||
}
|
||||
|
||||
int os_open(const char *pathname, int os_flags)
|
||||
{
|
||||
int flags;
|
||||
|
||||
switch (os_flags & OS_O_MASK) {
|
||||
case OS_O_RDONLY:
|
||||
default:
|
||||
flags = O_RDONLY;
|
||||
break;
|
||||
|
||||
case OS_O_WRONLY:
|
||||
flags = O_WRONLY;
|
||||
break;
|
||||
|
||||
case OS_O_RDWR:
|
||||
flags = O_RDWR;
|
||||
break;
|
||||
}
|
||||
|
||||
if (os_flags & OS_O_CREAT)
|
||||
flags |= O_CREAT;
|
||||
|
||||
return open(pathname, flags, 0777);
|
||||
}
|
||||
|
||||
int os_close(int fd)
|
||||
{
|
||||
return close(fd);
|
||||
}
|
||||
|
||||
int os_unlink(const char *pathname)
|
||||
{
|
||||
return unlink(pathname);
|
||||
}
|
||||
|
||||
void os_exit(int exit_code)
|
||||
{
|
||||
exit(exit_code);
|
||||
}
|
||||
|
||||
/* Restore tty state when we exit */
|
||||
static struct termios orig_term;
|
||||
static bool term_setup;
|
||||
|
||||
void os_fd_restore(void)
|
||||
{
|
||||
if (term_setup) {
|
||||
tcsetattr(0, TCSANOW, &orig_term);
|
||||
term_setup = false;
|
||||
}
|
||||
}
|
||||
|
||||
/* Put tty into raw mode so <tab> and <ctrl+c> work */
|
||||
void os_tty_raw(int fd, bool allow_sigs)
|
||||
{
|
||||
struct termios term;
|
||||
|
||||
if (term_setup)
|
||||
return;
|
||||
|
||||
/* If not a tty, don't complain */
|
||||
if (tcgetattr(fd, &orig_term))
|
||||
return;
|
||||
|
||||
term = orig_term;
|
||||
term.c_iflag = IGNBRK | IGNPAR;
|
||||
term.c_oflag = OPOST | ONLCR;
|
||||
term.c_cflag = CS8 | CREAD | CLOCAL;
|
||||
term.c_lflag = allow_sigs ? ISIG : 0;
|
||||
if (tcsetattr(fd, TCSANOW, &term))
|
||||
return;
|
||||
|
||||
term_setup = true;
|
||||
atexit(os_fd_restore);
|
||||
}
|
||||
|
||||
void *os_malloc(size_t length)
|
||||
{
|
||||
struct os_mem_hdr *hdr;
|
||||
|
||||
hdr = mmap(NULL, length + sizeof(*hdr), PROT_READ | PROT_WRITE,
|
||||
MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
|
||||
if (hdr == MAP_FAILED)
|
||||
return NULL;
|
||||
hdr->length = length;
|
||||
|
||||
return hdr + 1;
|
||||
}
|
||||
|
||||
void os_free(void *ptr)
|
||||
{
|
||||
struct os_mem_hdr *hdr = ptr;
|
||||
|
||||
hdr--;
|
||||
if (ptr)
|
||||
munmap(hdr, hdr->length + sizeof(*hdr));
|
||||
}
|
||||
|
||||
void *os_realloc(void *ptr, size_t length)
|
||||
{
|
||||
struct os_mem_hdr *hdr = ptr;
|
||||
void *buf = NULL;
|
||||
|
||||
hdr--;
|
||||
if (length != 0) {
|
||||
buf = os_malloc(length);
|
||||
if (!buf)
|
||||
return buf;
|
||||
if (ptr) {
|
||||
if (length > hdr->length)
|
||||
length = hdr->length;
|
||||
memcpy(buf, ptr, length);
|
||||
}
|
||||
}
|
||||
os_free(ptr);
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
||||
void os_usleep(unsigned long usec)
|
||||
{
|
||||
usleep(usec);
|
||||
}
|
||||
|
||||
uint64_t __attribute__((no_instrument_function)) os_get_nsec(void)
|
||||
{
|
||||
#if defined(CLOCK_MONOTONIC) && defined(_POSIX_MONOTONIC_CLOCK)
|
||||
struct timespec tp;
|
||||
if (EINVAL == clock_gettime(CLOCK_MONOTONIC, &tp)) {
|
||||
struct timeval tv;
|
||||
|
||||
gettimeofday(&tv, NULL);
|
||||
tp.tv_sec = tv.tv_sec;
|
||||
tp.tv_nsec = tv.tv_usec * 1000;
|
||||
}
|
||||
return tp.tv_sec * 1000000000ULL + tp.tv_nsec;
|
||||
#else
|
||||
struct timeval tv;
|
||||
gettimeofday(&tv, NULL);
|
||||
return tv.tv_sec * 1000000000ULL + tv.tv_usec * 1000;
|
||||
#endif
|
||||
}
|
||||
|
||||
static char *short_opts;
|
||||
static struct option *long_opts;
|
||||
|
||||
int os_parse_args(struct sandbox_state *state, int argc, char *argv[])
|
||||
{
|
||||
struct sandbox_cmdline_option **sb_opt = __u_boot_sandbox_option_start;
|
||||
size_t num_options = __u_boot_sandbox_option_count();
|
||||
size_t i;
|
||||
|
||||
int hidden_short_opt;
|
||||
size_t si;
|
||||
|
||||
int c;
|
||||
|
||||
if (short_opts || long_opts)
|
||||
return 1;
|
||||
|
||||
state->argc = argc;
|
||||
state->argv = argv;
|
||||
|
||||
/* dynamically construct the arguments to the system getopt_long */
|
||||
short_opts = os_malloc(sizeof(*short_opts) * num_options * 2 + 1);
|
||||
long_opts = os_malloc(sizeof(*long_opts) * num_options);
|
||||
if (!short_opts || !long_opts)
|
||||
return 1;
|
||||
|
||||
/*
|
||||
* getopt_long requires "val" to be unique (since that is what the
|
||||
* func returns), so generate unique values automatically for flags
|
||||
* that don't have a short option. pick 0x100 as that is above the
|
||||
* single byte range (where ASCII/ISO-XXXX-X charsets live).
|
||||
*/
|
||||
hidden_short_opt = 0x100;
|
||||
si = 0;
|
||||
for (i = 0; i < num_options; ++i) {
|
||||
long_opts[i].name = sb_opt[i]->flag;
|
||||
long_opts[i].has_arg = sb_opt[i]->has_arg ?
|
||||
required_argument : no_argument;
|
||||
long_opts[i].flag = NULL;
|
||||
|
||||
if (sb_opt[i]->flag_short) {
|
||||
short_opts[si++] = long_opts[i].val = sb_opt[i]->flag_short;
|
||||
if (long_opts[i].has_arg == required_argument)
|
||||
short_opts[si++] = ':';
|
||||
} else
|
||||
long_opts[i].val = sb_opt[i]->flag_short = hidden_short_opt++;
|
||||
}
|
||||
short_opts[si] = '\0';
|
||||
|
||||
/* we need to handle output ourselves since u-boot provides printf */
|
||||
opterr = 0;
|
||||
|
||||
/*
|
||||
* walk all of the options the user gave us on the command line,
|
||||
* figure out what u-boot option structure they belong to (via
|
||||
* the unique short val key), and call the appropriate callback.
|
||||
*/
|
||||
while ((c = getopt_long(argc, argv, short_opts, long_opts, NULL)) != -1) {
|
||||
for (i = 0; i < num_options; ++i) {
|
||||
if (sb_opt[i]->flag_short == c) {
|
||||
if (sb_opt[i]->callback(state, optarg)) {
|
||||
state->parse_err = sb_opt[i]->flag;
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i == num_options) {
|
||||
/*
|
||||
* store the faulting flag for later display. we have to
|
||||
* store the flag itself as the getopt parsing itself is
|
||||
* tricky: need to handle the following flags (assume all
|
||||
* of the below are unknown):
|
||||
* -a optopt='a' optind=<next>
|
||||
* -abbbb optopt='a' optind=<this>
|
||||
* -aaaaa optopt='a' optind=<this>
|
||||
* --a optopt=0 optind=<this>
|
||||
* as you can see, it is impossible to determine the exact
|
||||
* faulting flag without doing the parsing ourselves, so
|
||||
* we just report the specific flag that failed.
|
||||
*/
|
||||
if (optopt) {
|
||||
static char parse_err[3] = { '-', 0, '\0', };
|
||||
parse_err[1] = optopt;
|
||||
state->parse_err = parse_err;
|
||||
} else
|
||||
state->parse_err = argv[optind - 1];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void os_dirent_free(struct os_dirent_node *node)
|
||||
{
|
||||
struct os_dirent_node *next;
|
||||
|
||||
while (node) {
|
||||
next = node->next;
|
||||
free(node);
|
||||
node = next;
|
||||
}
|
||||
}
|
||||
|
||||
int os_dirent_ls(const char *dirname, struct os_dirent_node **headp)
|
||||
{
|
||||
struct dirent entry, *result;
|
||||
struct os_dirent_node *head, *node, *next;
|
||||
struct stat buf;
|
||||
DIR *dir;
|
||||
int ret;
|
||||
char *fname;
|
||||
int len;
|
||||
|
||||
*headp = NULL;
|
||||
dir = opendir(dirname);
|
||||
if (!dir)
|
||||
return -1;
|
||||
|
||||
/* Create a buffer for the maximum filename length */
|
||||
len = sizeof(entry.d_name) + strlen(dirname) + 2;
|
||||
fname = malloc(len);
|
||||
if (!fname) {
|
||||
ret = -ENOMEM;
|
||||
goto done;
|
||||
}
|
||||
|
||||
for (node = head = NULL;; node = next) {
|
||||
ret = readdir_r(dir, &entry, &result);
|
||||
if (ret || !result)
|
||||
break;
|
||||
next = malloc(sizeof(*node) + strlen(entry.d_name) + 1);
|
||||
if (!next) {
|
||||
os_dirent_free(head);
|
||||
ret = -ENOMEM;
|
||||
goto done;
|
||||
}
|
||||
next->next = NULL;
|
||||
strcpy(next->name, entry.d_name);
|
||||
switch (entry.d_type) {
|
||||
case DT_REG:
|
||||
next->type = OS_FILET_REG;
|
||||
break;
|
||||
case DT_DIR:
|
||||
next->type = OS_FILET_DIR;
|
||||
break;
|
||||
case DT_LNK:
|
||||
next->type = OS_FILET_LNK;
|
||||
break;
|
||||
}
|
||||
next->size = 0;
|
||||
snprintf(fname, len, "%s/%s", dirname, next->name);
|
||||
if (!stat(fname, &buf))
|
||||
next->size = buf.st_size;
|
||||
if (node)
|
||||
node->next = next;
|
||||
if (!head)
|
||||
head = node;
|
||||
}
|
||||
*headp = head;
|
||||
|
||||
done:
|
||||
closedir(dir);
|
||||
free(fname);
|
||||
return ret;
|
||||
}
|
||||
|
||||
const char *os_dirent_typename[OS_FILET_COUNT] = {
|
||||
" ",
|
||||
"SYM",
|
||||
"DIR",
|
||||
"???",
|
||||
};
|
||||
|
||||
const char *os_dirent_get_typename(enum os_dirent_t type)
|
||||
{
|
||||
if (type >= 0 && type < OS_FILET_COUNT)
|
||||
return os_dirent_typename[type];
|
||||
|
||||
return os_dirent_typename[OS_FILET_UNKNOWN];
|
||||
}
|
||||
|
||||
int os_get_filesize(const char *fname, loff_t *size)
|
||||
{
|
||||
struct stat buf;
|
||||
int ret;
|
||||
|
||||
ret = stat(fname, &buf);
|
||||
if (ret)
|
||||
return ret;
|
||||
*size = buf.st_size;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void os_putc(int ch)
|
||||
{
|
||||
putchar(ch);
|
||||
}
|
||||
|
||||
void os_puts(const char *str)
|
||||
{
|
||||
while (*str)
|
||||
os_putc(*str++);
|
||||
}
|
||||
|
||||
int os_write_ram_buf(const char *fname)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
int fd, ret;
|
||||
|
||||
fd = open(fname, O_CREAT | O_WRONLY, 0777);
|
||||
if (fd < 0)
|
||||
return -ENOENT;
|
||||
ret = write(fd, state->ram_buf, state->ram_size);
|
||||
close(fd);
|
||||
if (ret != state->ram_size)
|
||||
return -EIO;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int os_read_ram_buf(const char *fname)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
int fd, ret;
|
||||
loff_t size;
|
||||
|
||||
ret = os_get_filesize(fname, &size);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
if (size != state->ram_size)
|
||||
return -ENOSPC;
|
||||
fd = open(fname, O_RDONLY);
|
||||
if (fd < 0)
|
||||
return -ENOENT;
|
||||
|
||||
ret = read(fd, state->ram_buf, state->ram_size);
|
||||
close(fd);
|
||||
if (ret != state->ram_size)
|
||||
return -EIO;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int make_exec(char *fname, const void *data, int size)
|
||||
{
|
||||
int fd;
|
||||
|
||||
strcpy(fname, "/tmp/u-boot.jump.XXXXXX");
|
||||
fd = mkstemp(fname);
|
||||
if (fd < 0)
|
||||
return -ENOENT;
|
||||
if (write(fd, data, size) < 0)
|
||||
return -EIO;
|
||||
close(fd);
|
||||
if (chmod(fname, 0777))
|
||||
return -ENOEXEC;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int add_args(char ***argvp, const char *add_args[], int count)
|
||||
{
|
||||
char **argv;
|
||||
int argc;
|
||||
|
||||
for (argv = *argvp, argc = 0; (*argvp)[argc]; argc++)
|
||||
;
|
||||
|
||||
argv = malloc((argc + count + 1) * sizeof(char *));
|
||||
if (!argv) {
|
||||
printf("Out of memory for %d argv\n", count);
|
||||
return -ENOMEM;
|
||||
}
|
||||
memcpy(argv, *argvp, argc * sizeof(char *));
|
||||
memcpy(argv + argc, add_args, count * sizeof(char *));
|
||||
argv[argc + count] = NULL;
|
||||
|
||||
*argvp = argv;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int os_jump_to_image(const void *dest, int size)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
char fname[30], mem_fname[30];
|
||||
int fd, err;
|
||||
const char *extra_args[5];
|
||||
char **argv = state->argv;
|
||||
#ifdef DEBUG
|
||||
int argc, i;
|
||||
#endif
|
||||
|
||||
err = make_exec(fname, dest, size);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
strcpy(mem_fname, "/tmp/u-boot.mem.XXXXXX");
|
||||
fd = mkstemp(mem_fname);
|
||||
if (fd < 0)
|
||||
return -ENOENT;
|
||||
close(fd);
|
||||
err = os_write_ram_buf(mem_fname);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
os_fd_restore();
|
||||
|
||||
extra_args[0] = "-j";
|
||||
extra_args[1] = fname;
|
||||
extra_args[2] = "-m";
|
||||
extra_args[3] = mem_fname;
|
||||
extra_args[4] = "--rm_memory";
|
||||
err = add_args(&argv, extra_args,
|
||||
sizeof(extra_args) / sizeof(extra_args[0]));
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
#ifdef DEBUG
|
||||
for (i = 0; argv[i]; i++)
|
||||
printf("%d %s\n", i, argv[i]);
|
||||
#endif
|
||||
|
||||
if (state_uninit())
|
||||
os_exit(2);
|
||||
|
||||
err = execv(fname, argv);
|
||||
free(argv);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
return unlink(fname);
|
||||
}
|
||||
|
||||
void os_localtime(struct rtc_time *rt)
|
||||
{
|
||||
time_t t = time(NULL);
|
||||
struct tm *tm;
|
||||
|
||||
tm = localtime(&t);
|
||||
rt->tm_sec = tm->tm_sec;
|
||||
rt->tm_min = tm->tm_min;
|
||||
rt->tm_hour = tm->tm_hour;
|
||||
rt->tm_mday = tm->tm_mday;
|
||||
rt->tm_mon = tm->tm_mon + 1;
|
||||
rt->tm_year = tm->tm_year + 1900;
|
||||
rt->tm_wday = tm->tm_wday;
|
||||
rt->tm_yday = tm->tm_yday;
|
||||
rt->tm_isdst = tm->tm_isdst;
|
||||
}
|
||||
341
u-boot/arch/sandbox/cpu/sdl.c
Normal file
341
u-boot/arch/sandbox/cpu/sdl.c
Normal file
@@ -0,0 +1,341 @@
|
||||
/*
|
||||
* Copyright (c) 2013 Google, Inc
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <linux/input.h>
|
||||
#include <SDL/SDL.h>
|
||||
#include <sound.h>
|
||||
#include <asm/state.h>
|
||||
|
||||
static struct sdl_info {
|
||||
SDL_Surface *screen;
|
||||
int width;
|
||||
int height;
|
||||
int depth;
|
||||
int pitch;
|
||||
uint frequency;
|
||||
uint audio_pos;
|
||||
uint audio_size;
|
||||
uint8_t *audio_data;
|
||||
bool audio_active;
|
||||
bool inited;
|
||||
} sdl;
|
||||
|
||||
static void sandbox_sdl_poll_events(void)
|
||||
{
|
||||
/*
|
||||
* We don't want to include common.h in this file since it uses
|
||||
* system headers. So add a declation here.
|
||||
*/
|
||||
extern void reset_cpu(unsigned long addr);
|
||||
SDL_Event event;
|
||||
|
||||
while (SDL_PollEvent(&event)) {
|
||||
switch (event.type) {
|
||||
case SDL_QUIT:
|
||||
puts("LCD window closed - quitting\n");
|
||||
reset_cpu(1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static int sandbox_sdl_ensure_init(void)
|
||||
{
|
||||
if (!sdl.inited) {
|
||||
if (SDL_Init(0) < 0) {
|
||||
printf("Unable to initialize SDL: %s\n",
|
||||
SDL_GetError());
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
atexit(SDL_Quit);
|
||||
|
||||
sdl.inited = true;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_sdl_init_display(int width, int height, int log2_bpp)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
int err;
|
||||
|
||||
if (!width || !state->show_lcd)
|
||||
return 0;
|
||||
err = sandbox_sdl_ensure_init();
|
||||
if (err)
|
||||
return err;
|
||||
if (SDL_InitSubSystem(SDL_INIT_VIDEO) < 0) {
|
||||
printf("Unable to initialize SDL LCD: %s\n", SDL_GetError());
|
||||
return -EPERM;
|
||||
}
|
||||
SDL_WM_SetCaption("U-Boot", "U-Boot");
|
||||
|
||||
sdl.width = width;
|
||||
sdl.height = height;
|
||||
sdl.depth = 1 << log2_bpp;
|
||||
sdl.pitch = sdl.width * sdl.depth / 8;
|
||||
sdl.screen = SDL_SetVideoMode(width, height, 0, 0);
|
||||
sandbox_sdl_poll_events();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_sdl_sync(void *lcd_base)
|
||||
{
|
||||
SDL_Surface *frame;
|
||||
|
||||
frame = SDL_CreateRGBSurfaceFrom(lcd_base, sdl.width, sdl.height,
|
||||
sdl.depth, sdl.pitch,
|
||||
0x1f << 11, 0x3f << 5, 0x1f << 0, 0);
|
||||
SDL_BlitSurface(frame, NULL, sdl.screen, NULL);
|
||||
SDL_FreeSurface(frame);
|
||||
SDL_UpdateRect(sdl.screen, 0, 0, 0, 0);
|
||||
sandbox_sdl_poll_events();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define NONE (-1)
|
||||
#define NUM_SDL_CODES (SDLK_UNDO + 1)
|
||||
|
||||
static int16_t sdl_to_keycode[NUM_SDL_CODES] = {
|
||||
/* 0 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, KEY_BACKSPACE, KEY_TAB,
|
||||
NONE, NONE, NONE, KEY_ENTER, NONE,
|
||||
NONE, NONE, NONE, NONE, KEY_POWER, /* use PAUSE as POWER */
|
||||
|
||||
/* 20 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, KEY_ESC, NONE, NONE,
|
||||
NONE, NONE, KEY_SPACE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 40 */
|
||||
NONE, NONE, NONE, NONE, KEY_COMMA,
|
||||
KEY_MINUS, KEY_DOT, KEY_SLASH, KEY_0, KEY_1,
|
||||
KEY_2, KEY_3, KEY_4, KEY_5, KEY_6,
|
||||
KEY_7, KEY_8, KEY_9, NONE, KEY_SEMICOLON,
|
||||
|
||||
/* 60 */
|
||||
NONE, KEY_EQUAL, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 80 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, KEY_BACKSLASH, NONE, NONE,
|
||||
NONE, KEY_GRAVE, KEY_A, KEY_B, KEY_C,
|
||||
|
||||
/* 100 */
|
||||
KEY_D, KEY_E, KEY_F, KEY_G, KEY_H,
|
||||
KEY_I, KEY_J, KEY_K, KEY_L, KEY_M,
|
||||
KEY_N, KEY_O, KEY_P, KEY_Q, KEY_R,
|
||||
KEY_S, KEY_T, KEY_U, KEY_V, KEY_W,
|
||||
|
||||
/* 120 */
|
||||
KEY_X, KEY_Y, KEY_Z, NONE, NONE,
|
||||
NONE, NONE, KEY_DELETE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 140 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 160 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 180 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 200 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 220 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 240 */
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
NONE, KEY_KP0, KEY_KP1, KEY_KP2, KEY_KP3,
|
||||
|
||||
/* 260 */
|
||||
KEY_KP4, KEY_KP5, KEY_KP6, KEY_KP7, KEY_KP8,
|
||||
KEY_KP9, KEY_KPDOT, KEY_KPSLASH, KEY_KPASTERISK, KEY_KPMINUS,
|
||||
KEY_KPPLUS, KEY_KPENTER, KEY_KPEQUAL, KEY_UP, KEY_DOWN,
|
||||
KEY_RIGHT, KEY_LEFT, KEY_INSERT, KEY_HOME, KEY_END,
|
||||
|
||||
/* 280 */
|
||||
KEY_PAGEUP, KEY_PAGEDOWN, KEY_F1, KEY_F2, KEY_F3,
|
||||
KEY_F4, KEY_F5, KEY_F6, KEY_F7, KEY_F8,
|
||||
KEY_F9, KEY_F10, KEY_F11, KEY_F12, NONE,
|
||||
NONE, NONE, NONE, NONE, NONE,
|
||||
|
||||
/* 300 */
|
||||
KEY_NUMLOCK, KEY_CAPSLOCK, KEY_SCROLLLOCK, KEY_RIGHTSHIFT,
|
||||
KEY_LEFTSHIFT,
|
||||
KEY_RIGHTCTRL, KEY_LEFTCTRL, KEY_RIGHTALT, KEY_LEFTALT, KEY_RIGHTMETA,
|
||||
KEY_LEFTMETA, NONE, KEY_FN, NONE, KEY_COMPOSE,
|
||||
NONE, KEY_PRINT, KEY_SYSRQ, KEY_PAUSE, NONE,
|
||||
|
||||
/* 320 */
|
||||
NONE, NONE, NONE,
|
||||
};
|
||||
|
||||
int sandbox_sdl_scan_keys(int key[], int max_keys)
|
||||
{
|
||||
Uint8 *keystate;
|
||||
int i, count;
|
||||
|
||||
sandbox_sdl_poll_events();
|
||||
keystate = SDL_GetKeyState(NULL);
|
||||
for (i = count = 0; i < NUM_SDL_CODES; i++) {
|
||||
if (count >= max_keys)
|
||||
break;
|
||||
else if (keystate[i])
|
||||
key[count++] = sdl_to_keycode[i];
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
|
||||
int sandbox_sdl_key_pressed(int keycode)
|
||||
{
|
||||
int key[8]; /* allow up to 8 keys to be pressed at once */
|
||||
int count;
|
||||
int i;
|
||||
|
||||
count = sandbox_sdl_scan_keys(key, sizeof(key) / sizeof(key[0]));
|
||||
for (i = 0; i < count; i++) {
|
||||
if (key[i] == keycode)
|
||||
return 0;
|
||||
}
|
||||
|
||||
return -ENOENT;
|
||||
}
|
||||
|
||||
void sandbox_sdl_fill_audio(void *udata, Uint8 *stream, int len)
|
||||
{
|
||||
int avail;
|
||||
|
||||
avail = sdl.audio_size - sdl.audio_pos;
|
||||
if (avail < len)
|
||||
len = avail;
|
||||
|
||||
SDL_MixAudio(stream, sdl.audio_data + sdl.audio_pos, len,
|
||||
SDL_MIX_MAXVOLUME);
|
||||
sdl.audio_pos += len;
|
||||
|
||||
/* Loop if we are at the end */
|
||||
if (sdl.audio_pos == sdl.audio_size)
|
||||
sdl.audio_pos = 0;
|
||||
}
|
||||
|
||||
int sandbox_sdl_sound_init(void)
|
||||
{
|
||||
SDL_AudioSpec wanted;
|
||||
|
||||
if (sandbox_sdl_ensure_init())
|
||||
return -1;
|
||||
|
||||
if (sdl.audio_active)
|
||||
return 0;
|
||||
|
||||
/*
|
||||
* At present all sandbox sounds crash. This is probably due to
|
||||
* symbol name conflicts with U-Boot. We can remove the malloc()
|
||||
* probles with:
|
||||
*
|
||||
* #define USE_DL_PREFIX
|
||||
*
|
||||
* and get this:
|
||||
*
|
||||
* Assertion 'e->pollfd->fd == e->fd' failed at pulse/mainloop.c:676,
|
||||
* function dispatch_pollfds(). Aborting.
|
||||
*
|
||||
* The right solution is probably to make U-Boot's names private or
|
||||
* link os.c and sdl.c against their libraries before liking with
|
||||
* U-Boot. TBD. For now sound is disabled.
|
||||
*/
|
||||
printf("(Warning: sandbox sound disabled)\n");
|
||||
return 0;
|
||||
|
||||
/* Set the audio format */
|
||||
wanted.freq = 22050;
|
||||
wanted.format = AUDIO_S16;
|
||||
wanted.channels = 1; /* 1 = mono, 2 = stereo */
|
||||
wanted.samples = 1024; /* Good low-latency value for callback */
|
||||
wanted.callback = sandbox_sdl_fill_audio;
|
||||
wanted.userdata = NULL;
|
||||
|
||||
sdl.audio_size = sizeof(uint16_t) * wanted.freq;
|
||||
sdl.audio_data = malloc(sdl.audio_size);
|
||||
if (!sdl.audio_data) {
|
||||
printf("%s: Out of memory\n", __func__);
|
||||
return -1;
|
||||
}
|
||||
sdl.audio_pos = 0;
|
||||
|
||||
if (SDL_InitSubSystem(SDL_INIT_AUDIO) < 0) {
|
||||
printf("Unable to initialize SDL audio: %s\n", SDL_GetError());
|
||||
goto err;
|
||||
}
|
||||
|
||||
/* Open the audio device, forcing the desired format */
|
||||
if (SDL_OpenAudio(&wanted, NULL) < 0) {
|
||||
printf("Couldn't open audio: %s\n", SDL_GetError());
|
||||
goto err;
|
||||
}
|
||||
sdl.audio_active = true;
|
||||
|
||||
return 0;
|
||||
|
||||
err:
|
||||
free(sdl.audio_data);
|
||||
return -1;
|
||||
}
|
||||
|
||||
int sandbox_sdl_sound_start(uint frequency)
|
||||
{
|
||||
if (!sdl.audio_active)
|
||||
return -1;
|
||||
sdl.frequency = frequency;
|
||||
sound_create_square_wave((unsigned short *)sdl.audio_data,
|
||||
sdl.audio_size, frequency);
|
||||
sdl.audio_pos = 0;
|
||||
SDL_PauseAudio(0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_sdl_sound_stop(void)
|
||||
{
|
||||
if (!sdl.audio_active)
|
||||
return -1;
|
||||
SDL_PauseAudio(1);
|
||||
|
||||
return 0;
|
||||
}
|
||||
315
u-boot/arch/sandbox/cpu/start.c
Normal file
315
u-boot/arch/sandbox/cpu/start.c
Normal file
@@ -0,0 +1,315 @@
|
||||
/*
|
||||
* Copyright (c) 2011-2012 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <errno.h>
|
||||
#include <os.h>
|
||||
#include <cli.h>
|
||||
#include <malloc.h>
|
||||
#include <asm/getopt.h>
|
||||
#include <asm/io.h>
|
||||
#include <asm/sections.h>
|
||||
#include <asm/state.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
int sandbox_early_getopt_check(void)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
struct sandbox_cmdline_option **sb_opt = __u_boot_sandbox_option_start;
|
||||
size_t num_options = __u_boot_sandbox_option_count();
|
||||
size_t i;
|
||||
int max_arg_len, max_noarg_len;
|
||||
|
||||
/* parse_err will be a string of the faulting option */
|
||||
if (!state->parse_err)
|
||||
return 0;
|
||||
|
||||
if (strcmp(state->parse_err, "help")) {
|
||||
printf("u-boot: error: failed while parsing option: %s\n"
|
||||
"\ttry running with --help for more information.\n",
|
||||
state->parse_err);
|
||||
os_exit(1);
|
||||
}
|
||||
|
||||
printf(
|
||||
"u-boot, a command line test interface to U-Boot\n\n"
|
||||
"Usage: u-boot [options]\n"
|
||||
"Options:\n");
|
||||
|
||||
max_arg_len = 0;
|
||||
for (i = 0; i < num_options; ++i)
|
||||
max_arg_len = max((int)strlen(sb_opt[i]->flag), max_arg_len);
|
||||
max_noarg_len = max_arg_len + 7;
|
||||
|
||||
for (i = 0; i < num_options; ++i) {
|
||||
struct sandbox_cmdline_option *opt = sb_opt[i];
|
||||
|
||||
/* first output the short flag if it has one */
|
||||
if (opt->flag_short >= 0x100)
|
||||
printf(" ");
|
||||
else
|
||||
printf(" -%c, ", opt->flag_short);
|
||||
|
||||
/* then the long flag */
|
||||
if (opt->has_arg)
|
||||
printf("--%-*s <arg> ", max_arg_len, opt->flag);
|
||||
else
|
||||
printf("--%-*s", max_noarg_len, opt->flag);
|
||||
|
||||
/* finally the help text */
|
||||
printf(" %s\n", opt->help);
|
||||
}
|
||||
|
||||
os_exit(0);
|
||||
}
|
||||
|
||||
static int sandbox_cmdline_cb_help(struct sandbox_state *state, const char *arg)
|
||||
{
|
||||
/* just flag to sandbox_early_getopt_check to show usage */
|
||||
return 1;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(help, 'h', 0, "Display help");
|
||||
|
||||
int sandbox_main_loop_init(void)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
|
||||
/* Execute command if required */
|
||||
if (state->cmd || state->run_distro_boot) {
|
||||
int retval = 0;
|
||||
|
||||
cli_init();
|
||||
|
||||
#ifdef CONFIG_CMDLINE
|
||||
if (state->cmd)
|
||||
retval = run_command_list(state->cmd, -1, 0);
|
||||
|
||||
if (state->run_distro_boot)
|
||||
retval = cli_simple_run_command("run distro_bootcmd",
|
||||
0);
|
||||
#endif
|
||||
if (!state->interactive)
|
||||
os_exit(retval);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int sandbox_cmdline_cb_boot(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->run_distro_boot = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(boot, 'b', 0, "Run distro boot commands");
|
||||
|
||||
static int sandbox_cmdline_cb_command(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->cmd = arg;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(command, 'c', 1, "Execute U-Boot command");
|
||||
|
||||
static int sandbox_cmdline_cb_fdt(struct sandbox_state *state, const char *arg)
|
||||
{
|
||||
state->fdt_fname = arg;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(fdt, 'd', 1, "Specify U-Boot's control FDT");
|
||||
|
||||
static int sandbox_cmdline_cb_default_fdt(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
const char *fmt = "%s.dtb";
|
||||
char *fname;
|
||||
int len;
|
||||
|
||||
len = strlen(state->argv[0]) + strlen(fmt) + 1;
|
||||
fname = os_malloc(len);
|
||||
if (!fname)
|
||||
return -ENOMEM;
|
||||
snprintf(fname, len, fmt, state->argv[0]);
|
||||
state->fdt_fname = fname;
|
||||
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(default_fdt, 'D', 0,
|
||||
"Use the default u-boot.dtb control FDT in U-Boot directory");
|
||||
|
||||
static int sandbox_cmdline_cb_interactive(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->interactive = true;
|
||||
return 0;
|
||||
}
|
||||
|
||||
SANDBOX_CMDLINE_OPT_SHORT(interactive, 'i', 0, "Enter interactive mode");
|
||||
|
||||
static int sandbox_cmdline_cb_jump(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
/* Remember to delete this U-Boot image later */
|
||||
state->jumped_fname = arg;
|
||||
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(jump, 'j', 1, "Jumped from previous U-Boot");
|
||||
|
||||
static int sandbox_cmdline_cb_memory(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
int err;
|
||||
|
||||
/* For now assume we always want to write it */
|
||||
state->write_ram_buf = true;
|
||||
state->ram_buf_fname = arg;
|
||||
|
||||
err = os_read_ram_buf(arg);
|
||||
if (err) {
|
||||
printf("Failed to read RAM buffer\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(memory, 'm', 1,
|
||||
"Read/write ram_buf memory contents from file");
|
||||
|
||||
static int sandbox_cmdline_cb_rm_memory(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->ram_buf_rm = true;
|
||||
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT(rm_memory, 0, "Remove memory file after reading");
|
||||
|
||||
static int sandbox_cmdline_cb_state(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->state_fname = arg;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(state, 's', 1, "Specify the sandbox state FDT");
|
||||
|
||||
static int sandbox_cmdline_cb_read(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->read_state = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(read, 'r', 0, "Read the state FDT on startup");
|
||||
|
||||
static int sandbox_cmdline_cb_write(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->write_state = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(write, 'w', 0, "Write state FDT on exit");
|
||||
|
||||
static int sandbox_cmdline_cb_ignore_missing(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->ignore_missing_state_on_read = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(ignore_missing, 'n', 0,
|
||||
"Ignore missing state on read");
|
||||
|
||||
static int sandbox_cmdline_cb_show_lcd(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->show_lcd = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(show_lcd, 'l', 0,
|
||||
"Show the sandbox LCD display");
|
||||
|
||||
static const char *term_args[STATE_TERM_COUNT] = {
|
||||
"raw-with-sigs",
|
||||
"raw",
|
||||
"cooked",
|
||||
};
|
||||
|
||||
static int sandbox_cmdline_cb_terminal(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < STATE_TERM_COUNT; i++) {
|
||||
if (!strcmp(arg, term_args[i])) {
|
||||
state->term_raw = i;
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
printf("Unknown terminal setting '%s' (", arg);
|
||||
for (i = 0; i < STATE_TERM_COUNT; i++)
|
||||
printf("%s%s", i ? ", " : "", term_args[i]);
|
||||
puts(")\n");
|
||||
|
||||
return 1;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(terminal, 't', 1,
|
||||
"Set terminal to raw/cooked mode");
|
||||
|
||||
static int sandbox_cmdline_cb_verbose(struct sandbox_state *state,
|
||||
const char *arg)
|
||||
{
|
||||
state->show_test_output = true;
|
||||
return 0;
|
||||
}
|
||||
SANDBOX_CMDLINE_OPT_SHORT(verbose, 'v', 0, "Show test output");
|
||||
|
||||
int board_run_command(const char *cmdline)
|
||||
{
|
||||
printf("## Commands are disabled. Please enable CONFIG_CMDLINE.\n");
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
struct sandbox_state *state;
|
||||
gd_t data;
|
||||
int ret;
|
||||
|
||||
ret = state_init();
|
||||
if (ret)
|
||||
goto err;
|
||||
|
||||
state = state_get_current();
|
||||
if (os_parse_args(state, argc, argv))
|
||||
return 1;
|
||||
|
||||
ret = sandbox_read_state(state, state->state_fname);
|
||||
if (ret)
|
||||
goto err;
|
||||
|
||||
/* Remove old memory file if required */
|
||||
if (state->ram_buf_rm && state->ram_buf_fname)
|
||||
os_unlink(state->ram_buf_fname);
|
||||
|
||||
memset(&data, '\0', sizeof(data));
|
||||
gd = &data;
|
||||
#ifdef CONFIG_SYS_MALLOC_F_LEN
|
||||
gd->malloc_base = CONFIG_MALLOC_F_ADDR;
|
||||
#endif
|
||||
|
||||
/* Do pre- and post-relocation init */
|
||||
board_init_f(0);
|
||||
|
||||
board_init_r(gd->new_gd, 0);
|
||||
|
||||
/* NOTREACHED - board_init_r() does not return */
|
||||
return 0;
|
||||
|
||||
err:
|
||||
printf("Error %d\n", ret);
|
||||
return 1;
|
||||
}
|
||||
405
u-boot/arch/sandbox/cpu/state.c
Normal file
405
u-boot/arch/sandbox/cpu/state.c
Normal file
@@ -0,0 +1,405 @@
|
||||
/*
|
||||
* Copyright (c) 2011-2012 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <errno.h>
|
||||
#include <fdtdec.h>
|
||||
#include <os.h>
|
||||
#include <asm/state.h>
|
||||
|
||||
/* Main state record for the sandbox */
|
||||
static struct sandbox_state main_state;
|
||||
static struct sandbox_state *state; /* Pointer to current state record */
|
||||
|
||||
static int state_ensure_space(int extra_size)
|
||||
{
|
||||
void *blob = state->state_fdt;
|
||||
int used, size, free;
|
||||
void *buf;
|
||||
int ret;
|
||||
|
||||
used = fdt_off_dt_strings(blob) + fdt_size_dt_strings(blob);
|
||||
size = fdt_totalsize(blob);
|
||||
free = size - used;
|
||||
if (free > extra_size)
|
||||
return 0;
|
||||
|
||||
size = used + extra_size;
|
||||
buf = os_malloc(size);
|
||||
if (!buf)
|
||||
return -ENOMEM;
|
||||
|
||||
ret = fdt_open_into(blob, buf, size);
|
||||
if (ret) {
|
||||
os_free(buf);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
os_free(blob);
|
||||
state->state_fdt = buf;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int state_read_file(struct sandbox_state *state, const char *fname)
|
||||
{
|
||||
loff_t size;
|
||||
int ret;
|
||||
int fd;
|
||||
|
||||
ret = os_get_filesize(fname, &size);
|
||||
if (ret < 0) {
|
||||
printf("Cannot find sandbox state file '%s'\n", fname);
|
||||
return -ENOENT;
|
||||
}
|
||||
state->state_fdt = os_malloc(size);
|
||||
if (!state->state_fdt) {
|
||||
puts("No memory to read sandbox state\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
fd = os_open(fname, OS_O_RDONLY);
|
||||
if (fd < 0) {
|
||||
printf("Cannot open sandbox state file '%s'\n", fname);
|
||||
ret = -EPERM;
|
||||
goto err_open;
|
||||
}
|
||||
if (os_read(fd, state->state_fdt, size) != size) {
|
||||
printf("Cannot read sandbox state file '%s'\n", fname);
|
||||
ret = -EIO;
|
||||
goto err_read;
|
||||
}
|
||||
os_close(fd);
|
||||
|
||||
return 0;
|
||||
err_read:
|
||||
os_close(fd);
|
||||
err_open:
|
||||
os_free(state->state_fdt);
|
||||
state->state_fdt = NULL;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
/***
|
||||
* sandbox_read_state_nodes() - Read state associated with a driver
|
||||
*
|
||||
* This looks through all compatible nodes and calls the read function on
|
||||
* each one, to read in the state.
|
||||
*
|
||||
* If nothing is found, it still calls the read function once, to set up a
|
||||
* single global state for that driver.
|
||||
*
|
||||
* @state: Sandbox state
|
||||
* @io: Method to use for reading state
|
||||
* @blob: FDT containing state
|
||||
* @return 0 if OK, -EINVAL if the read function returned failure
|
||||
*/
|
||||
int sandbox_read_state_nodes(struct sandbox_state *state,
|
||||
struct sandbox_state_io *io, const void *blob)
|
||||
{
|
||||
int count;
|
||||
int node;
|
||||
int ret;
|
||||
|
||||
debug(" - read %s\n", io->name);
|
||||
if (!io->read)
|
||||
return 0;
|
||||
|
||||
node = -1;
|
||||
count = 0;
|
||||
while (blob) {
|
||||
node = fdt_node_offset_by_compatible(blob, node, io->compat);
|
||||
if (node < 0)
|
||||
return 0; /* No more */
|
||||
debug(" - read node '%s'\n", fdt_get_name(blob, node, NULL));
|
||||
ret = io->read(blob, node);
|
||||
if (ret) {
|
||||
printf("Unable to read state for '%s'\n", io->compat);
|
||||
return -EINVAL;
|
||||
}
|
||||
count++;
|
||||
}
|
||||
|
||||
/*
|
||||
* If we got no saved state, call the read function once without a
|
||||
* node, to set up the global state.
|
||||
*/
|
||||
if (count == 0) {
|
||||
debug(" - read global\n");
|
||||
ret = io->read(NULL, -1);
|
||||
if (ret) {
|
||||
printf("Unable to read global state for '%s'\n",
|
||||
io->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_read_state(struct sandbox_state *state, const char *fname)
|
||||
{
|
||||
struct sandbox_state_io *io;
|
||||
const void *blob;
|
||||
bool got_err;
|
||||
int ret;
|
||||
|
||||
if (state->read_state && fname) {
|
||||
ret = state_read_file(state, fname);
|
||||
if (ret == -ENOENT && state->ignore_missing_state_on_read)
|
||||
ret = 0;
|
||||
if (ret)
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Call all the state read funtcions */
|
||||
got_err = false;
|
||||
blob = state->state_fdt;
|
||||
io = ll_entry_start(struct sandbox_state_io, state_io);
|
||||
for (; io < ll_entry_end(struct sandbox_state_io, state_io); io++) {
|
||||
ret = sandbox_read_state_nodes(state, io, blob);
|
||||
if (ret < 0)
|
||||
got_err = true;
|
||||
}
|
||||
|
||||
if (state->read_state && fname) {
|
||||
debug("Read sandbox state from '%s'%s\n", fname,
|
||||
got_err ? " (with errors)" : "");
|
||||
}
|
||||
|
||||
return got_err ? -1 : 0;
|
||||
}
|
||||
|
||||
/***
|
||||
* sandbox_write_state_node() - Write state associated with a driver
|
||||
*
|
||||
* This calls the write function to write out global state for that driver.
|
||||
*
|
||||
* TODO(sjg@chromium.org): Support writing out state from multiple drivers
|
||||
* of the same time. We don't need this yet,and it will be much easier to
|
||||
* do when driver model is available.
|
||||
*
|
||||
* @state: Sandbox state
|
||||
* @io: Method to use for writing state
|
||||
* @return 0 if OK, -EIO if there is a fatal error (such as out of space
|
||||
* for adding the data), -EINVAL if the write function failed.
|
||||
*/
|
||||
int sandbox_write_state_node(struct sandbox_state *state,
|
||||
struct sandbox_state_io *io)
|
||||
{
|
||||
void *blob;
|
||||
int node;
|
||||
int ret;
|
||||
|
||||
if (!io->write)
|
||||
return 0;
|
||||
|
||||
ret = state_ensure_space(SANDBOX_STATE_MIN_SPACE);
|
||||
if (ret) {
|
||||
printf("Failed to add more space for state\n");
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
/* The blob location can change when the size increases */
|
||||
blob = state->state_fdt;
|
||||
node = fdt_node_offset_by_compatible(blob, -1, io->compat);
|
||||
if (node == -FDT_ERR_NOTFOUND) {
|
||||
node = fdt_add_subnode(blob, 0, io->name);
|
||||
if (node < 0) {
|
||||
printf("Cannot create node '%s': %s\n", io->name,
|
||||
fdt_strerror(node));
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
if (fdt_setprop_string(blob, node, "compatible", io->compat)) {
|
||||
puts("Cannot set compatible\n");
|
||||
return -EIO;
|
||||
}
|
||||
} else if (node < 0) {
|
||||
printf("Cannot access node '%s': %s\n", io->name,
|
||||
fdt_strerror(node));
|
||||
return -EIO;
|
||||
}
|
||||
debug("Write state for '%s' to node %d\n", io->compat, node);
|
||||
ret = io->write(blob, node);
|
||||
if (ret) {
|
||||
printf("Unable to write state for '%s'\n", io->compat);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sandbox_write_state(struct sandbox_state *state, const char *fname)
|
||||
{
|
||||
struct sandbox_state_io *io;
|
||||
bool got_err;
|
||||
int size;
|
||||
int ret;
|
||||
int fd;
|
||||
|
||||
/* Create a state FDT if we don't have one */
|
||||
if (!state->state_fdt) {
|
||||
size = 0x4000;
|
||||
state->state_fdt = os_malloc(size);
|
||||
if (!state->state_fdt) {
|
||||
puts("No memory to create FDT\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
ret = fdt_create_empty_tree(state->state_fdt, size);
|
||||
if (ret < 0) {
|
||||
printf("Cannot create empty state FDT: %s\n",
|
||||
fdt_strerror(ret));
|
||||
ret = -EIO;
|
||||
goto err_create;
|
||||
}
|
||||
}
|
||||
|
||||
/* Call all the state write funtcions */
|
||||
got_err = false;
|
||||
io = ll_entry_start(struct sandbox_state_io, state_io);
|
||||
ret = 0;
|
||||
for (; io < ll_entry_end(struct sandbox_state_io, state_io); io++) {
|
||||
ret = sandbox_write_state_node(state, io);
|
||||
if (ret == -EIO)
|
||||
break;
|
||||
else if (ret)
|
||||
got_err = true;
|
||||
}
|
||||
|
||||
if (ret == -EIO) {
|
||||
printf("Could not write sandbox state\n");
|
||||
goto err_create;
|
||||
}
|
||||
|
||||
ret = fdt_pack(state->state_fdt);
|
||||
if (ret < 0) {
|
||||
printf("Cannot pack state FDT: %s\n", fdt_strerror(ret));
|
||||
ret = -EINVAL;
|
||||
goto err_create;
|
||||
}
|
||||
size = fdt_totalsize(state->state_fdt);
|
||||
fd = os_open(fname, OS_O_WRONLY | OS_O_CREAT);
|
||||
if (fd < 0) {
|
||||
printf("Cannot open sandbox state file '%s'\n", fname);
|
||||
ret = -EIO;
|
||||
goto err_create;
|
||||
}
|
||||
if (os_write(fd, state->state_fdt, size) != size) {
|
||||
printf("Cannot write sandbox state file '%s'\n", fname);
|
||||
ret = -EIO;
|
||||
goto err_write;
|
||||
}
|
||||
os_close(fd);
|
||||
|
||||
debug("Wrote sandbox state to '%s'%s\n", fname,
|
||||
got_err ? " (with errors)" : "");
|
||||
|
||||
return 0;
|
||||
err_write:
|
||||
os_close(fd);
|
||||
err_create:
|
||||
os_free(state->state_fdt);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int state_setprop(int node, const char *prop_name, const void *data, int size)
|
||||
{
|
||||
void *blob;
|
||||
int len;
|
||||
int ret;
|
||||
|
||||
fdt_getprop(state->state_fdt, node, prop_name, &len);
|
||||
|
||||
/* Add space for the new property, its name and some overhead */
|
||||
ret = state_ensure_space(size - len + strlen(prop_name) + 32);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
/* This should succeed, barring a mutiny */
|
||||
blob = state->state_fdt;
|
||||
ret = fdt_setprop(blob, node, prop_name, data, size);
|
||||
if (ret) {
|
||||
printf("%s: Unable to set property '%s' in node '%s': %s\n",
|
||||
__func__, prop_name, fdt_get_name(blob, node, NULL),
|
||||
fdt_strerror(ret));
|
||||
return -ENOSPC;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
struct sandbox_state *state_get_current(void)
|
||||
{
|
||||
assert(state);
|
||||
return state;
|
||||
}
|
||||
|
||||
void state_set_skip_delays(bool skip_delays)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
|
||||
state->skip_delays = skip_delays;
|
||||
}
|
||||
|
||||
bool state_get_skip_delays(void)
|
||||
{
|
||||
struct sandbox_state *state = state_get_current();
|
||||
|
||||
return state->skip_delays;
|
||||
}
|
||||
|
||||
int state_init(void)
|
||||
{
|
||||
state = &main_state;
|
||||
|
||||
state->ram_size = CONFIG_SYS_SDRAM_SIZE;
|
||||
state->ram_buf = os_malloc(state->ram_size);
|
||||
assert(state->ram_buf);
|
||||
|
||||
/* No reset yet, so mark it as such. Always allow power reset */
|
||||
state->last_sysreset = SYSRESET_COUNT;
|
||||
state->sysreset_allowed[SYSRESET_POWER] = true;
|
||||
|
||||
/*
|
||||
* Example of how to use GPIOs:
|
||||
*
|
||||
* sandbox_gpio_set_direction(170, 0);
|
||||
* sandbox_gpio_set_value(170, 0);
|
||||
*/
|
||||
return 0;
|
||||
}
|
||||
|
||||
int state_uninit(void)
|
||||
{
|
||||
int err;
|
||||
|
||||
state = &main_state;
|
||||
|
||||
if (state->write_ram_buf && !state->ram_buf_rm) {
|
||||
err = os_write_ram_buf(state->ram_buf_fname);
|
||||
if (err) {
|
||||
printf("Failed to write RAM buffer\n");
|
||||
return err;
|
||||
}
|
||||
}
|
||||
|
||||
if (state->write_state) {
|
||||
if (sandbox_write_state(state, state->state_fname)) {
|
||||
printf("Failed to write sandbox state\n");
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
/* Delete this at the last moment so as not to upset gdb too much */
|
||||
if (state->jumped_fname)
|
||||
os_unlink(state->jumped_fname);
|
||||
|
||||
if (state->state_fdt)
|
||||
os_free(state->state_fdt);
|
||||
memset(state, '\0', sizeof(*state));
|
||||
|
||||
return 0;
|
||||
}
|
||||
24
u-boot/arch/sandbox/cpu/u-boot.lds
Normal file
24
u-boot/arch/sandbox/cpu/u-boot.lds
Normal file
@@ -0,0 +1,24 @@
|
||||
/*
|
||||
* Copyright (c) 2011-2012 The Chromium OS Authors.
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
SECTIONS
|
||||
{
|
||||
|
||||
. = ALIGN(4);
|
||||
.u_boot_list : {
|
||||
KEEP(*(SORT(.u_boot_list*)));
|
||||
}
|
||||
|
||||
__u_boot_sandbox_option_start = .;
|
||||
_u_boot_sandbox_getopt : { *(.u_boot_sandbox_getopt) }
|
||||
__u_boot_sandbox_option_end = .;
|
||||
|
||||
__bss_start = .;
|
||||
}
|
||||
|
||||
INSERT BEFORE .data;
|
||||
1
u-boot/arch/sandbox/dts/.gitignore
vendored
Normal file
1
u-boot/arch/sandbox/dts/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
||||
*.dtb
|
||||
16
u-boot/arch/sandbox/dts/Makefile
Normal file
16
u-boot/arch/sandbox/dts/Makefile
Normal file
@@ -0,0 +1,16 @@
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
dtb-$(CONFIG_SANDBOX) += sandbox.dtb
|
||||
dtb-$(CONFIG_UT_DM) += test.dtb
|
||||
|
||||
targets += $(dtb-y)
|
||||
|
||||
DTC_FLAGS += -R 4 -p 0x1000
|
||||
|
||||
PHONY += dtbs
|
||||
dtbs: $(addprefix $(obj)/, $(dtb-y))
|
||||
@:
|
||||
|
||||
clean-files := *.dtb
|
||||
105
u-boot/arch/sandbox/dts/cros-ec-keyboard.dtsi
Normal file
105
u-boot/arch/sandbox/dts/cros-ec-keyboard.dtsi
Normal file
@@ -0,0 +1,105 @@
|
||||
/*
|
||||
* Keyboard dts fragment for devices that use cros-ec-keyboard
|
||||
*
|
||||
* Copyright (c) 2014 Google, Inc
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <dt-bindings/input/input.h>
|
||||
|
||||
&cros_ec {
|
||||
keyboard-controller {
|
||||
compatible = "google,cros-ec-keyb";
|
||||
keypad,num-rows = <8>;
|
||||
keypad,num-columns = <13>;
|
||||
google,needs-ghost-filter;
|
||||
|
||||
linux,keymap = <
|
||||
MATRIX_KEY(0x00, 0x01, KEY_LEFTMETA)
|
||||
MATRIX_KEY(0x00, 0x02, KEY_F1)
|
||||
MATRIX_KEY(0x00, 0x03, KEY_B)
|
||||
MATRIX_KEY(0x00, 0x04, KEY_F10)
|
||||
MATRIX_KEY(0x00, 0x06, KEY_N)
|
||||
MATRIX_KEY(0x00, 0x08, KEY_EQUAL)
|
||||
MATRIX_KEY(0x00, 0x0a, KEY_RIGHTALT)
|
||||
|
||||
MATRIX_KEY(0x01, 0x01, KEY_ESC)
|
||||
MATRIX_KEY(0x01, 0x02, KEY_F4)
|
||||
MATRIX_KEY(0x01, 0x03, KEY_G)
|
||||
MATRIX_KEY(0x01, 0x04, KEY_F7)
|
||||
MATRIX_KEY(0x01, 0x06, KEY_H)
|
||||
MATRIX_KEY(0x01, 0x08, KEY_APOSTROPHE)
|
||||
MATRIX_KEY(0x01, 0x09, KEY_F9)
|
||||
MATRIX_KEY(0x01, 0x0b, KEY_BACKSPACE)
|
||||
|
||||
MATRIX_KEY(0x02, 0x00, KEY_LEFTCTRL)
|
||||
MATRIX_KEY(0x02, 0x01, KEY_TAB)
|
||||
MATRIX_KEY(0x02, 0x02, KEY_F3)
|
||||
MATRIX_KEY(0x02, 0x03, KEY_T)
|
||||
MATRIX_KEY(0x02, 0x04, KEY_F6)
|
||||
MATRIX_KEY(0x02, 0x05, KEY_RIGHTBRACE)
|
||||
MATRIX_KEY(0x02, 0x06, KEY_Y)
|
||||
MATRIX_KEY(0x02, 0x07, KEY_102ND)
|
||||
MATRIX_KEY(0x02, 0x08, KEY_LEFTBRACE)
|
||||
MATRIX_KEY(0x02, 0x09, KEY_F8)
|
||||
|
||||
MATRIX_KEY(0x03, 0x01, KEY_GRAVE)
|
||||
MATRIX_KEY(0x03, 0x02, KEY_F2)
|
||||
MATRIX_KEY(0x03, 0x03, KEY_5)
|
||||
MATRIX_KEY(0x03, 0x04, KEY_F5)
|
||||
MATRIX_KEY(0x03, 0x06, KEY_6)
|
||||
MATRIX_KEY(0x03, 0x08, KEY_MINUS)
|
||||
MATRIX_KEY(0x03, 0x0b, KEY_BACKSLASH)
|
||||
|
||||
MATRIX_KEY(0x04, 0x00, KEY_RIGHTCTRL)
|
||||
MATRIX_KEY(0x04, 0x01, KEY_A)
|
||||
MATRIX_KEY(0x04, 0x02, KEY_D)
|
||||
MATRIX_KEY(0x04, 0x03, KEY_F)
|
||||
MATRIX_KEY(0x04, 0x04, KEY_S)
|
||||
MATRIX_KEY(0x04, 0x05, KEY_K)
|
||||
MATRIX_KEY(0x04, 0x06, KEY_J)
|
||||
MATRIX_KEY(0x04, 0x08, KEY_SEMICOLON)
|
||||
MATRIX_KEY(0x04, 0x09, KEY_L)
|
||||
MATRIX_KEY(0x04, 0x0a, KEY_BACKSLASH)
|
||||
MATRIX_KEY(0x04, 0x0b, KEY_ENTER)
|
||||
|
||||
MATRIX_KEY(0x05, 0x01, KEY_Z)
|
||||
MATRIX_KEY(0x05, 0x02, KEY_C)
|
||||
MATRIX_KEY(0x05, 0x03, KEY_V)
|
||||
MATRIX_KEY(0x05, 0x04, KEY_X)
|
||||
MATRIX_KEY(0x05, 0x05, KEY_COMMA)
|
||||
MATRIX_KEY(0x05, 0x06, KEY_M)
|
||||
MATRIX_KEY(0x05, 0x07, KEY_LEFTSHIFT)
|
||||
MATRIX_KEY(0x05, 0x08, KEY_SLASH)
|
||||
MATRIX_KEY(0x05, 0x09, KEY_DOT)
|
||||
MATRIX_KEY(0x05, 0x0b, KEY_SPACE)
|
||||
|
||||
MATRIX_KEY(0x06, 0x01, KEY_1)
|
||||
MATRIX_KEY(0x06, 0x02, KEY_3)
|
||||
MATRIX_KEY(0x06, 0x03, KEY_4)
|
||||
MATRIX_KEY(0x06, 0x04, KEY_2)
|
||||
MATRIX_KEY(0x06, 0x05, KEY_8)
|
||||
MATRIX_KEY(0x06, 0x06, KEY_7)
|
||||
MATRIX_KEY(0x06, 0x08, KEY_0)
|
||||
MATRIX_KEY(0x06, 0x09, KEY_9)
|
||||
MATRIX_KEY(0x06, 0x0a, KEY_LEFTALT)
|
||||
MATRIX_KEY(0x06, 0x0b, KEY_DOWN)
|
||||
MATRIX_KEY(0x06, 0x0c, KEY_RIGHT)
|
||||
|
||||
MATRIX_KEY(0x07, 0x01, KEY_Q)
|
||||
MATRIX_KEY(0x07, 0x02, KEY_E)
|
||||
MATRIX_KEY(0x07, 0x03, KEY_R)
|
||||
MATRIX_KEY(0x07, 0x04, KEY_W)
|
||||
MATRIX_KEY(0x07, 0x05, KEY_I)
|
||||
MATRIX_KEY(0x07, 0x06, KEY_U)
|
||||
MATRIX_KEY(0x07, 0x07, KEY_RIGHTSHIFT)
|
||||
MATRIX_KEY(0x07, 0x08, KEY_P)
|
||||
MATRIX_KEY(0x07, 0x09, KEY_O)
|
||||
MATRIX_KEY(0x07, 0x0b, KEY_UP)
|
||||
MATRIX_KEY(0x07, 0x0c, KEY_LEFT)
|
||||
>;
|
||||
};
|
||||
};
|
||||
1
u-boot/arch/sandbox/dts/include/dt-bindings
Symbolic link
1
u-boot/arch/sandbox/dts/include/dt-bindings
Symbolic link
@@ -0,0 +1 @@
|
||||
../../../../include/dt-bindings
|
||||
266
u-boot/arch/sandbox/dts/sandbox.dts
Normal file
266
u-boot/arch/sandbox/dts/sandbox.dts
Normal file
@@ -0,0 +1,266 @@
|
||||
/dts-v1/;
|
||||
|
||||
#define USB_CLASS_HUB 9
|
||||
|
||||
/ {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
|
||||
aliases {
|
||||
eth5 = "/eth@90000000";
|
||||
i2c0 = &i2c_0;
|
||||
pci0 = &pci;
|
||||
rtc0 = &rtc_0;
|
||||
};
|
||||
|
||||
chosen {
|
||||
stdout-path = "/serial";
|
||||
};
|
||||
|
||||
cros_ec: cros-ec@0 {
|
||||
reg = <0 0>;
|
||||
compatible = "google,cros-ec-sandbox";
|
||||
|
||||
/*
|
||||
* This describes the flash memory within the EC. Note
|
||||
* that the STM32L flash erases to 0, not 0xff.
|
||||
*/
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
flash@8000000 {
|
||||
reg = <0x08000000 0x20000>;
|
||||
erase-value = <0>;
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
|
||||
/* Information for sandbox */
|
||||
ro {
|
||||
reg = <0 0xf000>;
|
||||
};
|
||||
wp-ro {
|
||||
reg = <0xf000 0x1000>;
|
||||
};
|
||||
rw {
|
||||
reg = <0x10000 0x10000>;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
eth@10002000 {
|
||||
compatible = "sandbox,eth";
|
||||
reg = <0x10002000 0x1000>;
|
||||
fake-host-hwaddr = [00 00 66 44 22 00];
|
||||
};
|
||||
|
||||
eth@80000000 {
|
||||
compatible = "sandbox,eth-raw";
|
||||
reg = <0x80000000 0x1000>;
|
||||
host-raw-interface = "eth0";
|
||||
};
|
||||
|
||||
eth@90000000 {
|
||||
compatible = "sandbox,eth-raw";
|
||||
reg = <0x90000000 0x1000>;
|
||||
host-raw-interface = "lo";
|
||||
};
|
||||
|
||||
gpio_a: gpios@0 {
|
||||
gpio-controller;
|
||||
compatible = "sandbox,gpio";
|
||||
#gpio-cells = <1>;
|
||||
gpio-bank-name = "a";
|
||||
num-gpios = <20>;
|
||||
};
|
||||
|
||||
gpio_b: gpios@1 {
|
||||
gpio-controller;
|
||||
compatible = "sandbox,gpio";
|
||||
#gpio-cells = <2>;
|
||||
gpio-bank-name = "b";
|
||||
num-gpios = <10>;
|
||||
};
|
||||
|
||||
hexagon {
|
||||
compatible = "demo-simple";
|
||||
colour = "white";
|
||||
sides = <6>;
|
||||
};
|
||||
|
||||
i2c_0: i2c@0 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
reg = <0 0>;
|
||||
compatible = "sandbox,i2c";
|
||||
clock-frequency = <400000>;
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&pinctrl_i2c0>;
|
||||
eeprom@2c {
|
||||
reg = <0x2c>;
|
||||
compatible = "i2c-eeprom";
|
||||
emul {
|
||||
compatible = "sandbox,i2c-eeprom";
|
||||
sandbox,filename = "i2c.bin";
|
||||
sandbox,size = <128>;
|
||||
};
|
||||
};
|
||||
|
||||
rtc_0: rtc@43 {
|
||||
reg = <0x43>;
|
||||
compatible = "sandbox-rtc";
|
||||
emul {
|
||||
compatible = "sandbox,i2c-rtc";
|
||||
};
|
||||
};
|
||||
sandbox_pmic: sandbox_pmic {
|
||||
reg = <0x40>;
|
||||
};
|
||||
};
|
||||
|
||||
lcd {
|
||||
u-boot,dm-pre-reloc;
|
||||
compatible = "sandbox,lcd-sdl";
|
||||
xres = <1366>;
|
||||
yres = <768>;
|
||||
};
|
||||
|
||||
pci: pci-controller {
|
||||
compatible = "sandbox,pci";
|
||||
device_type = "pci";
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
ranges = <0x02000000 0 0x10000000 0x10000000 0 0x2000
|
||||
0x01000000 0 0x20000000 0x20000000 0 0x2000>;
|
||||
pci@1f,0 {
|
||||
compatible = "pci-generic";
|
||||
reg = <0xf800 0 0 0 0>;
|
||||
emul@1f,0 {
|
||||
compatible = "sandbox,swap-case";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
pinctrl {
|
||||
compatible = "sandbox,pinctrl";
|
||||
|
||||
pinctrl_i2c0: i2c0 {
|
||||
groups = "i2c";
|
||||
function = "i2c";
|
||||
bias-pull-up;
|
||||
};
|
||||
|
||||
pinctrl_serial0: uart0 {
|
||||
groups = "serial_a";
|
||||
function = "serial";
|
||||
};
|
||||
};
|
||||
|
||||
reset@1 {
|
||||
compatible = "sandbox,reset";
|
||||
};
|
||||
|
||||
spi@0 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
reg = <0 0>;
|
||||
compatible = "sandbox,spi";
|
||||
cs-gpios = <0>, <&gpio_a 0>;
|
||||
firmware_storage_spi: flash@0 {
|
||||
reg = <0>;
|
||||
compatible = "spansion,m25p16", "sandbox,spi-flash";
|
||||
spi-max-frequency = <40000000>;
|
||||
sandbox,filename = "spi.bin";
|
||||
};
|
||||
};
|
||||
|
||||
square {
|
||||
compatible = "demo-shape";
|
||||
colour = "blue";
|
||||
sides = <4>;
|
||||
};
|
||||
|
||||
timer {
|
||||
compatible = "sandbox,timer";
|
||||
clock-frequency = <1000000>;
|
||||
};
|
||||
|
||||
tpm {
|
||||
compatible = "google,sandbox-tpm";
|
||||
};
|
||||
|
||||
triangle {
|
||||
compatible = "demo-shape";
|
||||
colour = "cyan";
|
||||
sides = <3>;
|
||||
character = <83>;
|
||||
light-gpios = <&gpio_a 2>, <&gpio_b 6 0>;
|
||||
};
|
||||
|
||||
/* Needs to be available prior to relocation */
|
||||
uart0: serial {
|
||||
compatible = "sandbox,serial";
|
||||
sandbox,text-colour = "cyan";
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&pinctrl_serial0>;
|
||||
};
|
||||
|
||||
usb@0 {
|
||||
compatible = "sandbox,usb";
|
||||
status = "disabled";
|
||||
hub {
|
||||
compatible = "sandbox,usb-hub";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
flash-stick {
|
||||
reg = <0>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
usb@1 {
|
||||
compatible = "sandbox,usb";
|
||||
hub {
|
||||
compatible = "usb-hub";
|
||||
usb,device-class = <USB_CLASS_HUB>;
|
||||
hub-emul {
|
||||
compatible = "sandbox,usb-hub";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
flash-stick {
|
||||
reg = <0>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
sandbox,filepath = "flash.bin";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
usb@2 {
|
||||
compatible = "sandbox,usb";
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
spmi: spmi@0 {
|
||||
compatible = "sandbox,spmi";
|
||||
#address-cells = <0x1>;
|
||||
#size-cells = <0x1>;
|
||||
pm8916@0 {
|
||||
compatible = "qcom,spmi-pmic";
|
||||
reg = <0x0 0x1>;
|
||||
#address-cells = <0x1>;
|
||||
#size-cells = <0x1>;
|
||||
|
||||
spmi_gpios: gpios@c000 {
|
||||
compatible = "qcom,pm8916-gpio";
|
||||
reg = <0xc000 0x400>;
|
||||
gpio-controller;
|
||||
gpio-count = <4>;
|
||||
#gpio-cells = <2>;
|
||||
gpio-bank-name="spmi";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
#include "cros-ec-keyboard.dtsi"
|
||||
#include "sandbox_pmic.dtsi"
|
||||
78
u-boot/arch/sandbox/dts/sandbox_pmic.dtsi
Normal file
78
u-boot/arch/sandbox/dts/sandbox_pmic.dtsi
Normal file
@@ -0,0 +1,78 @@
|
||||
/*
|
||||
* Sandbox PMIC dts node
|
||||
*
|
||||
* Copyright (C) 2015 Samsung Electronics
|
||||
* Przemyslaw Marczak <p.marczak@samsung.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <dt-bindings/pmic/sandbox_pmic.h>
|
||||
|
||||
&sandbox_pmic {
|
||||
compatible = "sandbox,pmic";
|
||||
|
||||
pmic_emul {
|
||||
compatible = "sandbox,i2c-pmic";
|
||||
|
||||
/*
|
||||
* Default PMICs register values are set by macro
|
||||
* VAL2REG(min, step, value) [uV/uA]
|
||||
* VAL2OMREG(mode id)
|
||||
* reg-defaults - byte array
|
||||
*/
|
||||
reg-defaults = /bits/ 8 <
|
||||
/* BUCK1 */
|
||||
VAL2REG(800000, 25000, 1000000)
|
||||
VAL2REG(150000, 25000, 150000)
|
||||
VAL2OMREG(BUCK_OM_OFF)
|
||||
/* BUCK2 */
|
||||
VAL2REG(750000, 50000, 3000000)
|
||||
VAL2REG(150000, 25000, 150000)
|
||||
VAL2OMREG(0)
|
||||
/* LDO1 */
|
||||
VAL2REG(800000, 25000, 1600000)
|
||||
VAL2REG(100000, 50000, 150000)
|
||||
VAL2OMREG(LDO_OM_OFF)
|
||||
/* LDO2 */
|
||||
VAL2REG(750000, 50000, 3000000)
|
||||
VAL2REG(150000, 25000, 150000)
|
||||
VAL2OMREG(0)
|
||||
/* reg[12:15] - not used */
|
||||
0x00
|
||||
0x00
|
||||
0x00
|
||||
0x00
|
||||
>;
|
||||
};
|
||||
|
||||
buck1 {
|
||||
regulator-name = "SUPPLY_1.2V";
|
||||
regulator-min-microvolt = <1200000>;
|
||||
regulator-max-microvolt = <1200000>;
|
||||
regulator-min-microamp = <200000>;
|
||||
regulator-max-microamp = <200000>;
|
||||
regulator-always-on;
|
||||
};
|
||||
|
||||
buck2: buck2 {
|
||||
regulator-name = "SUPPLY_3.3V";
|
||||
regulator-min-microvolt = <3300000>;
|
||||
regulator-max-microvolt = <3300000>;
|
||||
};
|
||||
|
||||
ldo1 {
|
||||
regulator-name = "VDD_EMMC_1.8V";
|
||||
regulator-min-microvolt = <1800000>;
|
||||
regulator-max-microvolt = <1800000>;
|
||||
regulator-min-microamp = <100000>;
|
||||
regulator-max-microamp = <100000>;
|
||||
regulator-boot-on;
|
||||
};
|
||||
|
||||
ldo2 {
|
||||
regulator-name = "VDD_LCD_3.3V";
|
||||
regulator-min-microvolt = <3300000>;
|
||||
regulator-max-microvolt = <3300000>;
|
||||
};
|
||||
};
|
||||
413
u-boot/arch/sandbox/dts/test.dts
Normal file
413
u-boot/arch/sandbox/dts/test.dts
Normal file
@@ -0,0 +1,413 @@
|
||||
/dts-v1/;
|
||||
|
||||
/ {
|
||||
model = "sandbox";
|
||||
compatible = "sandbox";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
|
||||
aliases {
|
||||
console = &uart0;
|
||||
eth0 = "/eth@10002000";
|
||||
eth3 = ð_3;
|
||||
eth5 = ð_5;
|
||||
i2c0 = "/i2c@0";
|
||||
pci0 = &pci;
|
||||
remoteproc1 = &rproc_1;
|
||||
remoteproc2 = &rproc_2;
|
||||
rtc0 = &rtc_0;
|
||||
rtc1 = &rtc_1;
|
||||
spi0 = "/spi@0";
|
||||
testfdt6 = "/e-test";
|
||||
testbus3 = "/some-bus";
|
||||
testfdt0 = "/some-bus/c-test@0";
|
||||
testfdt1 = "/some-bus/c-test@1";
|
||||
testfdt3 = "/b-test";
|
||||
testfdt5 = "/some-bus/c-test@5";
|
||||
testfdt8 = "/a-test";
|
||||
usb0 = &usb_0;
|
||||
usb1 = &usb_1;
|
||||
usb2 = &usb_2;
|
||||
};
|
||||
|
||||
a-test {
|
||||
reg = <0 1>;
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
ping-expect = <0>;
|
||||
ping-add = <0>;
|
||||
u-boot,dm-pre-reloc;
|
||||
test-gpios = <&gpio_a 1>, <&gpio_a 4>, <&gpio_b 5 0 3 2 1>,
|
||||
<0>, <&gpio_a 12>;
|
||||
test2-gpios = <&gpio_a 1>, <&gpio_a 4>, <&gpio_b 6 1 3 2 1>,
|
||||
<&gpio_b 7 2 3 2 1>, <&gpio_b 8 4 3 2 1>,
|
||||
<&gpio_b 9 0xc 3 2 1>;
|
||||
};
|
||||
|
||||
junk {
|
||||
reg = <1 1>;
|
||||
compatible = "not,compatible";
|
||||
};
|
||||
|
||||
no-compatible {
|
||||
reg = <2 1>;
|
||||
};
|
||||
|
||||
b-test {
|
||||
reg = <3 1>;
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
ping-expect = <3>;
|
||||
ping-add = <3>;
|
||||
};
|
||||
|
||||
some-bus {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
compatible = "denx,u-boot-test-bus";
|
||||
reg = <3 1>;
|
||||
ping-expect = <4>;
|
||||
ping-add = <4>;
|
||||
c-test@5 {
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
reg = <5>;
|
||||
ping-expect = <5>;
|
||||
ping-add = <5>;
|
||||
};
|
||||
c-test@0 {
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
reg = <0>;
|
||||
ping-expect = <6>;
|
||||
ping-add = <6>;
|
||||
};
|
||||
c-test@1 {
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
reg = <1>;
|
||||
ping-expect = <7>;
|
||||
ping-add = <7>;
|
||||
};
|
||||
};
|
||||
|
||||
d-test {
|
||||
reg = <3 1>;
|
||||
ping-expect = <6>;
|
||||
ping-add = <6>;
|
||||
compatible = "google,another-fdt-test";
|
||||
};
|
||||
|
||||
e-test {
|
||||
reg = <3 1>;
|
||||
ping-expect = <6>;
|
||||
ping-add = <6>;
|
||||
compatible = "google,another-fdt-test";
|
||||
};
|
||||
|
||||
f-test {
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
};
|
||||
|
||||
g-test {
|
||||
compatible = "denx,u-boot-fdt-test";
|
||||
};
|
||||
|
||||
clk_fixed: clk-fixed {
|
||||
compatible = "fixed-clock";
|
||||
#clock-cells = <0>;
|
||||
clock-frequency = <1234>;
|
||||
};
|
||||
|
||||
clk_sandbox: clk-sbox {
|
||||
compatible = "sandbox,clk";
|
||||
#clock-cells = <1>;
|
||||
};
|
||||
|
||||
clk-test {
|
||||
compatible = "sandbox,clk-test";
|
||||
clocks = <&clk_fixed>,
|
||||
<&clk_sandbox 1>,
|
||||
<&clk_sandbox 0>;
|
||||
clock-names = "fixed", "i2c", "spi";
|
||||
};
|
||||
|
||||
eth@10002000 {
|
||||
compatible = "sandbox,eth";
|
||||
reg = <0x10002000 0x1000>;
|
||||
fake-host-hwaddr = <0x00 0x00 0x66 0x44 0x22 0x00>;
|
||||
};
|
||||
|
||||
eth_5: eth@10003000 {
|
||||
compatible = "sandbox,eth";
|
||||
reg = <0x10003000 0x1000>;
|
||||
fake-host-hwaddr = <0x00 0x00 0x66 0x44 0x22 0x11>;
|
||||
};
|
||||
|
||||
eth_3: sbe5 {
|
||||
compatible = "sandbox,eth";
|
||||
reg = <0x10005000 0x1000>;
|
||||
fake-host-hwaddr = <0x00 0x00 0x66 0x44 0x22 0x33>;
|
||||
};
|
||||
|
||||
eth@10004000 {
|
||||
compatible = "sandbox,eth";
|
||||
reg = <0x10004000 0x1000>;
|
||||
fake-host-hwaddr = <0x00 0x00 0x66 0x44 0x22 0x22>;
|
||||
};
|
||||
|
||||
gpio_a: base-gpios {
|
||||
compatible = "sandbox,gpio";
|
||||
gpio-controller;
|
||||
#gpio-cells = <1>;
|
||||
gpio-bank-name = "a";
|
||||
num-gpios = <20>;
|
||||
};
|
||||
|
||||
gpio_b: extra-gpios {
|
||||
compatible = "sandbox,gpio";
|
||||
gpio-controller;
|
||||
#gpio-cells = <5>;
|
||||
gpio-bank-name = "b";
|
||||
num-gpios = <10>;
|
||||
};
|
||||
|
||||
i2c@0 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
reg = <0 1>;
|
||||
compatible = "sandbox,i2c";
|
||||
clock-frequency = <100000>;
|
||||
eeprom@2c {
|
||||
reg = <0x2c>;
|
||||
compatible = "i2c-eeprom";
|
||||
emul {
|
||||
compatible = "sandbox,i2c-eeprom";
|
||||
sandbox,filename = "i2c.bin";
|
||||
sandbox,size = <256>;
|
||||
};
|
||||
};
|
||||
|
||||
rtc_0: rtc@43 {
|
||||
reg = <0x43>;
|
||||
compatible = "sandbox-rtc";
|
||||
emul {
|
||||
compatible = "sandbox,i2c-rtc";
|
||||
};
|
||||
};
|
||||
|
||||
rtc_1: rtc@61 {
|
||||
reg = <0x61>;
|
||||
compatible = "sandbox-rtc";
|
||||
emul {
|
||||
compatible = "sandbox,i2c-rtc";
|
||||
};
|
||||
};
|
||||
|
||||
sandbox_pmic: sandbox_pmic {
|
||||
reg = <0x40>;
|
||||
};
|
||||
};
|
||||
|
||||
adc@0 {
|
||||
compatible = "sandbox,adc";
|
||||
vdd-supply = <&buck2>;
|
||||
vss-microvolts = <0>;
|
||||
};
|
||||
|
||||
lcd {
|
||||
u-boot,dm-pre-reloc;
|
||||
compatible = "sandbox,lcd-sdl";
|
||||
xres = <1366>;
|
||||
yres = <768>;
|
||||
};
|
||||
|
||||
leds {
|
||||
compatible = "gpio-leds";
|
||||
|
||||
iracibble {
|
||||
gpios = <&gpio_a 1 0>;
|
||||
label = "sandbox:red";
|
||||
};
|
||||
|
||||
martinet {
|
||||
gpios = <&gpio_a 2 0>;
|
||||
label = "sandbox:green";
|
||||
};
|
||||
};
|
||||
|
||||
mbox: mbox {
|
||||
compatible = "sandbox,mbox";
|
||||
#mbox-cells = <1>;
|
||||
};
|
||||
|
||||
mbox-test {
|
||||
compatible = "sandbox,mbox-test";
|
||||
mboxes = <&mbox 100>, <&mbox 1>;
|
||||
mbox-names = "other", "test";
|
||||
};
|
||||
|
||||
mmc {
|
||||
compatible = "sandbox,mmc";
|
||||
};
|
||||
|
||||
pci: pci-controller {
|
||||
compatible = "sandbox,pci";
|
||||
device_type = "pci";
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
ranges = <0x02000000 0 0x10000000 0x10000000 0 0x2000
|
||||
0x01000000 0 0x20000000 0x20000000 0 0x2000>;
|
||||
pci@1f,0 {
|
||||
compatible = "pci-generic";
|
||||
reg = <0xf800 0 0 0 0>;
|
||||
emul@1f,0 {
|
||||
compatible = "sandbox,swap-case";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
ram {
|
||||
compatible = "sandbox,ram";
|
||||
};
|
||||
|
||||
reset@0 {
|
||||
compatible = "sandbox,warm-reset";
|
||||
};
|
||||
|
||||
reset@1 {
|
||||
compatible = "sandbox,reset";
|
||||
};
|
||||
|
||||
resetc: reset-ctl {
|
||||
compatible = "sandbox,reset-ctl";
|
||||
#reset-cells = <1>;
|
||||
};
|
||||
|
||||
reset-ctl-test {
|
||||
compatible = "sandbox,reset-ctl-test";
|
||||
resets = <&resetc 100>, <&resetc 2>;
|
||||
reset-names = "other", "test";
|
||||
};
|
||||
|
||||
rproc_1: rproc@1 {
|
||||
compatible = "sandbox,test-processor";
|
||||
remoteproc-name = "remoteproc-test-dev1";
|
||||
};
|
||||
|
||||
rproc_2: rproc@2 {
|
||||
compatible = "sandbox,test-processor";
|
||||
internal-memory-mapped;
|
||||
remoteproc-name = "remoteproc-test-dev2";
|
||||
};
|
||||
|
||||
spi@0 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
reg = <0 1>;
|
||||
compatible = "sandbox,spi";
|
||||
cs-gpios = <0>, <&gpio_a 0>;
|
||||
spi.bin@0 {
|
||||
reg = <0>;
|
||||
compatible = "spansion,m25p16", "spi-flash";
|
||||
spi-max-frequency = <40000000>;
|
||||
sandbox,filename = "spi.bin";
|
||||
};
|
||||
};
|
||||
|
||||
syscon@0 {
|
||||
compatible = "sandbox,syscon0";
|
||||
reg = <0x10 4>;
|
||||
};
|
||||
|
||||
syscon@1 {
|
||||
compatible = "sandbox,syscon1";
|
||||
reg = <0x20 5
|
||||
0x28 6
|
||||
0x30 7
|
||||
0x38 8>;
|
||||
};
|
||||
|
||||
timer {
|
||||
compatible = "sandbox,timer";
|
||||
clock-frequency = <1000000>;
|
||||
};
|
||||
|
||||
uart0: serial {
|
||||
compatible = "sandbox,serial";
|
||||
u-boot,dm-pre-reloc;
|
||||
};
|
||||
|
||||
usb_0: usb@0 {
|
||||
compatible = "sandbox,usb";
|
||||
status = "disabled";
|
||||
hub {
|
||||
compatible = "sandbox,usb-hub";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
flash-stick {
|
||||
reg = <0>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
usb_1: usb@1 {
|
||||
compatible = "sandbox,usb";
|
||||
hub {
|
||||
compatible = "usb-hub";
|
||||
usb,device-class = <9>;
|
||||
hub-emul {
|
||||
compatible = "sandbox,usb-hub";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
flash-stick@0 {
|
||||
reg = <0>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
sandbox,filepath = "testflash.bin";
|
||||
};
|
||||
|
||||
flash-stick@1 {
|
||||
reg = <1>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
sandbox,filepath = "testflash1.bin";
|
||||
};
|
||||
|
||||
flash-stick@2 {
|
||||
reg = <2>;
|
||||
compatible = "sandbox,usb-flash";
|
||||
sandbox,filepath = "testflash2.bin";
|
||||
};
|
||||
|
||||
keyb@3 {
|
||||
reg = <3>;
|
||||
compatible = "sandbox,usb-keyb";
|
||||
};
|
||||
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
usb_2: usb@2 {
|
||||
compatible = "sandbox,usb";
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
spmi: spmi@0 {
|
||||
compatible = "sandbox,spmi";
|
||||
#address-cells = <0x1>;
|
||||
#size-cells = <0x1>;
|
||||
pm8916@0 {
|
||||
compatible = "qcom,spmi-pmic";
|
||||
reg = <0x0 0x1>;
|
||||
#address-cells = <0x1>;
|
||||
#size-cells = <0x1>;
|
||||
|
||||
spmi_gpios: gpios@c000 {
|
||||
compatible = "qcom,pm8916-gpio";
|
||||
reg = <0xc000 0x400>;
|
||||
gpio-controller;
|
||||
gpio-count = <4>;
|
||||
#gpio-cells = <2>;
|
||||
gpio-bank-name="spmi";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
#include "sandbox_pmic.dtsi"
|
||||
169
u-boot/arch/sandbox/include/asm/bitops.h
Normal file
169
u-boot/arch/sandbox/include/asm/bitops.h
Normal file
@@ -0,0 +1,169 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* Modified from Linux arch/arm/include/asm/bitops.h
|
||||
*
|
||||
* Copyright 1995, Russell King.
|
||||
* Various bits and pieces copyrights include:
|
||||
* Linus Torvalds (test_bit).
|
||||
*
|
||||
* bit 0 is the LSB of addr; bit 32 is the LSB of (addr+1).
|
||||
*
|
||||
* Please note that the code in this file should never be included
|
||||
* from user space. Many of these are not implemented in assembler
|
||||
* since they would be too costly. Also, they require priviledged
|
||||
* instructions (which are not available from user mode) to ensure
|
||||
* that they are atomic.
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_BITOPS_H
|
||||
#define __ASM_SANDBOX_BITOPS_H
|
||||
|
||||
#include <linux/compiler.h>
|
||||
#include <asm/system.h>
|
||||
#include <asm-generic/bitops/fls.h>
|
||||
#include <asm-generic/bitops/__fls.h>
|
||||
#include <asm-generic/bitops/fls64.h>
|
||||
#include <asm-generic/bitops/__ffs.h>
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
#define smp_mb__before_clear_bit() do { } while (0)
|
||||
#define smp_mb__after_clear_bit() do { } while (0)
|
||||
|
||||
/*
|
||||
* Function prototypes to keep gcc -Wall happy.
|
||||
*/
|
||||
extern void set_bit(int nr, void *addr);
|
||||
|
||||
extern void clear_bit(int nr, void *addr);
|
||||
|
||||
extern void change_bit(int nr, void *addr);
|
||||
|
||||
static inline void __change_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long mask = BIT_MASK(nr);
|
||||
unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
|
||||
|
||||
*p ^= mask;
|
||||
}
|
||||
|
||||
static inline int __test_and_set_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long mask = BIT_MASK(nr);
|
||||
unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
|
||||
unsigned long old = *p;
|
||||
|
||||
*p = old | mask;
|
||||
return (old & mask) != 0;
|
||||
}
|
||||
|
||||
static inline int test_and_set_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long __always_unused flags;
|
||||
int out;
|
||||
|
||||
local_irq_save(flags);
|
||||
out = __test_and_set_bit(nr, addr);
|
||||
local_irq_restore(flags);
|
||||
|
||||
return out;
|
||||
}
|
||||
|
||||
static inline int __test_and_clear_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long mask = BIT_MASK(nr);
|
||||
unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
|
||||
unsigned long old = *p;
|
||||
|
||||
*p = old & ~mask;
|
||||
return (old & mask) != 0;
|
||||
}
|
||||
|
||||
static inline int test_and_clear_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long __always_unused flags;
|
||||
int out;
|
||||
|
||||
local_irq_save(flags);
|
||||
out = __test_and_clear_bit(nr, addr);
|
||||
local_irq_restore(flags);
|
||||
|
||||
return out;
|
||||
}
|
||||
|
||||
extern int test_and_change_bit(int nr, void *addr);
|
||||
|
||||
static inline int __test_and_change_bit(int nr, void *addr)
|
||||
{
|
||||
unsigned long mask = BIT_MASK(nr);
|
||||
unsigned long *p = ((unsigned long *)addr) + BIT_WORD(nr);
|
||||
unsigned long old = *p;
|
||||
|
||||
*p = old ^ mask;
|
||||
return (old & mask) != 0;
|
||||
}
|
||||
|
||||
extern int find_first_zero_bit(void *addr, unsigned size);
|
||||
extern int find_next_zero_bit(void *addr, int size, int offset);
|
||||
|
||||
/*
|
||||
* This routine doesn't need to be atomic.
|
||||
*/
|
||||
static inline int test_bit(int nr, const void *addr)
|
||||
{
|
||||
return ((unsigned char *) addr)[nr >> 3] & (1U << (nr & 7));
|
||||
}
|
||||
|
||||
/*
|
||||
* ffz = Find First Zero in word. Undefined if no zero exists,
|
||||
* so code should check against ~0UL first..
|
||||
*/
|
||||
static inline unsigned long ffz(unsigned long word)
|
||||
{
|
||||
int k;
|
||||
|
||||
word = ~word;
|
||||
k = 31;
|
||||
if (word & 0x0000ffff) {
|
||||
k -= 16; word <<= 16;
|
||||
}
|
||||
if (word & 0x00ff0000) {
|
||||
k -= 8; word <<= 8;
|
||||
}
|
||||
if (word & 0x0f000000) {
|
||||
k -= 4; word <<= 4;
|
||||
}
|
||||
if (word & 0x30000000) {
|
||||
k -= 2; word <<= 2;
|
||||
}
|
||||
if (word & 0x40000000)
|
||||
k -= 1;
|
||||
return k;
|
||||
}
|
||||
|
||||
/*
|
||||
* hweightN: returns the hamming weight (i.e. the number
|
||||
* of bits set) of a N-bit word
|
||||
*/
|
||||
|
||||
#define hweight32(x) generic_hweight32(x)
|
||||
#define hweight16(x) generic_hweight16(x)
|
||||
#define hweight8(x) generic_hweight8(x)
|
||||
|
||||
#define ext2_set_bit test_and_set_bit
|
||||
#define ext2_clear_bit test_and_clear_bit
|
||||
#define ext2_test_bit test_bit
|
||||
#define ext2_find_first_zero_bit find_first_zero_bit
|
||||
#define ext2_find_next_zero_bit find_next_zero_bit
|
||||
|
||||
/* Bitmap functions for the minix filesystem. */
|
||||
#define minix_test_and_set_bit(nr, addr) test_and_set_bit(nr, addr)
|
||||
#define minix_set_bit(nr, addr) set_bit(nr, addr)
|
||||
#define minix_test_and_clear_bit(nr, addr) test_and_clear_bit(nr, addr)
|
||||
#define minix_test_bit(nr, addr) test_bit(nr, addr)
|
||||
#define minix_find_first_zero_bit(addr, size) find_first_zero_bit(addr, size)
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#endif /* _ARM_BITOPS_H */
|
||||
24
u-boot/arch/sandbox/include/asm/byteorder.h
Normal file
24
u-boot/arch/sandbox/include/asm/byteorder.h
Normal file
@@ -0,0 +1,24 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_BYTEORDER_H
|
||||
#define __ASM_SANDBOX_BYTEORDER_H
|
||||
|
||||
|
||||
#include <asm/types.h>
|
||||
|
||||
#if !defined(__STRICT_ANSI__) || defined(__KERNEL__)
|
||||
# define __BYTEORDER_HAS_U64__
|
||||
# define __SWAB_64_THRU_32__
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_SANDBOX_BIG_ENDIAN
|
||||
#include <linux/byteorder/big_endian.h>
|
||||
#else
|
||||
#include <linux/byteorder/little_endian.h>
|
||||
#endif
|
||||
|
||||
#endif
|
||||
25
u-boot/arch/sandbox/include/asm/cache.h
Normal file
25
u-boot/arch/sandbox/include/asm/cache.h
Normal file
@@ -0,0 +1,25 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_CACHE_H__
|
||||
#define __SANDBOX_CACHE_H__
|
||||
|
||||
/*
|
||||
* For native compilation of the sandbox we should still align
|
||||
* the contents of stack buffers to something reasonable. The
|
||||
* GCC macro __BIGGEST_ALIGNMENT__ is defined to be the maximum
|
||||
* required alignment for any basic type. This seems reasonable.
|
||||
* This is however GCC specific so if we don't have that available
|
||||
* assume that 16 is large enough.
|
||||
*/
|
||||
#ifdef __BIGGEST_ALIGNMENT__
|
||||
#define ARCH_DMA_MINALIGN __BIGGEST_ALIGNMENT__
|
||||
#else
|
||||
#define ARCH_DMA_MINALIGN 16
|
||||
#endif
|
||||
#define CONFIG_SYS_CACHELINE_SIZE ARCH_DMA_MINALIGN
|
||||
|
||||
#endif /* __SANDBOX_CACHE_H__ */
|
||||
111
u-boot/arch/sandbox/include/asm/clk.h
Normal file
111
u-boot/arch/sandbox/include/asm/clk.h
Normal file
@@ -0,0 +1,111 @@
|
||||
/*
|
||||
* Copyright (c) 2016, NVIDIA CORPORATION.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_CLK_H
|
||||
#define __SANDBOX_CLK_H
|
||||
|
||||
#include <common.h>
|
||||
|
||||
struct udevice;
|
||||
|
||||
/**
|
||||
* enum sandbox_clk_id - Identity of clocks implemented by the sandbox clock
|
||||
* provider.
|
||||
*
|
||||
* These IDs are within/relative-to the clock provider.
|
||||
*/
|
||||
enum sandbox_clk_id {
|
||||
SANDBOX_CLK_ID_SPI,
|
||||
SANDBOX_CLK_ID_I2C,
|
||||
|
||||
SANDBOX_CLK_ID_COUNT,
|
||||
};
|
||||
|
||||
/**
|
||||
* enum sandbox_clk_test_id - Identity of the clocks consumed by the sandbox
|
||||
* clock test device.
|
||||
*
|
||||
* These are the IDs the clock consumer knows the clocks as.
|
||||
*/
|
||||
enum sandbox_clk_test_id {
|
||||
SANDBOX_CLK_TEST_ID_FIXED,
|
||||
SANDBOX_CLK_TEST_ID_SPI,
|
||||
SANDBOX_CLK_TEST_ID_I2C,
|
||||
|
||||
SANDBOX_CLK_TEST_ID_COUNT,
|
||||
};
|
||||
|
||||
/**
|
||||
* sandbox_clk_query_rate - Query the current rate of a sandbox clock.
|
||||
*
|
||||
* @dev: The sandbox clock provider device.
|
||||
* @id: The clock to query.
|
||||
* @return: The rate of the clock.
|
||||
*/
|
||||
ulong sandbox_clk_query_rate(struct udevice *dev, int id);
|
||||
/**
|
||||
* sandbox_clk_query_enable - Query the enable state of a sandbox clock.
|
||||
*
|
||||
* @dev: The sandbox clock provider device.
|
||||
* @id: The clock to query.
|
||||
* @return: The rate of the clock.
|
||||
*/
|
||||
int sandbox_clk_query_enable(struct udevice *dev, int id);
|
||||
|
||||
/**
|
||||
* sandbox_clk_test_get - Ask the sandbox clock test device to request its
|
||||
* clocks.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @return: 0 if OK, or a negative error code.
|
||||
*/
|
||||
int sandbox_clk_test_get(struct udevice *dev);
|
||||
/**
|
||||
* sandbox_clk_test_get_rate - Ask the sandbox clock test device to query a
|
||||
* clock's rate.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @id: The test device's clock ID to query.
|
||||
* @return: The rate of the clock.
|
||||
*/
|
||||
ulong sandbox_clk_test_get_rate(struct udevice *dev, int id);
|
||||
/**
|
||||
* sandbox_clk_test_set_rate - Ask the sandbox clock test device to set a
|
||||
* clock's rate.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @id: The test device's clock ID to configure.
|
||||
* @return: The new rate of the clock.
|
||||
*/
|
||||
ulong sandbox_clk_test_set_rate(struct udevice *dev, int id, ulong rate);
|
||||
/**
|
||||
* sandbox_clk_test_enable - Ask the sandbox clock test device to enable a
|
||||
* clock.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @id: The test device's clock ID to configure.
|
||||
* @return: 0 if OK, or a negative error code.
|
||||
*/
|
||||
int sandbox_clk_test_enable(struct udevice *dev, int id);
|
||||
/**
|
||||
* sandbox_clk_test_disable - Ask the sandbox clock test device to disable a
|
||||
* clock.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @id: The test device's clock ID to configure.
|
||||
* @return: 0 if OK, or a negative error code.
|
||||
*/
|
||||
int sandbox_clk_test_disable(struct udevice *dev, int id);
|
||||
/**
|
||||
* sandbox_clk_test_free - Ask the sandbox clock test device to free its
|
||||
* clocks.
|
||||
*
|
||||
* @dev: The sandbox clock test (client) devivce.
|
||||
* @return: 0 if OK, or a negative error code.
|
||||
*/
|
||||
int sandbox_clk_test_free(struct udevice *dev);
|
||||
|
||||
#endif
|
||||
20
u-boot/arch/sandbox/include/asm/config.h
Normal file
20
u-boot/arch/sandbox/include/asm/config.h
Normal file
@@ -0,0 +1,20 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef _ASM_CONFIG_H_
|
||||
#define _ASM_CONFIG_H_
|
||||
|
||||
#define CONFIG_SANDBOX_ARCH
|
||||
|
||||
/* Used by drivers/spi/sandbox_spi.c and arch/sandbox/include/asm/state.h */
|
||||
#ifndef CONFIG_SANDBOX_SPI_MAX_BUS
|
||||
#define CONFIG_SANDBOX_SPI_MAX_BUS 1
|
||||
#endif
|
||||
#ifndef CONFIG_SANDBOX_SPI_MAX_CS
|
||||
#define CONFIG_SANDBOX_SPI_MAX_CS 10
|
||||
#endif
|
||||
|
||||
#endif
|
||||
1
u-boot/arch/sandbox/include/asm/errno.h
Normal file
1
u-boot/arch/sandbox/include/asm/errno.h
Normal file
@@ -0,0 +1 @@
|
||||
#include <asm-generic/errno.h>
|
||||
40
u-boot/arch/sandbox/include/asm/eth-raw-os.h
Normal file
40
u-boot/arch/sandbox/include/asm/eth-raw-os.h
Normal file
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Copyright (c) 2015 National Instruments
|
||||
*
|
||||
* (C) Copyright 2015
|
||||
* Joe Hershberger <joe.hershberger@ni.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#ifndef __ETH_RAW_OS_H
|
||||
#define __ETH_RAW_OS_H
|
||||
|
||||
/**
|
||||
* struct eth_sandbox_raw_priv - raw socket session
|
||||
*
|
||||
* sd: socket descriptor - the open socket during a session
|
||||
* device: struct sockaddr_ll - the host interface packets move to/from
|
||||
* local: 1 or 0 to select the local interface ('lo') or not
|
||||
* local_bindsd: socket descriptor to prevent the kernel from sending
|
||||
* a message to the server claiming the port is
|
||||
* unreachable
|
||||
* local_bind_udp_port: The UDP port number that we bound to
|
||||
*/
|
||||
struct eth_sandbox_raw_priv {
|
||||
int sd;
|
||||
void *device;
|
||||
int local;
|
||||
int local_bind_sd;
|
||||
unsigned short local_bind_udp_port;
|
||||
};
|
||||
|
||||
int sandbox_eth_raw_os_start(const char *ifname, unsigned char *ethmac,
|
||||
struct eth_sandbox_raw_priv *priv);
|
||||
int sandbox_eth_raw_os_send(void *packet, int length,
|
||||
struct eth_sandbox_raw_priv *priv);
|
||||
int sandbox_eth_raw_os_recv(void *packet, int *length,
|
||||
const struct eth_sandbox_raw_priv *priv);
|
||||
void sandbox_eth_raw_os_stop(struct eth_sandbox_raw_priv *priv);
|
||||
|
||||
#endif /* __ETH_RAW_OS_H */
|
||||
17
u-boot/arch/sandbox/include/asm/eth.h
Normal file
17
u-boot/arch/sandbox/include/asm/eth.h
Normal file
@@ -0,0 +1,17 @@
|
||||
/*
|
||||
* Copyright (c) 2015 National Instruments
|
||||
*
|
||||
* (C) Copyright 2015
|
||||
* Joe Hershberger <joe.hershberger@ni.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#ifndef __ETH_H
|
||||
#define __ETH_H
|
||||
|
||||
void sandbox_eth_disable_response(int index, bool disable);
|
||||
|
||||
void sandbox_eth_skip_timeout(void);
|
||||
|
||||
#endif /* __ETH_H */
|
||||
72
u-boot/arch/sandbox/include/asm/getopt.h
Normal file
72
u-boot/arch/sandbox/include/asm/getopt.h
Normal file
@@ -0,0 +1,72 @@
|
||||
/*
|
||||
* Code for setting up command line flags like `./u-boot --help`
|
||||
*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* Licensed under the GPL-2 or later.
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_GETOPT_H
|
||||
#define __SANDBOX_GETOPT_H
|
||||
|
||||
struct sandbox_state;
|
||||
|
||||
/*
|
||||
* Internal structure for storing details about the flag.
|
||||
* Most people should not have to dig around in this as
|
||||
* it only gets parsed by the core sandbox code. End
|
||||
* consumer code should focus on the macros below and
|
||||
* the callback function.
|
||||
*/
|
||||
struct sandbox_cmdline_option {
|
||||
/* The long flag name: "help" for "--help" */
|
||||
const char *flag;
|
||||
/* The (optional) short flag name: "h" for "-h" */
|
||||
int flag_short;
|
||||
/* The help string shown to the user when processing --help */
|
||||
const char *help;
|
||||
/* Whether this flag takes an argument */
|
||||
int has_arg;
|
||||
/* Callback into the end consumer code with the option */
|
||||
int (*callback)(struct sandbox_state *state, const char *opt);
|
||||
};
|
||||
|
||||
/*
|
||||
* Internal macro to expand the lower macros into the necessary
|
||||
* magic junk that makes this all work.
|
||||
*/
|
||||
#define _SANDBOX_CMDLINE_OPT(f, s, ha, h) \
|
||||
static struct sandbox_cmdline_option sandbox_cmdline_option_##f = { \
|
||||
.flag = #f, \
|
||||
.flag_short = s, \
|
||||
.help = h, \
|
||||
.has_arg = ha, \
|
||||
.callback = sandbox_cmdline_cb_##f, \
|
||||
}; \
|
||||
/* Ppointer to the struct in a special section for the linker script */ \
|
||||
static __attribute__((section(".u_boot_sandbox_getopt"), used)) \
|
||||
struct sandbox_cmdline_option \
|
||||
*sandbox_cmdline_option_##f##_ptr = \
|
||||
&sandbox_cmdline_option_##f
|
||||
|
||||
/**
|
||||
* Macros for end code to declare new command line flags.
|
||||
*
|
||||
* @param f The long flag name e.g. help
|
||||
* @param ha Does the flag have an argument e.g. 0/1
|
||||
* @param h The help string displayed when showing --help
|
||||
*
|
||||
* This invocation:
|
||||
* SANDBOX_CMDLINE_OPT(foo, 0, "The foo arg");
|
||||
* Will create a new flag named "--foo" (no short option) that takes
|
||||
* no argument. If the user specifies "--foo", then the callback func
|
||||
* sandbox_cmdline_cb_foo() will automatically be called.
|
||||
*/
|
||||
#define SANDBOX_CMDLINE_OPT(f, ha, h) _SANDBOX_CMDLINE_OPT(f, 0, ha, h)
|
||||
/*
|
||||
* Same as above, but @s is used to specify a short flag e.g.
|
||||
* SANDBOX_CMDLINE_OPT(foo, 'f', 0, "The foo arg");
|
||||
*/
|
||||
#define SANDBOX_CMDLINE_OPT_SHORT(f, s, ha, h) _SANDBOX_CMDLINE_OPT(f, s, ha, h)
|
||||
|
||||
#endif
|
||||
22
u-boot/arch/sandbox/include/asm/global_data.h
Normal file
22
u-boot/arch/sandbox/include/asm/global_data.h
Normal file
@@ -0,0 +1,22 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* (C) Copyright 2002-2010
|
||||
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_GBL_DATA_H
|
||||
#define __ASM_GBL_DATA_H
|
||||
|
||||
/* Architecture-specific global data */
|
||||
struct arch_global_data {
|
||||
uint8_t *ram_buf; /* emulated RAM buffer */
|
||||
};
|
||||
|
||||
#include <asm-generic/global_data.h>
|
||||
|
||||
#define DECLARE_GLOBAL_DATA_PTR extern gd_t *gd
|
||||
|
||||
#endif /* __ASM_GBL_DATA_H */
|
||||
85
u-boot/arch/sandbox/include/asm/gpio.h
Normal file
85
u-boot/arch/sandbox/include/asm/gpio.h
Normal file
@@ -0,0 +1,85 @@
|
||||
/*
|
||||
* This is the interface to the sandbox GPIO driver for test code which
|
||||
* wants to change the GPIO values reported to U-Boot.
|
||||
*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_GPIO_H
|
||||
#define __ASM_SANDBOX_GPIO_H
|
||||
|
||||
/*
|
||||
* We use the generic interface, and add a back-channel.
|
||||
*
|
||||
* The back-channel functions are declared in this file. They should not be used
|
||||
* except in test code.
|
||||
*
|
||||
* Test code can, for example, call sandbox_gpio_set_value() to set the value of
|
||||
* a simulated GPIO. From then on, normal code in U-Boot will see this new
|
||||
* value when it calls gpio_get_value().
|
||||
*
|
||||
* NOTE: DO NOT use the functions in this file except in test code!
|
||||
*/
|
||||
#include <asm-generic/gpio.h>
|
||||
|
||||
/**
|
||||
* Return the simulated value of a GPIO (used only in sandbox test code)
|
||||
*
|
||||
* @param dev device to use
|
||||
* @param offset GPIO offset within bank
|
||||
* @return -1 on error, 0 if GPIO is low, >0 if high
|
||||
*/
|
||||
int sandbox_gpio_get_value(struct udevice *dev, unsigned int offset);
|
||||
|
||||
/**
|
||||
* Set the simulated value of a GPIO (used only in sandbox test code)
|
||||
*
|
||||
* @param dev device to use
|
||||
* @param offset GPIO offset within bank
|
||||
* @param value value to set (0 for low, non-zero for high)
|
||||
* @return -1 on error, 0 if ok
|
||||
*/
|
||||
int sandbox_gpio_set_value(struct udevice *dev, unsigned int offset, int value);
|
||||
|
||||
/**
|
||||
* Set or reset the simulated open drain mode of a GPIO (used only in sandbox
|
||||
* test code)
|
||||
*
|
||||
* @param gp GPIO number
|
||||
* @param value value to set (0 for enabled open drain mode, non-zero for
|
||||
* disabled)
|
||||
* @return -1 on error, 0 if ok
|
||||
*/
|
||||
int sandbox_gpio_set_open_drain(struct udevice *dev, unsigned offset, int value);
|
||||
|
||||
/**
|
||||
* Return the state of the simulated open drain mode of a GPIO (used only in
|
||||
* sandbox test code)
|
||||
*
|
||||
* @param gp GPIO number
|
||||
* @return -1 on error, 0 if GPIO is input, >0 if output
|
||||
*/
|
||||
int sandbox_gpio_get_open_drain(struct udevice *dev, unsigned offset);
|
||||
|
||||
/**
|
||||
* Return the simulated direction of a GPIO (used only in sandbox test code)
|
||||
*
|
||||
* @param dev device to use
|
||||
* @param offset GPIO offset within bank
|
||||
* @return -1 on error, 0 if GPIO is input, >0 if output
|
||||
*/
|
||||
int sandbox_gpio_get_direction(struct udevice *dev, unsigned int offset);
|
||||
|
||||
/**
|
||||
* Set the simulated direction of a GPIO (used only in sandbox test code)
|
||||
*
|
||||
* @param dev device to use
|
||||
* @param offset GPIO offset within bank
|
||||
* @param output 0 to set as input, 1 to set as output
|
||||
* @return -1 on error, 0 if ok
|
||||
*/
|
||||
int sandbox_gpio_set_direction(struct udevice *dev, unsigned int offset,
|
||||
int output);
|
||||
|
||||
#endif
|
||||
77
u-boot/arch/sandbox/include/asm/io.h
Normal file
77
u-boot/arch/sandbox/include/asm/io.h
Normal file
@@ -0,0 +1,77 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_ASM_IO_H
|
||||
#define __SANDBOX_ASM_IO_H
|
||||
|
||||
/*
|
||||
* Given a physical address and a length, return a virtual address
|
||||
* that can be used to access the memory range with the caching
|
||||
* properties specified by "flags".
|
||||
*/
|
||||
#define MAP_NOCACHE (0)
|
||||
#define MAP_WRCOMBINE (0)
|
||||
#define MAP_WRBACK (0)
|
||||
#define MAP_WRTHROUGH (0)
|
||||
|
||||
void *map_physmem(phys_addr_t paddr, unsigned long len, unsigned long flags);
|
||||
|
||||
/*
|
||||
* Take down a mapping set up by map_physmem().
|
||||
*/
|
||||
void unmap_physmem(const void *vaddr, unsigned long flags);
|
||||
|
||||
/* For sandbox, we want addresses to point into our RAM buffer */
|
||||
static inline void *map_sysmem(phys_addr_t paddr, unsigned long len)
|
||||
{
|
||||
return map_physmem(paddr, len, MAP_WRBACK);
|
||||
}
|
||||
|
||||
/* Remove a previous mapping */
|
||||
static inline void unmap_sysmem(const void *vaddr)
|
||||
{
|
||||
unmap_physmem(vaddr, MAP_WRBACK);
|
||||
}
|
||||
|
||||
/* Map from a pointer to our RAM buffer */
|
||||
phys_addr_t map_to_sysmem(const void *ptr);
|
||||
|
||||
/* Define nops for sandbox I/O access */
|
||||
#define readb(addr) 0
|
||||
#define readw(addr) 0
|
||||
#define readl(addr) 0
|
||||
#define writeb(v, addr)
|
||||
#define writew(v, addr)
|
||||
#define writel(v, addr)
|
||||
|
||||
/* I/O access functions */
|
||||
int inl(unsigned int addr);
|
||||
int inw(unsigned int addr);
|
||||
int inb(unsigned int addr);
|
||||
|
||||
void outl(unsigned int value, unsigned int addr);
|
||||
void outw(unsigned int value, unsigned int addr);
|
||||
void outb(unsigned int value, unsigned int addr);
|
||||
|
||||
static inline void _insw(volatile u16 *port, void *buf, int ns)
|
||||
{
|
||||
}
|
||||
|
||||
static inline void _outsw(volatile u16 *port, const void *buf, int ns)
|
||||
{
|
||||
}
|
||||
|
||||
#define insw(port, buf, ns) _insw((u16 *)port, buf, ns)
|
||||
#define outsw(port, buf, ns) _outsw((u16 *)port, buf, ns)
|
||||
|
||||
/* For systemace.c */
|
||||
#define out16(addr, val)
|
||||
#define in16(addr) 0
|
||||
|
||||
#include <iotrace.h>
|
||||
#include <asm/types.h>
|
||||
|
||||
#endif
|
||||
21
u-boot/arch/sandbox/include/asm/mbox.h
Normal file
21
u-boot/arch/sandbox/include/asm/mbox.h
Normal file
@@ -0,0 +1,21 @@
|
||||
/*
|
||||
* Copyright (c) 2016, NVIDIA CORPORATION.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_MBOX_H
|
||||
#define __SANDBOX_MBOX_H
|
||||
|
||||
#include <common.h>
|
||||
|
||||
#define SANDBOX_MBOX_PING_XOR 0x12345678
|
||||
|
||||
struct udevice;
|
||||
|
||||
int sandbox_mbox_test_get(struct udevice *dev);
|
||||
int sandbox_mbox_test_send(struct udevice *dev, uint32_t msg);
|
||||
int sandbox_mbox_test_recv(struct udevice *dev, uint32_t *msg);
|
||||
int sandbox_mbox_test_free(struct udevice *dev);
|
||||
|
||||
#endif
|
||||
57
u-boot/arch/sandbox/include/asm/posix_types.h
Normal file
57
u-boot/arch/sandbox/include/asm/posix_types.h
Normal file
@@ -0,0 +1,57 @@
|
||||
/*
|
||||
* linux/include/asm-arm/posix_types.h
|
||||
*
|
||||
* Copyright (C) 1996-1998 Russell King.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* Changelog:
|
||||
* 27-06-1996 RMK Created
|
||||
*/
|
||||
#ifndef __ARCH_ARM_POSIX_TYPES_H
|
||||
#define __ARCH_ARM_POSIX_TYPES_H
|
||||
|
||||
/*
|
||||
* This file is generally used by user-level software, so you need to
|
||||
* be a little careful about namespace pollution etc. Also, we cannot
|
||||
* assume GCC is being used.
|
||||
*/
|
||||
|
||||
typedef unsigned short __kernel_dev_t;
|
||||
typedef unsigned long __kernel_ino_t;
|
||||
typedef unsigned short __kernel_mode_t;
|
||||
typedef unsigned short __kernel_nlink_t;
|
||||
typedef long __kernel_off_t;
|
||||
typedef int __kernel_pid_t;
|
||||
typedef unsigned short __kernel_ipc_pid_t;
|
||||
typedef unsigned short __kernel_uid_t;
|
||||
typedef unsigned short __kernel_gid_t;
|
||||
#if CONFIG_SANDBOX_BITS_PER_LONG == 32
|
||||
typedef unsigned int __kernel_size_t;
|
||||
typedef int __kernel_ssize_t;
|
||||
typedef int __kernel_ptrdiff_t;
|
||||
#else
|
||||
typedef unsigned long __kernel_size_t;
|
||||
typedef long __kernel_ssize_t;
|
||||
typedef long __kernel_ptrdiff_t;
|
||||
#endif
|
||||
typedef long __kernel_time_t;
|
||||
typedef long __kernel_suseconds_t;
|
||||
typedef long __kernel_clock_t;
|
||||
typedef int __kernel_daddr_t;
|
||||
typedef char *__kernel_caddr_t;
|
||||
typedef unsigned short __kernel_uid16_t;
|
||||
typedef unsigned short __kernel_gid16_t;
|
||||
typedef unsigned int __kernel_uid32_t;
|
||||
typedef unsigned int __kernel_gid32_t;
|
||||
|
||||
typedef unsigned short __kernel_old_uid_t;
|
||||
typedef unsigned short __kernel_old_gid_t;
|
||||
|
||||
#ifdef __GNUC__
|
||||
typedef long long __kernel_loff_t;
|
||||
#endif
|
||||
|
||||
#endif
|
||||
12
u-boot/arch/sandbox/include/asm/processor.h
Normal file
12
u-boot/arch/sandbox/include/asm/processor.h
Normal file
@@ -0,0 +1,12 @@
|
||||
/*
|
||||
* Copyright (c) 2014 Google, Inc
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef _ASM_PROCESSOR_H
|
||||
#define _ASM_PROCESSOR_H
|
||||
|
||||
/* This file is required for PCI */
|
||||
|
||||
#endif
|
||||
22
u-boot/arch/sandbox/include/asm/ptrace.h
Normal file
22
u-boot/arch/sandbox/include/asm/ptrace.h
Normal file
@@ -0,0 +1,22 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_PTRACE_H
|
||||
#define __ASM_SANDBOX_PTRACE_H
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
/* This is not used in the sandbox architecture, but required by U-Boot */
|
||||
struct pt_regs {
|
||||
};
|
||||
|
||||
#ifdef __KERNEL__
|
||||
extern void show_regs(struct pt_regs *);
|
||||
|
||||
#endif
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
#endif
|
||||
21
u-boot/arch/sandbox/include/asm/reset.h
Normal file
21
u-boot/arch/sandbox/include/asm/reset.h
Normal file
@@ -0,0 +1,21 @@
|
||||
/*
|
||||
* Copyright (c) 2016, NVIDIA CORPORATION.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_RESET_H
|
||||
#define __SANDBOX_RESET_H
|
||||
|
||||
#include <common.h>
|
||||
|
||||
struct udevice;
|
||||
|
||||
int sandbox_reset_query(struct udevice *dev, unsigned long id);
|
||||
|
||||
int sandbox_reset_test_get(struct udevice *dev);
|
||||
int sandbox_reset_test_assert(struct udevice *dev);
|
||||
int sandbox_reset_test_deassert(struct udevice *dev);
|
||||
int sandbox_reset_test_free(struct udevice *dev);
|
||||
|
||||
#endif
|
||||
28
u-boot/arch/sandbox/include/asm/rtc.h
Normal file
28
u-boot/arch/sandbox/include/asm/rtc.h
Normal file
@@ -0,0 +1,28 @@
|
||||
/*
|
||||
* Simulate an I2C real time clock
|
||||
*
|
||||
* Copyright (c) 2015 Google, Inc
|
||||
* Written by Simon Glass <sjg@chromium.org>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __asm_rtc_h
|
||||
#define __asm_rtc_h
|
||||
|
||||
/* Register numbers in the sandbox RTC */
|
||||
enum {
|
||||
REG_SEC = 5,
|
||||
REG_MIN,
|
||||
REG_HOUR,
|
||||
REG_MDAY,
|
||||
REG_MON,
|
||||
REG_YEAR,
|
||||
REG_WDAY,
|
||||
|
||||
REG_RESET = 0x20,
|
||||
|
||||
REG_COUNT = 0x80,
|
||||
};
|
||||
|
||||
#endif
|
||||
118
u-boot/arch/sandbox/include/asm/sdl.h
Normal file
118
u-boot/arch/sandbox/include/asm/sdl.h
Normal file
@@ -0,0 +1,118 @@
|
||||
/*
|
||||
* Copyright (c) 2013 Google, Inc
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_SDL_H
|
||||
#define __SANDBOX_SDL_H
|
||||
|
||||
#include <errno.h>
|
||||
|
||||
#ifdef CONFIG_SANDBOX_SDL
|
||||
|
||||
/**
|
||||
* sandbox_sdl_init_display() - Set up SDL video ready for use
|
||||
*
|
||||
* @width: Window width in pixels
|
||||
* @height Window height in pixels
|
||||
* @log2_bpp: Log to base 2 of the number of bits per pixel. So a 32bpp
|
||||
* display will pass 5, since 2*5 = 32
|
||||
* @return 0 if OK, -ENODEV if no device, -EIO if SDL failed to initialize
|
||||
* and -EPERM if the video failed to come up.
|
||||
*/
|
||||
int sandbox_sdl_init_display(int width, int height, int log2_bpp);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_sync() - Sync current U-Boot LCD frame buffer to SDL
|
||||
*
|
||||
* This must be called periodically to update the screen for SDL so that the
|
||||
* user can see it.
|
||||
*
|
||||
* @lcd_base: Base of frame buffer
|
||||
* @return 0 if screen was updated, -ENODEV is there is no screen.
|
||||
*/
|
||||
int sandbox_sdl_sync(void *lcd_base);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_scan_keys() - scan for pressed keys
|
||||
*
|
||||
* Works out which keys are pressed and returns a list
|
||||
*
|
||||
* @key: Array to receive keycodes
|
||||
* @max_keys: Size of array
|
||||
* @return number of keycodes found, 0 if none, -ENODEV if no keyboard
|
||||
*/
|
||||
int sandbox_sdl_scan_keys(int key[], int max_keys);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_key_pressed() - check if a particular key is pressed
|
||||
*
|
||||
* @keycode: Keycode to check (KEY_... - see include/linux/input.h
|
||||
* @return 0 if pressed, -ENOENT if not pressed. -ENODEV if keybord not
|
||||
* available,
|
||||
*/
|
||||
int sandbox_sdl_key_pressed(int keycode);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_sound_start() - start playing a sound
|
||||
*
|
||||
* @frequency: Frequency of sounds in Hertz
|
||||
* @return 0 if OK, -ENODEV if no sound is available
|
||||
*/
|
||||
int sandbox_sdl_sound_start(uint frequency);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_sound_stop() - stop playing a sound
|
||||
*
|
||||
* @return 0 if OK, -ENODEV if no sound is available
|
||||
*/
|
||||
int sandbox_sdl_sound_stop(void);
|
||||
|
||||
/**
|
||||
* sandbox_sdl_sound_init() - set up the sound system
|
||||
*
|
||||
* @return 0 if OK, -ENODEV if no sound is available
|
||||
*/
|
||||
int sandbox_sdl_sound_init(void);
|
||||
|
||||
#else
|
||||
static inline int sandbox_sdl_init_display(int width, int height,
|
||||
int log2_bpp)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_sync(void *lcd_base)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_scan_keys(int key[], int max_keys)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_key_pressed(int keycode)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_sound_start(uint frequency)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_sound_stop(void)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
static inline int sandbox_sdl_sound_init(void)
|
||||
{
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
24
u-boot/arch/sandbox/include/asm/sections.h
Normal file
24
u-boot/arch/sandbox/include/asm/sections.h
Normal file
@@ -0,0 +1,24 @@
|
||||
/*
|
||||
* decls for symbols defined in the linker script
|
||||
*
|
||||
* Copyright (c) 2012 The Chromium OS Authors.
|
||||
*
|
||||
* Licensed under the GPL-2 or later.
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_SECTIONS_H
|
||||
#define __SANDBOX_SECTIONS_H
|
||||
|
||||
#include <asm-generic/sections.h>
|
||||
|
||||
struct sandbox_cmdline_option;
|
||||
|
||||
extern struct sandbox_cmdline_option *__u_boot_sandbox_option_start[],
|
||||
*__u_boot_sandbox_option_end[];
|
||||
|
||||
static inline size_t __u_boot_sandbox_option_count(void)
|
||||
{
|
||||
return __u_boot_sandbox_option_end - __u_boot_sandbox_option_start;
|
||||
}
|
||||
|
||||
#endif
|
||||
14
u-boot/arch/sandbox/include/asm/sound.h
Normal file
14
u-boot/arch/sandbox/include/asm/sound.h
Normal file
@@ -0,0 +1,14 @@
|
||||
/*
|
||||
* Copyright (c) 2013 Google, Inc
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_SOUND_H
|
||||
#define __SANDBOX_SOUND_H
|
||||
|
||||
int sound_play(unsigned int msec, unsigned int frequency);
|
||||
|
||||
int sound_init(const void *blob);
|
||||
|
||||
#endif
|
||||
45
u-boot/arch/sandbox/include/asm/spi.h
Normal file
45
u-boot/arch/sandbox/include/asm/spi.h
Normal file
@@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Simulate a SPI port and clients (see README.sandbox for details)
|
||||
*
|
||||
* Copyright (c) 2011-2013 The Chromium OS Authors.
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* Licensed under the GPL-2 or later.
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SPI_H__
|
||||
#define __ASM_SPI_H__
|
||||
|
||||
#include <linux/types.h>
|
||||
|
||||
/*
|
||||
* The interface between the SPI bus and the SPI client. The bus will
|
||||
* instantiate a client, and that then call into it via these entry
|
||||
* points. These should be enough for the client to emulate the SPI
|
||||
* device just like the real hardware.
|
||||
*/
|
||||
struct sandbox_spi_emu_ops {
|
||||
/* The bus wants to instantiate a new client, so setup everything */
|
||||
int (*setup)(void **priv, const char *spec);
|
||||
/* The bus is done with us, so break things down */
|
||||
void (*free)(void *priv);
|
||||
/* The CS has been "activated" -- we won't worry about low/high */
|
||||
void (*cs_activate)(void *priv);
|
||||
/* The CS has been "deactivated" -- we won't worry about low/high */
|
||||
void (*cs_deactivate)(void *priv);
|
||||
/* The client is rx-ing bytes from the bus, so it should tx some */
|
||||
int (*xfer)(void *priv, const u8 *rx, u8 *tx, uint bytes);
|
||||
};
|
||||
|
||||
/*
|
||||
* Extract the bus/cs from the spi spec and return the start of the spi
|
||||
* client spec. If the bus/cs are invalid for the current config, then
|
||||
* it returns NULL.
|
||||
*
|
||||
* Example: arg="0:1:foo" will set bus to 0, cs to 1, and return "foo"
|
||||
*/
|
||||
const char *sandbox_spi_parse_spec(const char *arg, unsigned long *bus,
|
||||
unsigned long *cs);
|
||||
|
||||
#endif
|
||||
220
u-boot/arch/sandbox/include/asm/state.h
Normal file
220
u-boot/arch/sandbox/include/asm/state.h
Normal file
@@ -0,0 +1,220 @@
|
||||
/*
|
||||
* Copyright (c) 2011-2012 The Chromium OS Authors.
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __SANDBOX_STATE_H
|
||||
#define __SANDBOX_STATE_H
|
||||
|
||||
#include <config.h>
|
||||
#include <sysreset.h>
|
||||
#include <stdbool.h>
|
||||
#include <linux/stringify.h>
|
||||
|
||||
/**
|
||||
* Selects the behavior of the serial terminal.
|
||||
*
|
||||
* If Ctrl-C is processed by U-Boot, then the only way to quit sandbox is with
|
||||
* the 'reset' command, or equivalent.
|
||||
*
|
||||
* If the terminal is cooked, then Ctrl-C will terminate U-Boot, and the
|
||||
* command line will not be quite such a faithful emulation.
|
||||
*
|
||||
* Options are:
|
||||
*
|
||||
* raw-with-sigs - Raw, but allow signals (Ctrl-C will quit)
|
||||
* raw - Terminal is always raw
|
||||
* cooked - Terminal is always cooked
|
||||
*/
|
||||
enum state_terminal_raw {
|
||||
STATE_TERM_RAW_WITH_SIGS, /* Default */
|
||||
STATE_TERM_RAW,
|
||||
STATE_TERM_COOKED,
|
||||
|
||||
STATE_TERM_COUNT,
|
||||
};
|
||||
|
||||
struct sandbox_spi_info {
|
||||
const char *spec;
|
||||
struct udevice *emul;
|
||||
};
|
||||
|
||||
/* The complete state of the test system */
|
||||
struct sandbox_state {
|
||||
const char *cmd; /* Command to execute */
|
||||
bool interactive; /* Enable cmdline after execute */
|
||||
bool run_distro_boot; /* Automatically run distro bootcommands */
|
||||
const char *fdt_fname; /* Filename of FDT binary */
|
||||
const char *parse_err; /* Error to report from parsing */
|
||||
int argc; /* Program arguments */
|
||||
char **argv; /* Command line arguments */
|
||||
const char *jumped_fname; /* Jumped from previous U_Boot */
|
||||
uint8_t *ram_buf; /* Emulated RAM buffer */
|
||||
unsigned int ram_size; /* Size of RAM buffer */
|
||||
const char *ram_buf_fname; /* Filename to use for RAM buffer */
|
||||
bool ram_buf_rm; /* Remove RAM buffer file after read */
|
||||
bool write_ram_buf; /* Write RAM buffer on exit */
|
||||
const char *state_fname; /* File containing sandbox state */
|
||||
void *state_fdt; /* Holds saved state for sandbox */
|
||||
bool read_state; /* Read sandbox state on startup */
|
||||
bool write_state; /* Write sandbox state on exit */
|
||||
bool ignore_missing_state_on_read; /* No error if state missing */
|
||||
bool show_lcd; /* Show LCD on start-up */
|
||||
enum sysreset_t last_sysreset; /* Last system reset type */
|
||||
bool sysreset_allowed[SYSRESET_COUNT]; /* Allowed system reset types */
|
||||
enum state_terminal_raw term_raw; /* Terminal raw/cooked */
|
||||
bool skip_delays; /* Ignore any time delays (for test) */
|
||||
bool show_test_output; /* Don't suppress stdout in tests */
|
||||
|
||||
/* Pointer to information for each SPI bus/cs */
|
||||
struct sandbox_spi_info spi[CONFIG_SANDBOX_SPI_MAX_BUS]
|
||||
[CONFIG_SANDBOX_SPI_MAX_CS];
|
||||
};
|
||||
|
||||
/* Minimum space we guarantee in the state FDT when calling read/write*/
|
||||
#define SANDBOX_STATE_MIN_SPACE 0x1000
|
||||
|
||||
/**
|
||||
* struct sandbox_state_io - methods to saved/restore sandbox state
|
||||
* @name: Name of of the device tree node, also the name of the variable
|
||||
* holding this data so it should be an identifier (use underscore
|
||||
* instead of minus)
|
||||
* @compat: Compatible string for the node containing this state
|
||||
*
|
||||
* @read: Function to read state from FDT
|
||||
* If data is available, then blob and node will provide access to it. If
|
||||
* not (blob == NULL and node == -1) this function should set up an empty
|
||||
* data set for start-of-day.
|
||||
* @param blob: Pointer to device tree blob, or NULL if no data to read
|
||||
* @param node: Node offset to read from
|
||||
* @return 0 if OK, -ve on error
|
||||
*
|
||||
* @write: Function to write state to FDT
|
||||
* The caller will ensure that there is a node ready for the state. The
|
||||
* node may already contain the old state, in which case it should be
|
||||
* overridden. There is guaranteed to be SANDBOX_STATE_MIN_SPACE bytes
|
||||
* of free space, so error checking is not required for fdt_setprop...()
|
||||
* calls which add up to less than this much space.
|
||||
*
|
||||
* For adding larger properties, use state_setprop().
|
||||
*
|
||||
* @param blob: Device tree blob holding state
|
||||
* @param node: Node to write our state into
|
||||
*
|
||||
* Note that it is possible to save data as large blobs or as individual
|
||||
* hierarchical properties. However, unless you intend to keep state files
|
||||
* around for a long time and be able to run an old state file on a new
|
||||
* sandbox, it might not be worth using individual properties for everything.
|
||||
* This is certainly supported, it is just a matter of the effort you wish
|
||||
* to put into the state read/write feature.
|
||||
*/
|
||||
struct sandbox_state_io {
|
||||
const char *name;
|
||||
const char *compat;
|
||||
int (*write)(void *blob, int node);
|
||||
int (*read)(const void *blob, int node);
|
||||
};
|
||||
|
||||
/**
|
||||
* SANDBOX_STATE_IO - Declare sandbox state to read/write
|
||||
*
|
||||
* Sandbox permits saving state from one run and restoring it in another. This
|
||||
* allows the test system to retain state between runs and thus better
|
||||
* emulate a real system. Examples of state that might be useful to save are
|
||||
* the emulated GPIOs pin settings, flash memory contents and TPM private
|
||||
* data. U-Boot memory contents is dealth with separately since it is large
|
||||
* and it is not normally useful to save it (since a normal system does not
|
||||
* preserve DRAM between runs). See the '-m' option for this.
|
||||
*
|
||||
* See struct sandbox_state_io above for member documentation.
|
||||
*/
|
||||
#define SANDBOX_STATE_IO(_name, _compat, _read, _write) \
|
||||
ll_entry_declare(struct sandbox_state_io, _name, state_io) = { \
|
||||
.name = __stringify(_name), \
|
||||
.read = _read, \
|
||||
.write = _write, \
|
||||
.compat = _compat, \
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets a pointer to the current state.
|
||||
*
|
||||
* @return pointer to state
|
||||
*/
|
||||
struct sandbox_state *state_get_current(void);
|
||||
|
||||
/**
|
||||
* Read the sandbox state from the supplied device tree file
|
||||
*
|
||||
* This calls all registered state handlers to read in the sandbox state
|
||||
* from a previous test run.
|
||||
*
|
||||
* @param state Sandbox state to update
|
||||
* @param fname Filename of device tree file to read from
|
||||
* @return 0 if OK, -ve on error
|
||||
*/
|
||||
int sandbox_read_state(struct sandbox_state *state, const char *fname);
|
||||
|
||||
/**
|
||||
* Write the sandbox state to the supplied device tree file
|
||||
*
|
||||
* This calls all registered state handlers to write out the sandbox state
|
||||
* so that it can be preserved for a future test run.
|
||||
*
|
||||
* If the file exists it is overwritten.
|
||||
*
|
||||
* @param state Sandbox state to update
|
||||
* @param fname Filename of device tree file to write to
|
||||
* @return 0 if OK, -ve on error
|
||||
*/
|
||||
int sandbox_write_state(struct sandbox_state *state, const char *fname);
|
||||
|
||||
/**
|
||||
* Add a property to a sandbox state node
|
||||
*
|
||||
* This is equivalent to fdt_setprop except that it automatically enlarges
|
||||
* the device tree if necessary. That means it is safe to write any amount
|
||||
* of data here.
|
||||
*
|
||||
* This function can only be called from within struct sandbox_state_io's
|
||||
* ->write method, i.e. within state I/O drivers.
|
||||
*
|
||||
* @param node Device tree node to write to
|
||||
* @param prop_name Property to write
|
||||
* @param data Data to write into property
|
||||
* @param size Size of data to write into property
|
||||
*/
|
||||
int state_setprop(int node, const char *prop_name, const void *data, int size);
|
||||
|
||||
/**
|
||||
* Control skipping of time delays
|
||||
*
|
||||
* Some tests have unnecessay time delays (e.g. USB). Allow these to be
|
||||
* skipped to speed up testing
|
||||
*
|
||||
* @param skip_delays true to skip delays from now on, false to honour delay
|
||||
* requests
|
||||
*/
|
||||
void state_set_skip_delays(bool skip_delays);
|
||||
|
||||
/**
|
||||
* See if delays should be skipped
|
||||
*
|
||||
* @return true if delays should be skipped, false if they should be honoured
|
||||
*/
|
||||
bool state_get_skip_delays(void);
|
||||
|
||||
/**
|
||||
* Initialize the test system state
|
||||
*/
|
||||
int state_init(void);
|
||||
|
||||
/**
|
||||
* Uninitialize the test system state, writing out state if configured to
|
||||
* do so.
|
||||
*
|
||||
* @return 0 if OK, -ve on error
|
||||
*/
|
||||
int state_uninit(void);
|
||||
|
||||
#endif
|
||||
7
u-boot/arch/sandbox/include/asm/string.h
Normal file
7
u-boot/arch/sandbox/include/asm/string.h
Normal file
@@ -0,0 +1,7 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <linux/string.h>
|
||||
17
u-boot/arch/sandbox/include/asm/system.h
Normal file
17
u-boot/arch/sandbox/include/asm/system.h
Normal file
@@ -0,0 +1,17 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_SYSTEM_H
|
||||
#define __ASM_SANDBOX_SYSTEM_H
|
||||
|
||||
/* Define this as nops for sandbox architecture */
|
||||
#define local_irq_save(x)
|
||||
#define local_irq_enable()
|
||||
#define local_irq_disable()
|
||||
#define local_save_flags(x)
|
||||
#define local_irq_restore(x)
|
||||
|
||||
#endif
|
||||
82
u-boot/arch/sandbox/include/asm/test.h
Normal file
82
u-boot/arch/sandbox/include/asm/test.h
Normal file
@@ -0,0 +1,82 @@
|
||||
/*
|
||||
* Test-related constants for sandbox
|
||||
*
|
||||
* Copyright (c) 2014 Google, Inc
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_TEST_H
|
||||
#define __ASM_TEST_H
|
||||
|
||||
/* The sandbox driver always permits an I2C device with this address */
|
||||
#define SANDBOX_I2C_TEST_ADDR 0x59
|
||||
|
||||
#define SANDBOX_PCI_VENDOR_ID 0x1234
|
||||
#define SANDBOX_PCI_DEVICE_ID 0x5678
|
||||
#define SANDBOX_PCI_CLASS_CODE PCI_CLASS_CODE_COMM
|
||||
#define SANDBOX_PCI_CLASS_SUB_CODE PCI_CLASS_SUB_CODE_COMM_SERIAL
|
||||
|
||||
#define SANDBOX_CLK_RATE 32768
|
||||
|
||||
/* System controller driver data */
|
||||
enum {
|
||||
SYSCON0 = 32,
|
||||
SYSCON1,
|
||||
|
||||
SYSCON_COUNT
|
||||
};
|
||||
|
||||
/**
|
||||
* sandbox_i2c_set_test_mode() - set test mode for running unit tests
|
||||
*
|
||||
* See sandbox_i2c_xfer() for the behaviour changes.
|
||||
*
|
||||
* @bus: sandbox I2C bus to adjust
|
||||
* @test_mode: true to select test mode, false to run normally
|
||||
*/
|
||||
void sandbox_i2c_set_test_mode(struct udevice *bus, bool test_mode);
|
||||
|
||||
enum sandbox_i2c_eeprom_test_mode {
|
||||
SIE_TEST_MODE_NONE,
|
||||
/* Permits read/write of only one byte per I2C transaction */
|
||||
SIE_TEST_MODE_SINGLE_BYTE,
|
||||
};
|
||||
|
||||
void sandbox_i2c_eeprom_set_test_mode(struct udevice *dev,
|
||||
enum sandbox_i2c_eeprom_test_mode mode);
|
||||
|
||||
void sandbox_i2c_eeprom_set_offset_len(struct udevice *dev, int offset_len);
|
||||
|
||||
/*
|
||||
* sandbox_timer_add_offset()
|
||||
*
|
||||
* Allow tests to add to the time reported through lib/time.c functions
|
||||
* offset: number of milliseconds to advance the system time
|
||||
*/
|
||||
void sandbox_timer_add_offset(unsigned long offset);
|
||||
|
||||
/**
|
||||
* sandbox_i2c_rtc_set_offset() - set the time offset from system/base time
|
||||
*
|
||||
* @dev: RTC device to adjust
|
||||
* @use_system_time: true to use system time, false to use @base_time
|
||||
* @offset: RTC offset from current system/base time (-1 for no
|
||||
* change)
|
||||
* @return old value of RTC offset
|
||||
*/
|
||||
long sandbox_i2c_rtc_set_offset(struct udevice *dev, bool use_system_time,
|
||||
int offset);
|
||||
|
||||
/**
|
||||
* sandbox_i2c_rtc_get_set_base_time() - get and set the base time
|
||||
*
|
||||
* @dev: RTC device to adjust
|
||||
* @base_time: New base system time (set to -1 for no change)
|
||||
* @return old base time
|
||||
*/
|
||||
long sandbox_i2c_rtc_get_set_base_time(struct udevice *dev, long base_time);
|
||||
|
||||
int sandbox_usb_keyb_add_string(struct udevice *dev, const char *str);
|
||||
|
||||
#endif
|
||||
61
u-boot/arch/sandbox/include/asm/types.h
Normal file
61
u-boot/arch/sandbox/include/asm/types.h
Normal file
@@ -0,0 +1,61 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __ASM_SANDBOX_TYPES_H
|
||||
#define __ASM_SANDBOX_TYPES_H
|
||||
|
||||
typedef unsigned short umode_t;
|
||||
|
||||
/*
|
||||
* __xx is ok: it doesn't pollute the POSIX namespace. Use these in the
|
||||
* header files exported to user space
|
||||
*/
|
||||
|
||||
typedef __signed__ char __s8;
|
||||
typedef unsigned char __u8;
|
||||
|
||||
typedef __signed__ short __s16;
|
||||
typedef unsigned short __u16;
|
||||
|
||||
typedef __signed__ int __s32;
|
||||
typedef unsigned int __u32;
|
||||
|
||||
#if defined(__GNUC__)
|
||||
__extension__ typedef __signed__ long long __s64;
|
||||
__extension__ typedef unsigned long long __u64;
|
||||
#endif
|
||||
|
||||
/*
|
||||
* These aren't exported outside the kernel to avoid name space clashes
|
||||
*/
|
||||
#ifdef __KERNEL__
|
||||
|
||||
typedef signed char s8;
|
||||
typedef unsigned char u8;
|
||||
|
||||
typedef signed short s16;
|
||||
typedef unsigned short u16;
|
||||
|
||||
typedef signed int s32;
|
||||
typedef unsigned int u32;
|
||||
|
||||
#if !defined(CONFIG_USE_STDINT) || !defined(__INT64_TYPE__)
|
||||
typedef signed long long s64;
|
||||
typedef unsigned long long u64;
|
||||
#else
|
||||
typedef __INT64_TYPE__ s64;
|
||||
typedef __UINT64_TYPE__ u64;
|
||||
#endif
|
||||
|
||||
#define BITS_PER_LONG CONFIG_SANDBOX_BITS_PER_LONG
|
||||
|
||||
typedef unsigned long dma_addr_t;
|
||||
typedef u32 phys_addr_t;
|
||||
typedef u32 phys_size_t;
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#endif
|
||||
89
u-boot/arch/sandbox/include/asm/u-boot-sandbox.h
Normal file
89
u-boot/arch/sandbox/include/asm/u-boot-sandbox.h
Normal file
@@ -0,0 +1,89 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* (C) Copyright 2002
|
||||
* Sysgo Real-Time Solutions, GmbH <www.elinos.com>
|
||||
* Marius Groeger <mgroeger@sysgo.de>
|
||||
*
|
||||
* (C) Copyright 2002
|
||||
* Sysgo Real-Time Solutions, GmbH <www.elinos.com>
|
||||
* Alex Zuepke <azu@sysgo.de>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef _U_BOOT_SANDBOX_H_
|
||||
#define _U_BOOT_SANDBOX_H_
|
||||
|
||||
/* board/.../... */
|
||||
int board_init(void);
|
||||
|
||||
/* start.c */
|
||||
int sandbox_early_getopt_check(void);
|
||||
int sandbox_main_loop_init(void);
|
||||
|
||||
int cleanup_before_linux(void);
|
||||
|
||||
/* drivers/video/sandbox_sdl.c */
|
||||
int sandbox_lcd_sdl_early_init(void);
|
||||
|
||||
/**
|
||||
* pci_map_physmem() - map a PCI device into memory
|
||||
*
|
||||
* This is used on sandbox to map a device into memory so that it can be
|
||||
* used with normal memory access. After this call, some part of the device's
|
||||
* internal structure becomes visible.
|
||||
*
|
||||
* This function is normally called from sandbox's map_sysmem() automatically.
|
||||
*
|
||||
* @paddr: Physical memory address, normally corresponding to a PCI BAR
|
||||
* @lenp: On entry, the size of the area to map, On exit it is updated
|
||||
* to the size actually mapped, which may be less if the device
|
||||
* has less space
|
||||
* @devp: Returns the device which mapped into this space
|
||||
* @ptrp: Returns a pointer to the mapped address. The device's space
|
||||
* can be accessed as @lenp bytes starting here
|
||||
* @return 0 if OK, -ve on error
|
||||
*/
|
||||
int pci_map_physmem(phys_addr_t paddr, unsigned long *lenp,
|
||||
struct udevice **devp, void **ptrp);
|
||||
|
||||
/**
|
||||
* pci_unmap_physmem() - undo a memory mapping
|
||||
*
|
||||
* This must be called after pci_map_physmem() to undo the mapping.
|
||||
*
|
||||
* @paddr: Physical memory address, as passed to pci_map_physmem()
|
||||
* @len: Size of area mapped, as returned by pci_map_physmem()
|
||||
* @dev: Device to unmap, as returned by pci_map_physmem()
|
||||
* @return 0 if OK, -ve on error
|
||||
*/
|
||||
int pci_unmap_physmem(const void *addr, unsigned long len,
|
||||
struct udevice *dev);
|
||||
|
||||
/**
|
||||
* sandbox_set_enable_pci_map() - Enable / disable PCI address mapping
|
||||
*
|
||||
* Since address mapping involves calling every driver, provide a way to
|
||||
* enable and disable this. It can be handled automatically by the emulator
|
||||
* uclass, which knows if any emulators are currently active.
|
||||
*
|
||||
* If this is disabled, pci_map_physmem() will not be called from
|
||||
* map_sysmem().
|
||||
*
|
||||
* @enable: 0 to disable, 1 to enable
|
||||
*/
|
||||
void sandbox_set_enable_pci_map(int enable);
|
||||
|
||||
/**
|
||||
* sandbox_read_fdt_from_file() - Read a device tree from a file
|
||||
*
|
||||
* Read a device tree file from a host file and set it up for use as the
|
||||
* control FDT.
|
||||
*/
|
||||
int sandbox_read_fdt_from_file(void);
|
||||
|
||||
/* Exit sandbox (quit U-Boot) */
|
||||
void sandbox_exit(void);
|
||||
|
||||
#endif /* _U_BOOT_SANDBOX_H_ */
|
||||
29
u-boot/arch/sandbox/include/asm/u-boot.h
Normal file
29
u-boot/arch/sandbox/include/asm/u-boot.h
Normal file
@@ -0,0 +1,29 @@
|
||||
/*
|
||||
* (C) Copyright 2002
|
||||
* Sysgo Real-Time Solutions, GmbH <www.elinos.com>
|
||||
* Marius Groeger <mgroeger@sysgo.de>
|
||||
*
|
||||
* (C) Copyright 2002
|
||||
* Sysgo Real-Time Solutions, GmbH <www.elinos.com>
|
||||
* Alex Zuepke <azu@sysgo.de>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*
|
||||
********************************************************************
|
||||
* NOTE: This header file defines an interface to U-Boot. Including
|
||||
* this (unmodified) header file in another file is considered normal
|
||||
* use of U-Boot, and does *not* fall under the heading of "derived
|
||||
* work".
|
||||
********************************************************************
|
||||
*/
|
||||
|
||||
#ifndef _U_BOOT_H_
|
||||
#define _U_BOOT_H_ 1
|
||||
|
||||
/* Use the generic board which requires a unified bd_info */
|
||||
#include <asm-generic/u-boot.h>
|
||||
|
||||
/* For image.h:image_check_target_arch() */
|
||||
#define IH_ARCH_DEFAULT IH_ARCH_SANDBOX
|
||||
|
||||
#endif /* _U_BOOT_H_ */
|
||||
7
u-boot/arch/sandbox/include/asm/unaligned.h
Normal file
7
u-boot/arch/sandbox/include/asm/unaligned.h
Normal file
@@ -0,0 +1,7 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <asm-generic/unaligned.h>
|
||||
12
u-boot/arch/sandbox/lib/Makefile
Normal file
12
u-boot/arch/sandbox/lib/Makefile
Normal file
@@ -0,0 +1,12 @@
|
||||
#
|
||||
# Copyright (c) 2011 The Chromium OS Authors.
|
||||
#
|
||||
# (C) Copyright 2002-2006
|
||||
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
obj-y += interrupts.o
|
||||
obj-$(CONFIG_PCI) += pci_io.o
|
||||
obj-$(CONFIG_CMD_BOOTM) += bootm.o
|
||||
63
u-boot/arch/sandbox/lib/bootm.c
Normal file
63
u-boot/arch/sandbox/lib/bootm.c
Normal file
@@ -0,0 +1,63 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
* Copyright (c) 2015 Sjoerd Simons <sjoerd.simons@collabora.co.uk>
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <asm/io.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
#define LINUX_ARM_ZIMAGE_MAGIC 0x016f2818
|
||||
|
||||
struct arm_z_header {
|
||||
uint32_t code[9];
|
||||
uint32_t zi_magic;
|
||||
uint32_t zi_start;
|
||||
uint32_t zi_end;
|
||||
} __attribute__ ((__packed__));
|
||||
|
||||
int bootz_setup(ulong image, ulong *start, ulong *end)
|
||||
{
|
||||
uint8_t *zimage = map_sysmem(image, 0);
|
||||
struct arm_z_header *arm_hdr = (struct arm_z_header *)zimage;
|
||||
int ret = 0;
|
||||
|
||||
if (memcmp(zimage + 0x202, "HdrS", 4) == 0) {
|
||||
uint8_t setup_sects = *(zimage + 0x1f1);
|
||||
uint32_t syssize =
|
||||
le32_to_cpu(*(uint32_t *)(zimage + 0x1f4));
|
||||
|
||||
*start = 0;
|
||||
*end = (setup_sects + 1) * 512 + syssize * 16;
|
||||
|
||||
printf("setting up X86 zImage [ %ld - %ld ]\n",
|
||||
*start, *end);
|
||||
} else if (le32_to_cpu(arm_hdr->zi_magic) == LINUX_ARM_ZIMAGE_MAGIC) {
|
||||
*start = le32_to_cpu(arm_hdr->zi_start);
|
||||
*end = le32_to_cpu(arm_hdr->zi_end);
|
||||
|
||||
printf("setting up ARM zImage [ %ld - %ld ]\n",
|
||||
*start, *end);
|
||||
} else {
|
||||
printf("Unrecognized zImage\n");
|
||||
ret = 1;
|
||||
}
|
||||
|
||||
unmap_sysmem((void *)image);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int do_bootm_linux(int flag, int argc, char *argv[], bootm_headers_t *images)
|
||||
{
|
||||
if (flag & (BOOTM_STATE_OS_GO | BOOTM_STATE_OS_FAKE_GO)) {
|
||||
bootstage_mark(BOOTSTAGE_ID_RUN_OS);
|
||||
printf("## Transferring control to Linux (at address %08lx)...\n",
|
||||
images->ep);
|
||||
reset_cpu(0);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
23
u-boot/arch/sandbox/lib/interrupts.c
Normal file
23
u-boot/arch/sandbox/lib/interrupts.c
Normal file
@@ -0,0 +1,23 @@
|
||||
/*
|
||||
* Copyright (c) 2011 The Chromium OS Authors.
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
|
||||
int interrupt_init(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void enable_interrupts(void)
|
||||
{
|
||||
return;
|
||||
}
|
||||
int disable_interrupts(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
138
u-boot/arch/sandbox/lib/pci_io.c
Normal file
138
u-boot/arch/sandbox/lib/pci_io.c
Normal file
@@ -0,0 +1,138 @@
|
||||
/*
|
||||
* Copyright (c) 2014 Google, Inc
|
||||
* Written by Simon Glass <sjg@chromium.org>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
/*
|
||||
* IO space access commands.
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <command.h>
|
||||
#include <dm.h>
|
||||
#include <asm/io.h>
|
||||
|
||||
int pci_map_physmem(phys_addr_t paddr, unsigned long *lenp,
|
||||
struct udevice **devp, void **ptrp)
|
||||
{
|
||||
struct udevice *dev;
|
||||
int ret;
|
||||
|
||||
*ptrp = 0;
|
||||
for (uclass_first_device(UCLASS_PCI_EMUL, &dev);
|
||||
dev;
|
||||
uclass_next_device(&dev)) {
|
||||
struct dm_pci_emul_ops *ops = pci_get_emul_ops(dev);
|
||||
|
||||
if (!ops || !ops->map_physmem)
|
||||
continue;
|
||||
ret = (ops->map_physmem)(dev, paddr, lenp, ptrp);
|
||||
if (ret)
|
||||
continue;
|
||||
*devp = dev;
|
||||
return 0;
|
||||
}
|
||||
|
||||
debug("%s: failed: addr=%x\n", __func__, paddr);
|
||||
return -ENOSYS;
|
||||
}
|
||||
|
||||
int pci_unmap_physmem(const void *vaddr, unsigned long len,
|
||||
struct udevice *dev)
|
||||
{
|
||||
struct dm_pci_emul_ops *ops = pci_get_emul_ops(dev);
|
||||
|
||||
if (!ops || !ops->unmap_physmem)
|
||||
return -ENOSYS;
|
||||
return (ops->unmap_physmem)(dev, vaddr, len);
|
||||
}
|
||||
|
||||
static int pci_io_read(unsigned int addr, ulong *valuep, pci_size_t size)
|
||||
{
|
||||
struct udevice *dev;
|
||||
int ret;
|
||||
|
||||
*valuep = pci_get_ff(size);
|
||||
for (uclass_first_device(UCLASS_PCI_EMUL, &dev);
|
||||
dev;
|
||||
uclass_next_device(&dev)) {
|
||||
struct dm_pci_emul_ops *ops = pci_get_emul_ops(dev);
|
||||
|
||||
if (ops && ops->read_io) {
|
||||
ret = (ops->read_io)(dev, addr, valuep, size);
|
||||
if (!ret)
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
debug("%s: failed: addr=%x\n", __func__, addr);
|
||||
return -ENOSYS;
|
||||
}
|
||||
|
||||
static int pci_io_write(unsigned int addr, ulong value, pci_size_t size)
|
||||
{
|
||||
struct udevice *dev;
|
||||
int ret;
|
||||
|
||||
for (uclass_first_device(UCLASS_PCI_EMUL, &dev);
|
||||
dev;
|
||||
uclass_next_device(&dev)) {
|
||||
struct dm_pci_emul_ops *ops = pci_get_emul_ops(dev);
|
||||
|
||||
if (ops && ops->write_io) {
|
||||
ret = (ops->write_io)(dev, addr, value, size);
|
||||
if (!ret)
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
debug("%s: failed: addr=%x, value=%lx\n", __func__, addr, value);
|
||||
return -ENOSYS;
|
||||
}
|
||||
|
||||
int inl(unsigned int addr)
|
||||
{
|
||||
unsigned long value;
|
||||
int ret;
|
||||
|
||||
ret = pci_io_read(addr, &value, PCI_SIZE_32);
|
||||
|
||||
return ret ? 0 : value;
|
||||
}
|
||||
|
||||
int inw(unsigned int addr)
|
||||
{
|
||||
unsigned long value;
|
||||
int ret;
|
||||
|
||||
ret = pci_io_read(addr, &value, PCI_SIZE_16);
|
||||
|
||||
return ret ? 0 : value;
|
||||
}
|
||||
|
||||
int inb(unsigned int addr)
|
||||
{
|
||||
unsigned long value;
|
||||
int ret;
|
||||
|
||||
ret = pci_io_read(addr, &value, PCI_SIZE_8);
|
||||
|
||||
return ret ? 0 : value;
|
||||
}
|
||||
|
||||
void outl(unsigned int value, unsigned int addr)
|
||||
{
|
||||
pci_io_write(addr, value, PCI_SIZE_32);
|
||||
}
|
||||
|
||||
void outw(unsigned int value, unsigned int addr)
|
||||
{
|
||||
pci_io_write(addr, value, PCI_SIZE_16);
|
||||
}
|
||||
|
||||
void outb(unsigned int value, unsigned int addr)
|
||||
{
|
||||
pci_io_write(addr, value, PCI_SIZE_8);
|
||||
}
|
||||
Reference in New Issue
Block a user