#define _isp_ceil_div(a,b) (((a)+(b)-1)/(b))
-#ifdef C_RUN
-#define ISP_VEC_ALIGN (_isp_ceil_div(ISP_VEC_WIDTH, 64)*8)
-#else
#define ISP_VEC_ALIGN ISP_VMEM_ALIGN
-#endif
/* HRT specific vector support */
#define isp2400_mamoiada_vector_alignment ISP_VEC_ALIGN
#define HRT_HOST_TYPE(cell_type) HRTCAT(hrt_host_type_of_, cell_type)
#define HRT_INT_TYPE(type) HRTCAT(hrt_int_type_of_, type)
-#ifdef C_RUN
-
-#ifdef C_RUN_DYNAMIC_LINK_PROGRAMS
-extern void *csim_processor_get_crun_symbol(hive_proc_id p, const char *sym);
-#define _hrt_cell_get_crun_symbol(cell,sym) csim_processor_get_crun_symbol(cell,HRTSTR(sym))
-#define _hrt_cell_get_crun_indexed_symbol(cell,sym) csim_processor_get_crun_symbol(cell,HRTSTR(sym))
-#else
-#define _hrt_cell_get_crun_symbol(cell,sym) (&sym)
-#define _hrt_cell_get_crun_indexed_symbol(cell,sym) (sym)
-#endif // C_RUN_DYNAMIC_LINK_PROGRAMS
-
-#define hrt_scalar_store(cell, type, var, data) \
- ((*(HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_symbol(cell,var)) = (data))
-#define hrt_scalar_load(cell, type, var) \
- ((*(HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_symbol(cell,var)))
-
-#define hrt_indexed_store(cell, type, array, index, data) \
- ((((HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_indexed_symbol(cell,array))[index]) = (data))
-#define hrt_indexed_load(cell, type, array, index) \
- (((HRT_HOST_TYPE(type)*)_hrt_cell_get_crun_indexed_symbol(cell,array))[index])
-
-#else /* C_RUN */
-
#define hrt_scalar_store(cell, type, var, data) \
HRTCAT(hrt_mem_store_,HRT_TYPE_BITS(cell, type))(\
cell, \
HRTCAT(HIVE_MEM_,array), \
(HRTCAT(HIVE_ADDR_,array))+((index)*HRT_TYPE_BYTES(cell, type))))
-#endif /* C_RUN */
-
#endif /* _HRT_VAR_H */
#endif
}
/* ISP functions to control the ISP state from the host, even in crun. */
-#ifdef C_RUN
-volatile uint32_t isp_sleeping[N_ISP_ID] = { 0 }; /* Sleeping state per ISP */
-volatile uint32_t isp_ready [N_ISP_ID] = { 1 }; /* Ready state per ISP */
-#endif
/* Inspect readiness of an ISP indexed by ID */
unsigned isp_is_ready(isp_ID_t ID)
{
assert (ID < N_ISP_ID);
-#ifdef C_RUN
- return isp_ready[ID];
-#else
return isp_ctrl_getbit(ID, ISP_SC_REG, ISP_IDLE_BIT);
-#endif
}
/* Inspect sleeping of an ISP indexed by ID */
unsigned isp_is_sleeping(isp_ID_t ID)
{
assert (ID < N_ISP_ID);
-#ifdef C_RUN
- return isp_sleeping[ID];
-#else
return isp_ctrl_getbit(ID, ISP_SC_REG, ISP_SLEEPING_BIT);
-#endif
}
/* To be called by the host immediately before starting ISP ID. */
void isp_start(isp_ID_t ID)
{
assert (ID < N_ISP_ID);
-#ifdef C_RUN
- isp_ready[ID] = 0;
-#endif
}
/* Wake up ISP ID. */
void isp_wake(isp_ID_t ID)
{
assert (ID < N_ISP_ID);
-#ifdef C_RUN
- isp_sleeping[ID] = 0;
-#else
isp_ctrl_setbit(ID, ISP_SC_REG, ISP_START_BIT);
hrt_sleep();
-#endif
}
#include "isp_public.h"
-#ifdef C_RUN
-#include <string.h> /* memcpy() */
-#endif
-
#include "device_access.h"
#include "assert_support.h"
{
assert(ID < N_ISP_ID);
assert(ISP_DMEM_BASE[ID] != (hrt_address)-1);
-#ifdef C_RUN
- memcpy((void *)addr, data, size);
-#elif !defined(HRT_MEMORY_ACCESS)
+#if !defined(HRT_MEMORY_ACCESS)
ia_css_device_store(ISP_DMEM_BASE[ID] + addr, data, size);
#else
hrt_master_port_store(ISP_DMEM_BASE[ID] + addr, data, size);
{
assert(ID < N_ISP_ID);
assert(ISP_DMEM_BASE[ID] != (hrt_address)-1);
-#ifdef C_RUN
- memcpy(data, (void *)addr, size);
-#elif !defined(HRT_MEMORY_ACCESS)
+#if !defined(HRT_MEMORY_ACCESS)
ia_css_device_load(ISP_DMEM_BASE[ID] + addr, data, size);
#else
hrt_master_port_load(ISP_DMEM_BASE[ID] + addr, data, size);
assert(ID < N_ISP_ID);
assert(ISP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifdef C_RUN
- *(uint32_t *)addr = data;
-#elif !defined(HRT_MEMORY_ACCESS)
+#if !defined(HRT_MEMORY_ACCESS)
ia_css_device_store_uint32(ISP_DMEM_BASE[ID] + addr, data);
#else
hrt_master_port_store_32(ISP_DMEM_BASE[ID] + addr, data);
assert(ID < N_ISP_ID);
assert(ISP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifdef C_RUN
- return *(uint32_t *)addr;
-#elif !defined(HRT_MEMORY_ACCESS)
+#if !defined(HRT_MEMORY_ACCESS)
return ia_css_device_load_uint32(ISP_DMEM_BASE[ID] + addr);
#else
return hrt_master_port_uload_32(ISP_DMEM_BASE[ID] + addr);
bool icache_master;
};
-#ifdef C_RUN
-#include "hive_isp_css_sp_hrt.h"
-#define sp_address_of(var) _hrt_cell_get_crun_indexed_symbol(SP, var)
-#ifdef C_RUN_DYNAMIC_LINK_PROGRAMS
-#ifndef DUMMY_HRT_SYSMEM_FUNCTIONS
-#define DUMMY_HRT_SYSMEM_FUNCTIONS
-/* These two inline functions prevent gcc from generating compiler warnings
- * about unused static functions. */
-static inline void *
-dummy__hrt_sysmem_ident_address(hive_device_id mem, const char *sym)
-{
- return __hrt_sysmem_ident_address(mem, sym);
-}
-
-static inline void
-dummy_hrt_sysmem_map_var(hive_mem_id mem, const char *ident, volatile void *native_address, unsigned int size)
-{
- _hrt_sysmem_map_var(mem, ident, native_address, size);
-}
-#endif /* DUMMY_HRT_SYSMEM_FUNCTIONS */
-#endif /* C_RUN */
-#else
#define sp_address_of(var) (HIVE_ADDR_ ## var)
-#endif
/*
* deprecated
#include "sp_public.h"
#include "device_access.h"
-#ifdef C_RUN
-#include <string.h> /* memcpy() */
-#endif
#include "assert_support.h"
{
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
-#ifndef C_RUN
ia_css_device_store(SP_DMEM_BASE[ID] + addr, data, size);
-#else
- memcpy((void *)(uint32_t)addr, data, size);
-#endif
return;
}
{
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
-#ifndef C_RUN
ia_css_device_load(SP_DMEM_BASE[ID] + addr, data, size);
-#else
- memcpy(data, (void *)(uint32_t)addr, size);
-#endif
return;
}
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
ia_css_device_store_uint8(SP_DMEM_BASE[SP0_ID] + addr, data);
-#else
- *(uint8_t *)(uint32_t)addr = data;
-#endif
return;
}
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
ia_css_device_store_uint16(SP_DMEM_BASE[SP0_ID] + addr, data);
-#else
- *(uint16_t *)(uint32_t)addr = data;
-#endif
return;
}
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
ia_css_device_store_uint32(SP_DMEM_BASE[SP0_ID] + addr, data);
-#else
- *(uint32_t *)(uint32_t)addr = data;
-#endif
return;
}
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
return ia_css_device_load_uint8(SP_DMEM_BASE[SP0_ID] + addr);
-#else
- return *(uint8_t *)(uint32_t)addr;
-#endif
}
STORAGE_CLASS_SP_C uint16_t sp_dmem_load_uint16(
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
return ia_css_device_load_uint16(SP_DMEM_BASE[SP0_ID] + addr);
-#else
- return *(uint16_t *)(uint32_t)addr;
-#endif
}
STORAGE_CLASS_SP_C uint32_t sp_dmem_load_uint32(
assert(ID < N_SP_ID);
assert(SP_DMEM_BASE[ID] != (hrt_address)-1);
(void)ID;
-#ifndef C_RUN
return ia_css_device_load_uint32(SP_DMEM_BASE[SP0_ID] + addr);
-#else
- return *(uint32_t *)(uint32_t)addr;
-#endif
}
#endif /* __SP_PRIVATE_H_INCLUDED__ */
{
unsigned i;
hive_uedge *data;
-#ifdef C_RUN
- data = (hive_uedge *)from;
- (void)ID;
-#else
unsigned size = sizeof(short)*ISP_NWAY;
VMEM_ARRAY(v, 2*ISP_NWAY); /* Need 2 vectors to work around vmem hss bug */
assert(ISP_BAMEM_BASE[ID] != (hrt_address)-1);
hrt_master_port_load(ISP_BAMEM_BASE[ID] + (unsigned long)from, &v[0][0], size);
#endif
data = (hive_uedge *)v;
-#endif
for (i = 0; i < ISP_NWAY; i++) {
hive_uedge elem = 0;
hive_sim_wide_unpack(data, &elem, ISP_VEC_ELEMBITS, i);
const t_vmem_elem *from)
{
unsigned i;
-#ifdef C_RUN
- hive_uedge *data = (hive_uedge *)to;
- (void)ID;
- for (i = 0; i < ISP_NWAY; i++) {
- hive_sim_wide_pack(data, (hive_wide)&from[i], ISP_VEC_ELEMBITS, i);
- }
-#else
unsigned size = sizeof(short)*ISP_NWAY;
VMEM_ARRAY(v, 2*ISP_NWAY); /* Need 2 vectors to work around vmem hss bug */
//load_vector (&v[1][0], &to[ISP_NWAY]); /* Fetch the next vector, since it will be overwritten. */
hrt_master_port_store(ISP_BAMEM_BASE[ID] + (unsigned long)to, &v, size);
#endif
hrt_sleep(); /* Spend at least 1 cycles per vector */
-#endif
}
void isp_vmem_load(
unsigned c;
const t_vmem_elem *vp = from;
assert(ID < N_ISP_ID);
-#ifndef C_RUN
assert((unsigned long)from % ISP_VEC_ALIGN == 0);
-#endif
assert(elems % ISP_NWAY == 0);
for (c = 0; c < elems; c += ISP_NWAY) {
load_vector(ID, &to[c], vp);
unsigned c;
t_vmem_elem *vp = to;
assert(ID < N_ISP_ID);
-#ifndef C_RUN
assert((unsigned long)to % ISP_VEC_ALIGN == 0);
-#endif
assert(elems % ISP_NWAY == 0);
for (c = 0; c < elems; c += ISP_NWAY) {
store_vector (ID, vp, &from[c]);
unsigned h;
assert(ID < N_ISP_ID);
-#ifndef C_RUN
assert((unsigned long)from % ISP_VEC_ALIGN == 0);
-#endif
assert(width % ISP_NWAY == 0);
assert(stride_from % ISP_NWAY == 0);
for (h = 0; h < height; h++) {
unsigned h;
assert(ID < N_ISP_ID);
-#ifndef C_RUN
assert((unsigned long)to % ISP_VEC_ALIGN == 0);
-#endif
assert(width % ISP_NWAY == 0);
assert(stride_to % ISP_NWAY == 0);
for (h = 0; h < height; h++) {
#define VMEM_SIZE ISP_VMEM_DEPTH
#define VMEM_ELEMBITS ISP_VMEM_ELEMBITS
-#ifdef C_RUN
-#define VMEM_ALIGN 1
-#else
#define VMEM_ALIGN ISP_VMEM_ALIGN
-#endif
#ifndef PIPE_GENERATION
typedef tvector *pvector;
* The implemenation for the pipe generation tool is in see support.isp.h */
#define OP___assert(cnd) assert(cnd)
-#ifdef C_RUN
-#define compile_time_assert(cond) OP___assert(cond)
-#else
STORAGE_CLASS_INLINE void compile_time_assert (unsigned cond)
{
/* Call undefined function if cond is false */
extern void _compile_time_assert (void);
if (!cond) _compile_time_assert();
}
-#endif
#endif /* PIPE_GENERATION */
#endif /* __ASSERT_SUPPORT_H_INCLUDED__ */
ia_css_queue_remote_t remoteq;
fw = &sh_css_sp_fw;
-#ifdef C_RUN
- q_base_addr = (unsigned int)sp_address_of(ia_css_bufq_host_sp_queue);
-#else
q_base_addr = fw->info.sp.host_sp_queue;
-#endif
/* Setup queue location as SP and proc id as SP0_ID */
remoteq.location = IA_CSS_QUEUE_LOC_SP;
va_end(ap);
}
-#if !defined(C_RUN) && !defined(HRT_UNSCHED)
+#if !defined(HRT_UNSCHED)
static void debug_dump_long_array_formatted(
const sp_ID_t sp_id,
hrt_address stack_sp_addr,
void ia_css_debug_dump_sp_stack_info(void)
{
}
-#endif /* #if !C_RUN && !HRT_UNSCHED */
+#endif /* #if !HRT_UNSCHED */
void ia_css_debug_set_dtrace_level(const unsigned int trace_level)
spctrl_cofig_info[sp_id].code_addr = mmgr_NULL;
-#if defined(C_RUN) || defined(HRT_UNSCHED)
+#if defined(HRT_UNSCHED)
(void)init_dmem_cfg;
code_addr = mmgr_malloc(1);
if (code_addr == mmgr_NULL)
blctrl_cfg->bl_entry = 0;
blctrl_cfg->program_name = (char *)(program);
-#if !defined(C_RUN) && !defined(HRT_UNSCHED)
+#if !defined(HRT_UNSCHED)
blctrl_cfg->ddr_data_offset = fw->blob.data_source;
blctrl_cfg->dmem_data_addr = fw->blob.data_target;
blctrl_cfg->dmem_bss_addr = fw->blob.bss_target;
spctrl_cfg->sp_entry = 0;
spctrl_cfg->program_name = (char *)(program);
-#if !defined(C_RUN) && !defined(HRT_UNSCHED)
+#if !defined(HRT_UNSCHED)
spctrl_cfg->ddr_data_offset = fw->blob.data_source;
spctrl_cfg->dmem_data_addr = fw->blob.data_target;
spctrl_cfg->dmem_bss_addr = fw->blob.bss_target;
return; /* removing single and multiple firmware is handled in acc_unload_extension() */
}
-#if !defined(C_RUN) && !defined(HRT_UNSCHED)
+#if !defined(HRT_UNSCHED)
static enum ia_css_err
upload_isp_code(struct ia_css_fw_info *firmware)
{
static enum ia_css_err
acc_load_extension(struct ia_css_fw_info *firmware)
{
-#if !defined(C_RUN) && !defined(HRT_UNSCHED)
+#if !defined(HRT_UNSCHED)
enum ia_css_err err;
struct ia_css_fw_info *hd = firmware;
while (hd){
*sh_css_fw = *fw;
-#if defined(C_RUN) || defined(HRT_UNSCHED)
+#if defined(HRT_UNSCHED)
sh_css_fw->blob.code = sh_css_malloc(1);
#else
sh_css_fw->blob.code = sh_css_malloc(fw->blob.size);
#include "assert_support.h"
#include <hrt/master_port.h> /* hrt_master_port_load() */
-#ifdef C_RUN
-#include <string.h> /* memcpy() */
-#endif
/*
* This is an HRT backend implementation for CSIM
const size_t size)
{
assert(base_address != (sys_address)-1);
-#ifndef C_RUN
hrt_master_port_load((uint32_t)(base_address + addr), data, size);
-#else
- memcpy(data, (void *)addr, size);
-#endif
}
void device_store(
const size_t size)
{
assert(base_address != (sys_address)-1);
-#ifndef C_RUN
hrt_master_port_store((uint32_t)(base_address + addr), data, size);
-#else
- memcpy((void *)addr, data, size);
-#endif
return;
}