| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * 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 int)sp_address_of(var), \ |
| (uint32_t)(value)) |
| |
| #define store_sp_ptr(var, value) \ |
| sp_dmem_store_uint32(SP0_ID, (unsigned int)sp_address_of(var), \ |
| (uint32_t)(value)) |
| |
| #define load_sp_uint(var) \ |
| sp_dmem_load_uint32(SP0_ID, (unsigned int)sp_address_of(var)) |
| |
| #define load_sp_array_uint8(array_name, index) \ |
| sp_dmem_load_uint8(SP0_ID, (unsigned int)sp_address_of(array_name) + \ |
| (index) * sizeof(uint8_t)) |
| |
| #define load_sp_array_uint16(array_name, index) \ |
| sp_dmem_load_uint16(SP0_ID, (unsigned int)sp_address_of(array_name) + \ |
| (index) * sizeof(uint16_t)) |
| |
| #define load_sp_array_uint(array_name, index) \ |
| sp_dmem_load_uint32(SP0_ID, (unsigned int)sp_address_of(array_name) + \ |
| (index) * sizeof(uint32_t)) |
| |
| #define store_sp_var(var, data, bytes) \ |
| sp_dmem_store(SP0_ID, (unsigned int)sp_address_of(var), data, bytes) |
| |
| #define store_sp_array_uint8(array_name, index, value) \ |
| sp_dmem_store_uint8(SP0_ID, (unsigned int)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 int)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 int)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 int)sp_address_of(var) + \ |
| offset, data, bytes) |
| |
| #define load_sp_var(var, data, bytes) \ |
| sp_dmem_load(SP0_ID, (unsigned int)sp_address_of(var), data, bytes) |
| |
| #define load_sp_var_with_offset(var, offset, data, bytes) \ |
| sp_dmem_load(SP0_ID, (unsigned int)sp_address_of(var) + offset, \ |
| data, bytes) |
| |
| #endif /* __SP_LOCAL_H_INCLUDED__ */ |