blob: 3c70b8fdb5324c86626867d6a724e03013357654 [file] [log] [blame]
/*
* Support for Intel Camera Imaging ISP subsystem.
* Copyright (c) 2010-2015, Intel Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*/
#ifndef __SP_LOCAL_H_INCLUDED__
#define __SP_LOCAL_H_INCLUDED__
#include <type_support.h>
#include "sp_global.h"
struct sp_state_s {
int pc;
int status_register;
bool is_broken;
bool is_idle;
bool is_sleeping;
bool is_stalling;
};
struct sp_stall_s {
bool fifo0;
bool fifo1;
bool fifo2;
bool fifo3;
bool fifo4;
bool fifo5;
bool fifo6;
bool fifo7;
bool fifo8;
bool fifo9;
bool fifoa;
bool dmem;
bool control_master;
bool icache_master;
};
#define sp_address_of(var) (HIVE_ADDR_ ## var)
/*
* deprecated
*/
#define store_sp_int(var, value) \
sp_dmem_store_uint32(SP0_ID, (unsigned)sp_address_of(var), \
(uint32_t)(value))
#define store_sp_ptr(var, value) \
sp_dmem_store_uint32(SP0_ID, (unsigned)sp_address_of(var), \
(uint32_t)(value))
#define load_sp_uint(var) \
sp_dmem_load_uint32(SP0_ID, (unsigned)sp_address_of(var))
#define load_sp_array_uint8(array_name, index) \
sp_dmem_load_uint8(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint8_t))
#define load_sp_array_uint16(array_name, index) \
sp_dmem_load_uint16(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint16_t))
#define load_sp_array_uint(array_name, index) \
sp_dmem_load_uint32(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint32_t))
#define store_sp_var(var, data, bytes) \
sp_dmem_store(SP0_ID, (unsigned)sp_address_of(var), data, bytes)
#define store_sp_array_uint8(array_name, index, value) \
sp_dmem_store_uint8(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint8_t), value)
#define store_sp_array_uint16(array_name, index, value) \
sp_dmem_store_uint16(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint16_t), value)
#define store_sp_array_uint(array_name, index, value) \
sp_dmem_store_uint32(SP0_ID, (unsigned)sp_address_of(array_name) + \
(index)*sizeof(uint32_t), value)
#define store_sp_var_with_offset(var, offset, data, bytes) \
sp_dmem_store(SP0_ID, (unsigned)sp_address_of(var) + \
offset, data, bytes)
#define load_sp_var(var, data, bytes) \
sp_dmem_load(SP0_ID, (unsigned)sp_address_of(var), data, bytes)
#define load_sp_var_with_offset(var, offset, data, bytes) \
sp_dmem_load(SP0_ID, (unsigned)sp_address_of(var) + offset, \
data, bytes)
#endif /* __SP_LOCAL_H_INCLUDED__ */