mirror of https://gitee.com/openkylin/linux.git
media: atomisp: remove non-used 32-bits consts at system_local
There is an abstraction at the code in order to support 32 or 64 bits address/data length. However, for all Atom chipsets supported by this version, the size is fixed. So, cleanup the mess, removing the uused code and placing the data sizes on a single place. The end goal is to completely remove those local/global headers, replacing them by some ISP-version dependent struct, in order for the driver to decide what version it would need in runtime. Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
ecf1b4ca97
commit
a6154805d0
|
@ -52,32 +52,14 @@ typedef unsigned short hive_uint16;
|
||||||
typedef unsigned int hive_uint32;
|
typedef unsigned int hive_uint32;
|
||||||
typedef unsigned long long hive_uint64;
|
typedef unsigned long long hive_uint64;
|
||||||
|
|
||||||
/* by default assume 32 bit master port (both data and address) */
|
|
||||||
#ifndef HRT_DATA_WIDTH
|
|
||||||
#define HRT_DATA_WIDTH 32
|
#define HRT_DATA_WIDTH 32
|
||||||
#endif
|
#define HRT_ADDRESS_WIDTH 64
|
||||||
#ifndef HRT_ADDRESS_WIDTH
|
|
||||||
#define HRT_ADDRESS_WIDTH 32
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define HRT_DATA_BYTES (HRT_DATA_WIDTH / 8)
|
#define HRT_DATA_BYTES (HRT_DATA_WIDTH / 8)
|
||||||
#define HRT_ADDRESS_BYTES (HRT_ADDRESS_WIDTH / 8)
|
#define HRT_ADDRESS_BYTES (HRT_ADDRESS_WIDTH / 8)
|
||||||
|
#define SIZEOF_HRT_REG (HRT_DATA_WIDTH >> 3)
|
||||||
|
|
||||||
#if HRT_DATA_WIDTH == 64
|
|
||||||
typedef hive_uint64 hrt_data;
|
|
||||||
#elif HRT_DATA_WIDTH == 32
|
|
||||||
typedef hive_uint32 hrt_data;
|
typedef hive_uint32 hrt_data;
|
||||||
#else
|
|
||||||
#error data width not supported
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if HRT_ADDRESS_WIDTH == 64
|
|
||||||
typedef hive_uint64 hrt_address;
|
typedef hive_uint64 hrt_address;
|
||||||
#elif HRT_ADDRESS_WIDTH == 32
|
|
||||||
typedef hive_uint32 hrt_address;
|
|
||||||
#else
|
|
||||||
#error adddres width not supported
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* use 64 bit addresses in simulation, where possible */
|
/* use 64 bit addresses in simulation, where possible */
|
||||||
typedef hive_uint64 hive_sim_address;
|
typedef hive_uint64 hive_sim_address;
|
||||||
|
|
|
@ -75,8 +75,6 @@
|
||||||
* Semi global. "HRT" is accessible from SP, but the HRT types do not fully apply
|
* Semi global. "HRT" is accessible from SP, but the HRT types do not fully apply
|
||||||
*/
|
*/
|
||||||
#define HRT_VADDRESS_WIDTH 32
|
#define HRT_VADDRESS_WIDTH 32
|
||||||
//#define HRT_ADDRESS_WIDTH 64 /* Surprise, this is a local property*/
|
|
||||||
#define HRT_DATA_WIDTH 32
|
|
||||||
|
|
||||||
#define SIZEOF_HRT_REG (HRT_DATA_WIDTH >> 3)
|
#define SIZEOF_HRT_REG (HRT_DATA_WIDTH >> 3)
|
||||||
#define HIVE_ISP_CTRL_DATA_BYTES (HIVE_ISP_CTRL_DATA_WIDTH / 8)
|
#define HIVE_ISP_CTRL_DATA_BYTES (HIVE_ISP_CTRL_DATA_WIDTH / 8)
|
||||||
|
|
|
@ -24,17 +24,12 @@
|
||||||
|
|
||||||
#include "system_global.h"
|
#include "system_global.h"
|
||||||
|
|
||||||
/* HRT assumes 32 by default (see Linux/include/hive_types.h), overrule it in case it is different */
|
|
||||||
#undef HRT_ADDRESS_WIDTH
|
|
||||||
#define HRT_ADDRESS_WIDTH 64 /* Surprise, this is a local property */
|
|
||||||
|
|
||||||
/* This interface is deprecated */
|
/* This interface is deprecated */
|
||||||
#include "hive_types.h"
|
#include "hive_types.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Cell specific address maps
|
* Cell specific address maps
|
||||||
*/
|
*/
|
||||||
#if HRT_ADDRESS_WIDTH == 64
|
|
||||||
|
|
||||||
#define GP_FIFO_BASE ((hrt_address)0x0000000000090104) /* This is NOT a base address */
|
#define GP_FIFO_BASE ((hrt_address)0x0000000000090104) /* This is NOT a base address */
|
||||||
|
|
||||||
|
@ -154,130 +149,4 @@ static const hrt_address RX_BASE[N_RX_ID] = {
|
||||||
(hrt_address)0x0000000000080100ULL
|
(hrt_address)0x0000000000080100ULL
|
||||||
};
|
};
|
||||||
|
|
||||||
#elif HRT_ADDRESS_WIDTH == 32
|
|
||||||
|
|
||||||
#define GP_FIFO_BASE ((hrt_address)0x00090104) /* This is NOT a base address */
|
|
||||||
|
|
||||||
/* ISP */
|
|
||||||
static const hrt_address ISP_CTRL_BASE[N_ISP_ID] = {
|
|
||||||
(hrt_address)0x00020000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address ISP_DMEM_BASE[N_ISP_ID] = {
|
|
||||||
(hrt_address)0x00200000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address ISP_BAMEM_BASE[N_BAMEM_ID] = {
|
|
||||||
(hrt_address)0x100000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* SP */
|
|
||||||
static const hrt_address SP_CTRL_BASE[N_SP_ID] = {
|
|
||||||
(hrt_address)0x00010000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address SP_DMEM_BASE[N_SP_ID] = {
|
|
||||||
(hrt_address)0x00300000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* MMU */
|
|
||||||
/*
|
|
||||||
* MMU0_ID: The data MMU
|
|
||||||
* MMU1_ID: The icache MMU
|
|
||||||
*/
|
|
||||||
static const hrt_address MMU_BASE[N_MMU_ID] = {
|
|
||||||
(hrt_address)0x00070000UL,
|
|
||||||
(hrt_address)0x000A0000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* DMA */
|
|
||||||
static const hrt_address DMA_BASE[N_DMA_ID] = {
|
|
||||||
(hrt_address)0x00040000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* IRQ */
|
|
||||||
static const hrt_address IRQ_BASE[N_IRQ_ID] = {
|
|
||||||
(hrt_address)0x00000500UL,
|
|
||||||
(hrt_address)0x00030A00UL,
|
|
||||||
(hrt_address)0x0008C000UL,
|
|
||||||
(hrt_address)0x00090200UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
(hrt_address)0x00000500UL};
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* GDC */
|
|
||||||
static const hrt_address GDC_BASE[N_GDC_ID] = {
|
|
||||||
(hrt_address)0x00050000UL,
|
|
||||||
(hrt_address)0x00060000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* FIFO_MONITOR (not a subset of GP_DEVICE) */
|
|
||||||
static const hrt_address FIFO_MONITOR_BASE[N_FIFO_MONITOR_ID] = {
|
|
||||||
(hrt_address)0x00000000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
static const hrt_address GP_REGS_BASE[N_GP_REGS_ID] = {
|
|
||||||
(hrt_address)0x00000000UL};
|
|
||||||
|
|
||||||
static const hrt_address GP_DEVICE_BASE[N_GP_DEVICE_ID] = {
|
|
||||||
(hrt_address)0x00090000UL};
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* GP_DEVICE (single base for all separate GP_REG instances) */
|
|
||||||
static const hrt_address GP_DEVICE_BASE[N_GP_DEVICE_ID] = {
|
|
||||||
(hrt_address)0x00000000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*GP TIMER , all timer registers are inter-twined,
|
|
||||||
* so, having multiple base addresses for
|
|
||||||
* different timers does not help*/
|
|
||||||
static const hrt_address GP_TIMER_BASE =
|
|
||||||
(hrt_address)0x00000600UL;
|
|
||||||
|
|
||||||
/* GPIO */
|
|
||||||
static const hrt_address GPIO_BASE[N_GPIO_ID] = {
|
|
||||||
(hrt_address)0x00000400UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* TIMED_CTRL */
|
|
||||||
static const hrt_address TIMED_CTRL_BASE[N_TIMED_CTRL_ID] = {
|
|
||||||
(hrt_address)0x00000100UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* INPUT_FORMATTER */
|
|
||||||
static const hrt_address INPUT_FORMATTER_BASE[N_INPUT_FORMATTER_ID] = {
|
|
||||||
(hrt_address)0x00030000UL,
|
|
||||||
(hrt_address)0x00030200UL,
|
|
||||||
(hrt_address)0x00030400UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* (hrt_address)0x00030600UL, */ /* memcpy() */
|
|
||||||
|
|
||||||
/* INPUT_SYSTEM */
|
|
||||||
static const hrt_address INPUT_SYSTEM_BASE[N_INPUT_SYSTEM_ID] = {
|
|
||||||
(hrt_address)0x00080000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* (hrt_address)0x00081000UL, */ /* capture A */
|
|
||||||
/* (hrt_address)0x00082000UL, */ /* capture B */
|
|
||||||
/* (hrt_address)0x00083000UL, */ /* capture C */
|
|
||||||
/* (hrt_address)0x00084000UL, */ /* Acquisition */
|
|
||||||
/* (hrt_address)0x00085000UL, */ /* DMA */
|
|
||||||
/* (hrt_address)0x00089000UL, */ /* ctrl */
|
|
||||||
/* (hrt_address)0x0008A000UL, */ /* GP regs */
|
|
||||||
/* (hrt_address)0x0008B000UL, */ /* FIFO */
|
|
||||||
/* (hrt_address)0x0008C000UL, */ /* IRQ */
|
|
||||||
|
|
||||||
/* RX, the MIPI lane control regs start at offset 0 */
|
|
||||||
static const hrt_address RX_BASE[N_RX_ID] = {
|
|
||||||
(hrt_address)0x00080100UL
|
|
||||||
};
|
|
||||||
|
|
||||||
#else
|
|
||||||
#error "system_local.h: HRT_ADDRESS_WIDTH must be one of {32,64}"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __SYSTEM_LOCAL_H_INCLUDED__ */
|
#endif /* __SYSTEM_LOCAL_H_INCLUDED__ */
|
||||||
|
|
|
@ -85,11 +85,7 @@
|
||||||
* the HRT types do not fully apply
|
* the HRT types do not fully apply
|
||||||
*/
|
*/
|
||||||
#define HRT_VADDRESS_WIDTH 32
|
#define HRT_VADDRESS_WIDTH 32
|
||||||
/* Surprise, this is a local property*/
|
|
||||||
/*#define HRT_ADDRESS_WIDTH 64 */
|
|
||||||
#define HRT_DATA_WIDTH 32
|
|
||||||
|
|
||||||
#define SIZEOF_HRT_REG (HRT_DATA_WIDTH >> 3)
|
|
||||||
#define HIVE_ISP_CTRL_DATA_BYTES (HIVE_ISP_CTRL_DATA_WIDTH / 8)
|
#define HIVE_ISP_CTRL_DATA_BYTES (HIVE_ISP_CTRL_DATA_WIDTH / 8)
|
||||||
|
|
||||||
/* The main bus connecting all devices */
|
/* The main bus connecting all devices */
|
||||||
|
|
|
@ -24,15 +24,12 @@
|
||||||
|
|
||||||
#include "system_global.h"
|
#include "system_global.h"
|
||||||
|
|
||||||
#define HRT_ADDRESS_WIDTH 64 /* Surprise, this is a local property */
|
|
||||||
|
|
||||||
/* This interface is deprecated */
|
/* This interface is deprecated */
|
||||||
#include "hive_types.h"
|
#include "hive_types.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Cell specific address maps
|
* Cell specific address maps
|
||||||
*/
|
*/
|
||||||
#if HRT_ADDRESS_WIDTH == 64
|
|
||||||
|
|
||||||
#define GP_FIFO_BASE ((hrt_address)0x0000000000090104) /* This is NOT a base address */
|
#define GP_FIFO_BASE ((hrt_address)0x0000000000090104) /* This is NOT a base address */
|
||||||
|
|
||||||
|
@ -198,175 +195,5 @@ static const hrt_address STREAM2MMIO_CTRL_BASE[N_STREAM2MMIO_ID] = {
|
||||||
0x00000000000C2C00ULL, /* stream2mmio controller B */
|
0x00000000000C2C00ULL, /* stream2mmio controller B */
|
||||||
0x00000000000C4C00ULL /* stream2mmio controller C */
|
0x00000000000C4C00ULL /* stream2mmio controller C */
|
||||||
};
|
};
|
||||||
#elif HRT_ADDRESS_WIDTH == 32
|
|
||||||
|
|
||||||
#define GP_FIFO_BASE ((hrt_address)0x00090104) /* This is NOT a base address */
|
|
||||||
|
|
||||||
/* ISP */
|
|
||||||
static const hrt_address ISP_CTRL_BASE[N_ISP_ID] = {
|
|
||||||
0x00020000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address ISP_DMEM_BASE[N_ISP_ID] = {
|
|
||||||
0xffffffffUL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address ISP_BAMEM_BASE[N_BAMEM_ID] = {
|
|
||||||
0xffffffffUL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* SP */
|
|
||||||
static const hrt_address SP_CTRL_BASE[N_SP_ID] = {
|
|
||||||
0x00010000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address SP_DMEM_BASE[N_SP_ID] = {
|
|
||||||
0x00300000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* MMU */
|
|
||||||
/*
|
|
||||||
* MMU0_ID: The data MMU
|
|
||||||
* MMU1_ID: The icache MMU
|
|
||||||
*/
|
|
||||||
static const hrt_address MMU_BASE[N_MMU_ID] = {
|
|
||||||
0x00070000UL,
|
|
||||||
0x000A0000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* DMA */
|
|
||||||
static const hrt_address DMA_BASE[N_DMA_ID] = {
|
|
||||||
0x00040000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
static const hrt_address ISYS2401_DMA_BASE[N_ISYS2401_DMA_ID] = {
|
|
||||||
0x000CA000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* IRQ */
|
|
||||||
static const hrt_address IRQ_BASE[N_IRQ_ID] = {
|
|
||||||
0x00000500UL,
|
|
||||||
0x00030A00UL,
|
|
||||||
0x0008C000UL,
|
|
||||||
0x00090200UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
0x00000500UL};
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* GDC */
|
|
||||||
static const hrt_address GDC_BASE[N_GDC_ID] = {
|
|
||||||
0x00050000UL,
|
|
||||||
0x00060000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* FIFO_MONITOR (not a subset of GP_DEVICE) */
|
|
||||||
static const hrt_address FIFO_MONITOR_BASE[N_FIFO_MONITOR_ID] = {
|
|
||||||
0x00000000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
static const hrt_address GP_REGS_BASE[N_GP_REGS_ID] = {
|
|
||||||
0x00000000UL};
|
|
||||||
|
|
||||||
static const hrt_address GP_DEVICE_BASE[N_GP_DEVICE_ID] = {
|
|
||||||
0x00090000UL};
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* GP_DEVICE (single base for all separate GP_REG instances) */
|
|
||||||
static const hrt_address GP_DEVICE_BASE[N_GP_DEVICE_ID] = {
|
|
||||||
0x00000000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/*GP TIMER , all timer registers are inter-twined,
|
|
||||||
* so, having multiple base addresses for
|
|
||||||
* different timers does not help*/
|
|
||||||
static const hrt_address GP_TIMER_BASE =
|
|
||||||
(hrt_address)0x00000600UL;
|
|
||||||
/* GPIO */
|
|
||||||
static const hrt_address GPIO_BASE[N_GPIO_ID] = {
|
|
||||||
0x00000400UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* TIMED_CTRL */
|
|
||||||
static const hrt_address TIMED_CTRL_BASE[N_TIMED_CTRL_ID] = {
|
|
||||||
0x00000100UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* INPUT_FORMATTER */
|
|
||||||
static const hrt_address INPUT_FORMATTER_BASE[N_INPUT_FORMATTER_ID] = {
|
|
||||||
0x00030000UL,
|
|
||||||
0x00030200UL,
|
|
||||||
0x00030400UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* 0x00030600UL, */ /* memcpy() */
|
|
||||||
|
|
||||||
/* INPUT_SYSTEM */
|
|
||||||
static const hrt_address INPUT_SYSTEM_BASE[N_INPUT_SYSTEM_ID] = {
|
|
||||||
0x00080000UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* 0x00081000UL, */ /* capture A */
|
|
||||||
/* 0x00082000UL, */ /* capture B */
|
|
||||||
/* 0x00083000UL, */ /* capture C */
|
|
||||||
/* 0x00084000UL, */ /* Acquisition */
|
|
||||||
/* 0x00085000UL, */ /* DMA */
|
|
||||||
/* 0x00089000UL, */ /* ctrl */
|
|
||||||
/* 0x0008A000UL, */ /* GP regs */
|
|
||||||
/* 0x0008B000UL, */ /* FIFO */
|
|
||||||
/* 0x0008C000UL, */ /* IRQ */
|
|
||||||
|
|
||||||
/* RX, the MIPI lane control regs start at offset 0 */
|
|
||||||
static const hrt_address RX_BASE[N_RX_ID] = {
|
|
||||||
0x00080100UL
|
|
||||||
};
|
|
||||||
|
|
||||||
/* IBUF_CTRL, part of the Input System 2401 */
|
|
||||||
static const hrt_address IBUF_CTRL_BASE[N_IBUF_CTRL_ID] = {
|
|
||||||
0x000C1800UL, /* ibuf controller A */
|
|
||||||
0x000C3800UL, /* ibuf controller B */
|
|
||||||
0x000C5800UL /* ibuf controller C */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* ISYS IRQ Controllers, part of the Input System 2401 */
|
|
||||||
static const hrt_address ISYS_IRQ_BASE[N_ISYS_IRQ_ID] = {
|
|
||||||
0x000C1400ULL, /* port a */
|
|
||||||
0x000C3400ULL, /* port b */
|
|
||||||
0x000C5400ULL /* port c */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* CSI FE, part of the Input System 2401 */
|
|
||||||
static const hrt_address CSI_RX_FE_CTRL_BASE[N_CSI_RX_FRONTEND_ID] = {
|
|
||||||
0x000C0400UL, /* csi fe controller A */
|
|
||||||
0x000C2400UL, /* csi fe controller B */
|
|
||||||
0x000C4400UL /* csi fe controller C */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* CSI BE, part of the Input System 2401 */
|
|
||||||
static const hrt_address CSI_RX_FE_CTRL_BASE[N_CSI_RX_BACKEND_ID] = {
|
|
||||||
0x000C0800UL, /* csi be controller A */
|
|
||||||
0x000C2800UL, /* csi be controller B */
|
|
||||||
0x000C4800UL /* csi be controller C */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* PIXEL Generator, part of the Input System 2401 */
|
|
||||||
static const hrt_address PIXELGEN_CTRL_BASE[N_PIXELGEN_ID] = {
|
|
||||||
0x000C1000UL, /* pixel gen controller A */
|
|
||||||
0x000C3000UL, /* pixel gen controller B */
|
|
||||||
0x000C5000UL /* pixel gen controller C */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Stream2MMIO, part of the Input System 2401 */
|
|
||||||
static const hrt_address STREAM2MMIO_CTRL_BASE[N_STREAM2MMIO_ID] = {
|
|
||||||
0x000C0C00UL, /* stream2mmio controller A */
|
|
||||||
0x000C2C00UL, /* stream2mmio controller B */
|
|
||||||
0x000C4C00UL /* stream2mmio controller C */
|
|
||||||
};
|
|
||||||
|
|
||||||
#else
|
|
||||||
#error "system_local.h: HRT_ADDRESS_WIDTH must be one of {32,64}"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __SYSTEM_LOCAL_H_INCLUDED__ */
|
#endif /* __SYSTEM_LOCAL_H_INCLUDED__ */
|
||||||
|
|
Loading…
Reference in New Issue