8e0346d137
* configure.in: Add SPARC LEON support. * configure: Regenerated. * sparc_leon/asm-leon/amba.h, sparc_leon/asm-leon/asmmacro.h, sparc_leon/asm-leon/clock.h, sparc_leon/asm-leon/contextswitch.h, sparc_leon/asm-leon/elfmacro.h, sparc_leon/asm-leon/head.h, sparc_leon/asm-leon/irq.h, sparc_leon/asm-leon/jiffies.h, sparc_leon/asm-leon/lambapp.h, sparc_leon/asm-leon/lambapp_devs.h, sparc_leon/asm-leon/leon.h, sparc_leon/asm-leon/leon3.h, sparc_leon/asm-leon/leonbare_debug.h, sparc_leon/asm-leon/leonbare_kernel.h, sparc_leon/asm-leon/leonbare_kernel_queue.h, sparc_leon/asm-leon/leoncompat.h, sparc_leon/asm-leon/leondbg.h, sparc_leon/asm-leon/leonstack.h, sparc_leon/asm-leon/liblocks.h, sparc_leon/asm-leon/linkage.h, sparc_leon/asm-leon/param.h, sparc_leon/asm-leon/queue.h, sparc_leon/asm-leon/spinlock.h, sparc_leon/asm-leon/stack.h, sparc_leon/asm-leon/time.h, sparc_leon/asm-leon/timer.h, sparc_leon/asm-leon/types.h, sparc_leon/asm-leon/winmacros.h: New file. * sparc_leon/Makefile.in, sparc_leon/_exit.c, sparc_leon/amba.c, sparc_leon/amba_dbg.c, sparc_leon/amba_driver.c, sparc_leon/amba_scan.c, sparc_leon/asm-leon, sparc_leon/bdinit.S, sparc_leon/busscan.S, sparc_leon/cacheA.S, sparc_leon/catch_interrupt.c, sparc_leon/catch_interrupt_mvt.c, sparc_leon/catch_interrupt_pending.c, sparc_leon/catch_interrupt_svt.c, sparc_leon/configure.in, sparc_leon/console.c, sparc_leon/console_dbg.c, sparc_leon/console_init.c, sparc_leon/contextswitch.c, sparc_leon/contextswitch_asm.S, sparc_leon/crt0.S, sparc_leon/crti.S, sparc_leon/crtn.S, sparc_leon/etrap.S, sparc_leon/etrap_fast.S, sparc_leon/fpu.S, sparc_leon/gettimeofday.c, sparc_leon/initcalls.c, sparc_leon/io.c, sparc_leon/irqinstall.S, sparc_leon/irqtrap.S, sparc_leon/irqtrap_fast.S, sparc_leon/jiffies.c, sparc_leon/kernel.c, sparc_leon/kernel_context.S, sparc_leon/kernel_debug.c, sparc_leon/kernel_debug_var.c, sparc_leon/kernel_mm.c, sparc_leon/kernel_mutex.c, sparc_leon/kernel_queue.c, sparc_leon/kernel_sched.c, sparc_leon/kernel_thread.c, sparc_leon/lcpuinit.S, sparc_leon/locore.S, sparc_leon/locore_atexit.c, sparc_leon/locore_clean.S, sparc_leon/locore_mvt.S, sparc_leon/locore_mvt_reset.S, sparc_leon/locore_svt.S, sparc_leon/locore_svt_reset.S, sparc_leon/locore_svtdisp.S, sparc_leon/locore_var.S, sparc_leon/locore_var_svt.S, sparc_leon/mmu_asm.S, sparc_leon/mutex.c, sparc_leon/nocache.S, sparc_leon/pnpinit.c, sparc_leon/pnpinit_malloc.c, sparc_leon/pnpinit_simple.c, sparc_leon/regwin.S, sparc_leon/regwin_patch.c, sparc_leon/regwin_slow.S, sparc_leon/regwinflush.S, sparc_leon/rtc.c, sparc_leon/rtrap.S, sparc_leon/rtrap_fast.S, sparc_leon/stop.S, sparc_leon/timer.c, sparc_leon/times.c: New file * sparc_leon/configure: Regenerate
178 lines
5.2 KiB
C
178 lines
5.2 KiB
C
/*
|
|
* Copyright (c) 2011 Aeroflex Gaisler
|
|
*
|
|
* BSD license:
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
|
|
#ifndef _LAMBAPP_H
|
|
#define _LAMBAPP_H
|
|
|
|
|
|
/* Include VENDOR and DEVICE definitions */
|
|
#include "lambapp_devs.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
struct ambapp_dev_hdr;
|
|
struct ambapp_apb_info;
|
|
struct ambapp_ahb_info;
|
|
|
|
struct ambapp_dev_hdr
|
|
{
|
|
struct ambapp_dev_hdr *next; /* Next */
|
|
struct ambapp_dev_hdr *prev; /* Previous Device. If (this == prev->child) prev is bus bridge */
|
|
struct ambapp_dev_hdr *children; /* Points to first device on sub-bus */
|
|
void *owner; /* Owner of this AMBA device */
|
|
unsigned char dev_type; /* AHB MST, AHB SLV or APB SLV */
|
|
unsigned char vendor; /* Vendor ID */
|
|
unsigned short device; /* Device ID */
|
|
void *devinfo; /* Device info (APB or AHB depending on type) */
|
|
};
|
|
|
|
#define AMBAPP_FLAG_FFACT_DIR 0x100 /* Frequency factor direction, 0=down, 1=up */
|
|
#define AMBAPP_FLAG_FFACT 0x0f0 /* Frequency factor against top bus */
|
|
#define AMBAPP_FLAG_MBUS 0x00c
|
|
#define AMBAPP_FLAG_SBUS 0x003
|
|
|
|
struct ambapp_apb_info
|
|
{
|
|
/* COMMON */
|
|
unsigned char irq;
|
|
unsigned char ver;
|
|
|
|
/* APB SPECIFIC */
|
|
unsigned int start;
|
|
unsigned int mask;
|
|
};
|
|
|
|
struct ambapp_ahb_info
|
|
{
|
|
/* COMMON */
|
|
unsigned char irq;
|
|
unsigned char ver;
|
|
|
|
/* AHB SPECIFIC */
|
|
unsigned int start[4];
|
|
unsigned int mask[4];
|
|
char type[4]; /* type[N] Determine type of start[N]-mask[N], 2=AHB Memory Space, 3=AHB I/O Space */
|
|
unsigned int custom[3];
|
|
};
|
|
|
|
/* Describes a complete AMBA Core. Each device may consist of 3 interfaces */
|
|
struct ambapp_dev_info
|
|
{
|
|
char irq; /* irq=-1 indicate no IRQ */
|
|
unsigned char vendor;
|
|
unsigned short device;
|
|
int index; /* Core index if multiple "subcores" in one */
|
|
struct ambapp_ahb_info *ahb_mst;
|
|
struct ambapp_ahb_info *ahb_slv;
|
|
struct ambapp_apb_info *apb_slv;
|
|
};
|
|
|
|
struct ambapp_mmap
|
|
{
|
|
unsigned int size;
|
|
unsigned int local_adr;
|
|
unsigned int remote_adr;
|
|
};
|
|
|
|
/* Complete AMBA PnP information */
|
|
struct ambapp_bus
|
|
{
|
|
struct ambapp_mmap *mmaps;
|
|
struct ambapp_dev_hdr *root;
|
|
};
|
|
|
|
/*
|
|
* Return values
|
|
* 0 - continue
|
|
* 1 - stop scanning
|
|
*/
|
|
typedef int (*ambapp_func_t) (struct ambapp_dev_hdr * dev, int index,
|
|
int maxdepth, void *arg);
|
|
|
|
#define DEV_IS_FREE(dev) (dev->owner == NULL)
|
|
#define DEV_IS_ALLOCATED(dev) (dev->owner != NULL)
|
|
|
|
/* Options to ambapp_for_each */
|
|
#define OPTIONS_AHB_MSTS 0x00000001
|
|
#define OPTIONS_AHB_SLVS 0x00000002
|
|
#define OPTIONS_APB_SLVS 0x00000004
|
|
#define OPTIONS_ALL_DEVS (OPTIONS_AHB_MSTS|OPTIONS_AHB_SLVS|OPTIONS_APB_SLVS)
|
|
|
|
#define OPTIONS_FREE 0x00000010
|
|
#define OPTIONS_ALLOCATED 0x00000020
|
|
#define OPTIONS_ALL (OPTIONS_FREE|OPTIONS_ALLOCATED)
|
|
|
|
/* Depth first search, Defualt is breth first search. */
|
|
#define OPTIONS_DEPTH_FIRST 0x00000100
|
|
|
|
#define DEV_AHB_NONE 0
|
|
#define DEV_AHB_MST 1
|
|
#define DEV_AHB_SLV 2
|
|
#define DEV_APB_SLV 3
|
|
|
|
/* Structures used to access Plug&Play information directly */
|
|
struct ambapp_pnp_ahb
|
|
{
|
|
const unsigned int id; /* VENDOR, DEVICE, VER, IRQ, */
|
|
const unsigned int custom[3];
|
|
const unsigned int mbar[4]; /* MASK, ADDRESS, TYPE, CACHABLE/PREFETCHABLE */
|
|
};
|
|
|
|
struct ambapp_pnp_apb
|
|
{
|
|
const unsigned int id; /* VENDOR, DEVICE, VER, IRQ, */
|
|
const unsigned int iobar; /* MASK, ADDRESS, TYPE, CACHABLE/PREFETCHABLE */
|
|
};
|
|
|
|
#define ambapp_pnp_vendor(id) (((id) >> 24) & 0xff)
|
|
#define ambapp_pnp_device(id) (((id) >> 12) & 0xfff)
|
|
#define ambapp_pnp_ver(id) (((id)>>5) & 0x1f)
|
|
#define ambapp_pnp_irq(id) ((id) & 0x1f)
|
|
|
|
#define ambapp_pnp_start(mbar) (((mbar) & 0xfff00000) & (((mbar) & 0xfff0) << 16))
|
|
#define ambapp_pnp_mbar_mask(mbar) (((mbar)>>4) & 0xfff)
|
|
#define ambapp_pnp_mbar_type(mbar) ((mbar) & 0xf)
|
|
|
|
#define ambapp_pnp_apb_start(iobar, base) ((base) | ((((iobar) & 0xfff00000)>>12) & (((iobar) & 0xfff0)<<4)) )
|
|
#define ambapp_pnp_apb_mask(iobar) ((~(ambapp_pnp_mbar_mask(iobar)<<8) & 0x000fffff) + 1)
|
|
|
|
#define AMBA_TYPE_AHBIO_ADDR(addr,base_ioarea) ((unsigned int)(base_ioarea) | ((addr) >> 12))
|
|
|
|
#define AMBA_TYPE_APBIO 0x1
|
|
#define AMBA_TYPE_MEM 0x2
|
|
#define AMBA_TYPE_AHBIO 0x3
|
|
|
|
extern int find_apbslv (int vendor, int device,
|
|
struct ambapp_apb_info *dev);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|