19d4fa1a1SMauro Carvalho Chehab /* 29d4fa1a1SMauro Carvalho Chehab * Support for Intel Camera Imaging ISP subsystem. 39d4fa1a1SMauro Carvalho Chehab * Copyright (c) 2015, Intel Corporation. 49d4fa1a1SMauro Carvalho Chehab * 59d4fa1a1SMauro Carvalho Chehab * This program is free software; you can redistribute it and/or modify it 69d4fa1a1SMauro Carvalho Chehab * under the terms and conditions of the GNU General Public License, 79d4fa1a1SMauro Carvalho Chehab * version 2, as published by the Free Software Foundation. 89d4fa1a1SMauro Carvalho Chehab * 99d4fa1a1SMauro Carvalho Chehab * This program is distributed in the hope it will be useful, but WITHOUT 109d4fa1a1SMauro Carvalho Chehab * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 119d4fa1a1SMauro Carvalho Chehab * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 129d4fa1a1SMauro Carvalho Chehab * more details. 139d4fa1a1SMauro Carvalho Chehab */ 149d4fa1a1SMauro Carvalho Chehab 159d4fa1a1SMauro Carvalho Chehab #ifndef __INPUT_FORMATTER_GLOBAL_H_INCLUDED__ 169d4fa1a1SMauro Carvalho Chehab #define __INPUT_FORMATTER_GLOBAL_H_INCLUDED__ 179d4fa1a1SMauro Carvalho Chehab 189d4fa1a1SMauro Carvalho Chehab #define IS_INPUT_FORMATTER_VERSION2 199d4fa1a1SMauro Carvalho Chehab #define IS_INPUT_SWITCH_VERSION2 209d4fa1a1SMauro Carvalho Chehab 219d4fa1a1SMauro Carvalho Chehab #include <type_support.h> 229d4fa1a1SMauro Carvalho Chehab #include <system_types.h> 239d4fa1a1SMauro Carvalho Chehab #include "if_defs.h" 249d4fa1a1SMauro Carvalho Chehab #include "str2mem_defs.h" 259d4fa1a1SMauro Carvalho Chehab #include "input_switch_2400_defs.h" 269d4fa1a1SMauro Carvalho Chehab 279d4fa1a1SMauro Carvalho Chehab #define _HIVE_INPUT_SWITCH_GET_FSYNC_REG_LSB(ch_id) ((ch_id) * 3) 289d4fa1a1SMauro Carvalho Chehab 299d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_N_CHANNELS 4 309d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_N_FORMATTYPES 32 319d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_N_SWITCH_CODE 4 329d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_M_CHANNELS 0x00000003 339d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_M_FORMATTYPES 0x0000001f 349d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_M_SWITCH_CODE 0x00000003 359d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_M_FSYNC 0x00000007 369d4fa1a1SMauro Carvalho Chehab 379d4fa1a1SMauro Carvalho Chehab #define HIVE_SWITCH_ENCODE_FSYNC(x) \ 389d4fa1a1SMauro Carvalho Chehab (1U << (((x) - 1) & HIVE_SWITCH_M_CHANNELS)) 399d4fa1a1SMauro Carvalho Chehab 409d4fa1a1SMauro Carvalho Chehab #define _HIVE_INPUT_SWITCH_GET_LUT_FIELD(reg, bit_index) \ 419d4fa1a1SMauro Carvalho Chehab (((reg) >> (bit_index)) & HIVE_SWITCH_M_SWITCH_CODE) 429d4fa1a1SMauro Carvalho Chehab #define _HIVE_INPUT_SWITCH_SET_LUT_FIELD(reg, bit_index, val) \ 439d4fa1a1SMauro Carvalho Chehab (((reg) & ~(HIVE_SWITCH_M_SWITCH_CODE << (bit_index))) | (((hrt_data)(val) & HIVE_SWITCH_M_SWITCH_CODE) << (bit_index))) 449d4fa1a1SMauro Carvalho Chehab #define _HIVE_INPUT_SWITCH_GET_FSYNC_FIELD(reg, bit_index) \ 459d4fa1a1SMauro Carvalho Chehab (((reg) >> (bit_index)) & HIVE_SWITCH_M_FSYNC) 469d4fa1a1SMauro Carvalho Chehab #define _HIVE_INPUT_SWITCH_SET_FSYNC_FIELD(reg, bit_index, val) \ 479d4fa1a1SMauro Carvalho Chehab (((reg) & ~(HIVE_SWITCH_M_FSYNC << (bit_index))) | (((hrt_data)(val) & HIVE_SWITCH_M_FSYNC) << (bit_index))) 489d4fa1a1SMauro Carvalho Chehab 499d4fa1a1SMauro Carvalho Chehab typedef struct input_formatter_cfg_s input_formatter_cfg_t; 509d4fa1a1SMauro Carvalho Chehab 519d4fa1a1SMauro Carvalho Chehab /* Hardware registers */ 529d4fa1a1SMauro Carvalho Chehab /*#define HIVE_IF_RESET_ADDRESS 0x000*/ /* deprecated */ 539d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_START_LINE_ADDRESS 0x004 549d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_START_COLUMN_ADDRESS 0x008 559d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_CROPPED_HEIGHT_ADDRESS 0x00C 569d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_CROPPED_WIDTH_ADDRESS 0x010 579d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_VERTICAL_DECIMATION_ADDRESS 0x014 589d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_HORIZONTAL_DECIMATION_ADDRESS 0x018 599d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_H_DEINTERLEAVING_ADDRESS 0x01C 609d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_LEFTPADDING_WIDTH_ADDRESS 0x020 619d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_END_OF_LINE_OFFSET_ADDRESS 0x024 629d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_VMEM_START_ADDRESS_ADDRESS 0x028 639d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_VMEM_END_ADDRESS_ADDRESS 0x02C 649d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_VMEM_INCREMENT_ADDRESS 0x030 659d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_YUV_420_FORMAT_ADDRESS 0x034 669d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_VSYNCK_ACTIVE_LOW_ADDRESS 0x038 679d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_HSYNCK_ACTIVE_LOW_ADDRESS 0x03C 689d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_ALLOW_FIFO_OVERFLOW_ADDRESS 0x040 699d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_BLOCK_FIFO_NO_REQ_ADDRESS 0x044 709d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_V_DEINTERLEAVING_ADDRESS 0x048 719d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_FSM_CROP_PIXEL_COUNTER 0x110 729d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_FSM_CROP_LINE_COUNTER 0x10C 739d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_FSM_CROP_STATUS 0x108 749d4fa1a1SMauro Carvalho Chehab 759d4fa1a1SMauro Carvalho Chehab /* Registers only for simulation */ 769d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_CRUN_MODE_ADDRESS 0x04C 779d4fa1a1SMauro Carvalho Chehab #define HIVE_IF_DUMP_OUTPUT_ADDRESS 0x050 789d4fa1a1SMauro Carvalho Chehab 799d4fa1a1SMauro Carvalho Chehab /* Follow the DMA syntax, "cmd" last */ 809d4fa1a1SMauro Carvalho Chehab #define IF_PACK(val, cmd) ((val & 0x0fff) | (cmd /*& 0xf000*/)) 819d4fa1a1SMauro Carvalho Chehab 829d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_SOFT_RESET_REG_ADDRESS (_STR2MEM_SOFT_RESET_REG_ID * _STR2MEM_REG_ALIGN) 839d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_INPUT_ENDIANNESS_REG_ADDRESS (_STR2MEM_INPUT_ENDIANNESS_REG_ID * _STR2MEM_REG_ALIGN) 849d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_OUTPUT_ENDIANNESS_REG_ADDRESS (_STR2MEM_OUTPUT_ENDIANNESS_REG_ID * _STR2MEM_REG_ALIGN) 859d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_BIT_SWAPPING_REG_ADDRESS (_STR2MEM_BIT_SWAPPING_REG_ID * _STR2MEM_REG_ALIGN) 869d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_BLOCK_SYNC_LEVEL_REG_ADDRESS (_STR2MEM_BLOCK_SYNC_LEVEL_REG_ID * _STR2MEM_REG_ALIGN) 879d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_PACKET_SYNC_LEVEL_REG_ADDRESS (_STR2MEM_PACKET_SYNC_LEVEL_REG_ID * _STR2MEM_REG_ALIGN) 889d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_READ_POST_WRITE_SYNC_ENABLE_REG_ADDRESS (_STR2MEM_READ_POST_WRITE_SYNC_ENABLE_REG_ID * _STR2MEM_REG_ALIGN) 899d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_DUAL_BYTE_INPUTS_ENABLED_REG_ADDRESS (_STR2MEM_DUAL_BYTE_INPUTS_ENABLED_REG_ID * _STR2MEM_REG_ALIGN) 909d4fa1a1SMauro Carvalho Chehab #define HIVE_STR2MEM_EN_STAT_UPDATE_ADDRESS (_STR2MEM_EN_STAT_UPDATE_ID * _STR2MEM_REG_ALIGN) 919d4fa1a1SMauro Carvalho Chehab 929d4fa1a1SMauro Carvalho Chehab /* 939d4fa1a1SMauro Carvalho Chehab * This data structure is shared between host and SP 949d4fa1a1SMauro Carvalho Chehab */ 959d4fa1a1SMauro Carvalho Chehab struct input_formatter_cfg_s { 969d4fa1a1SMauro Carvalho Chehab u32 start_line; 979d4fa1a1SMauro Carvalho Chehab u32 start_column; 989d4fa1a1SMauro Carvalho Chehab u32 left_padding; 999d4fa1a1SMauro Carvalho Chehab u32 cropped_height; 1009d4fa1a1SMauro Carvalho Chehab u32 cropped_width; 1019d4fa1a1SMauro Carvalho Chehab u32 deinterleaving; 1029d4fa1a1SMauro Carvalho Chehab u32 buf_vecs; 1039d4fa1a1SMauro Carvalho Chehab u32 buf_start_index; 1049d4fa1a1SMauro Carvalho Chehab u32 buf_increment; 1059d4fa1a1SMauro Carvalho Chehab u32 buf_eol_offset; 1069d4fa1a1SMauro Carvalho Chehab u32 is_yuv420_format; 1079d4fa1a1SMauro Carvalho Chehab u32 block_no_reqs; 1089d4fa1a1SMauro Carvalho Chehab }; 1099d4fa1a1SMauro Carvalho Chehab 1109d4fa1a1SMauro Carvalho Chehab extern const hrt_address HIVE_IF_SRST_ADDRESS[N_INPUT_FORMATTER_ID]; 1119d4fa1a1SMauro Carvalho Chehab extern const hrt_data HIVE_IF_SRST_MASK[N_INPUT_FORMATTER_ID]; 1129d4fa1a1SMauro Carvalho Chehab extern const u8 HIVE_IF_SWITCH_CODE[N_INPUT_FORMATTER_ID]; 1139d4fa1a1SMauro Carvalho Chehab 1149d4fa1a1SMauro Carvalho Chehab #endif /* __INPUT_FORMATTER_GLOBAL_H_INCLUDED__ */ 115