| # SPDX-License-Identifier: GPL-2.0-only OR BSD-3-Clause |
| # Copyright (C) 2019--2020 Intel Corporation |
| |
| # register rflags |
| # - f field LSB MSB rflags |
| # - e enum value # after a field |
| # - e enum value [LSB MSB] |
| # - b bool bit |
| # - l arg name min max elsize [discontig...] |
| # |
| # rflags |
| # 8, 16, 32 register bits (default is 8) |
| # v1.1 defined in version 1.1 |
| # f formula |
| # float_ireal iReal or IEEE 754; 32 bits |
| # ireal unsigned iReal |
| |
| # general status registers |
| module_model_id 0x0000 16 |
| module_revision_number_major 0x0002 8 |
| frame_count 0x0005 8 |
| pixel_order 0x0006 8 |
| - e GRBG 0 |
| - e RGGB 1 |
| - e BGGR 2 |
| - e GBRG 3 |
| MIPI_CCS_version 0x0007 8 |
| - e v1_0 0x10 |
| - e v1_1 0x11 |
| - f major 4 7 |
| - f minor 0 3 |
| data_pedestal 0x0008 16 |
| module_manufacturer_id 0x000e 16 |
| module_revision_number_minor 0x0010 8 |
| module_date_year 0x0012 8 |
| module_date_month 0x0013 8 |
| module_date_day 0x0014 8 |
| module_date_phase 0x0015 8 |
| - f 0 2 |
| - e ts 0 |
| - e es 1 |
| - e cs 2 |
| - e mp 3 |
| sensor_model_id 0x0016 16 |
| sensor_revision_number 0x0018 8 |
| sensor_firmware_version 0x001a 8 |
| serial_number 0x001c 32 |
| sensor_manufacturer_id 0x0020 16 |
| sensor_revision_number_16 0x0022 16 |
| |
| # frame format description registers |
| frame_format_model_type 0x0040 8 |
| - e 2-byte 1 |
| - e 4-byte 2 |
| frame_format_model_subtype 0x0041 8 |
| - f rows 0 3 |
| - f columns 4 7 |
| frame_format_descriptor(n) 0x0042 16 f |
| - l n 0 14 2 |
| - f pixels 0 11 |
| - f pcode 12 15 |
| - e embedded 1 |
| - e dummy_pixel 2 |
| - e black_pixel 3 |
| - e dark_pixel 4 |
| - e visible_pixel 5 |
| - e manuf_specific_0 8 |
| - e manuf_specific_1 9 |
| - e manuf_specific_2 10 |
| - e manuf_specific_3 11 |
| - e manuf_specific_4 12 |
| - e manuf_specific_5 13 |
| - e manuf_specific_6 14 |
| frame_format_descriptor_4(n) 0x0060 32 f |
| - l n 0 7 4 |
| - f pixels 0 15 |
| - f pcode 28 31 |
| - e embedded 1 |
| - e dummy_pixel 2 |
| - e black_pixel 3 |
| - e dark_pixel 4 |
| - e visible_pixel 5 |
| - e manuf_specific_0 8 |
| - e manuf_specific_1 9 |
| - e manuf_specific_2 10 |
| - e manuf_specific_3 11 |
| - e manuf_specific_4 12 |
| - e manuf_specific_5 13 |
| - e manuf_specific_6 14 |
| |
| # analog gain description registers |
| analog_gain_capability 0x0080 16 |
| - e global 0 |
| - e alternate_global 2 |
| analog_gain_code_min 0x0084 16 |
| analog_gain_code_max 0x0086 16 |
| analog_gain_code_step 0x0088 16 |
| analog_gain_type 0x008a 16 |
| analog_gain_m0 0x008c 16 |
| analog_gain_c0 0x008e 16 |
| analog_gain_m1 0x0090 16 |
| analog_gain_c1 0x0092 16 |
| analog_linear_gain_min 0x0094 16 v1.1 |
| analog_linear_gain_max 0x0096 16 v1.1 |
| analog_linear_gain_step_size 0x0098 16 v1.1 |
| analog_exponential_gain_min 0x009a 16 v1.1 |
| analog_exponential_gain_max 0x009c 16 v1.1 |
| analog_exponential_gain_step_size 0x009e 16 v1.1 |
| |
| # data format description registers |
| data_format_model_type 0x00c0 8 |
| - e normal 1 |
| - e extended 2 |
| data_format_model_subtype 0x00c1 8 |
| - f rows 0 3 |
| - f columns 4 7 |
| data_format_descriptor(n) 0x00c2 16 f |
| - l n 0 15 2 |
| - f compressed 0 7 |
| - f uncompressed 8 15 |
| |
| # general set-up registers |
| mode_select 0x0100 8 |
| - e software_standby 0 |
| - e streaming 1 |
| image_orientation 0x0101 8 |
| - b horizontal_mirror 0 |
| - b vertical_flip 1 |
| software_reset 0x0103 8 |
| - e off 0 |
| - e on 1 |
| grouped_parameter_hold 0x0104 8 |
| mask_corrupted_frames 0x0105 8 |
| - e allow 0 |
| - e mask 1 |
| fast_standby_ctrl 0x0106 8 |
| - e complete_frames 0 |
| - e frame_truncation 1 |
| CCI_address_ctrl 0x0107 8 |
| 2nd_CCI_if_ctrl 0x0108 8 |
| - b enable 0 |
| - b ack 1 |
| 2nd_CCI_address_ctrl 0x0109 8 |
| CSI_channel_identifier 0x0110 8 |
| CSI_signaling_mode 0x0111 8 |
| - e csi_2_dphy 2 |
| - e csi_2_cphy 3 |
| CSI_data_format 0x0112 16 |
| CSI_lane_mode 0x0114 8 |
| DPCM_Frame_DT 0x011d 8 |
| Bottom_embedded_data_DT 0x011e 8 |
| Bottom_embedded_data_VC 0x011f 8 |
| |
| gain_mode 0x0120 8 |
| - e global 0 |
| - e alternate 1 |
| ADC_bit_depth 0x0121 8 |
| emb_data_ctrl 0x0122 v1.1 |
| - b raw8_packing_for_raw16 0 |
| - b raw10_packing_for_raw20 1 |
| - b raw12_packing_for_raw24 2 |
| |
| GPIO_TRIG_mode 0x0130 8 |
| extclk_frequency_mhz 0x0136 16 ireal |
| temp_sensor_ctrl 0x0138 8 |
| - b enable 0 |
| temp_sensor_mode 0x0139 8 |
| temp_sensor_output 0x013a 8 |
| |
| # integration time registers |
| fine_integration_time 0x0200 16 |
| coarse_integration_time 0x0202 16 |
| |
| # analog gain registers |
| analog_gain_code_global 0x0204 16 |
| analog_linear_gain_global 0x0206 16 v1.1 |
| analog_exponential_gain_global 0x0208 16 v1.1 |
| |
| # digital gain registers |
| digital_gain_global 0x020e 16 |
| |
| # hdr control registers |
| Short_analog_gain_global 0x0216 16 |
| Short_digital_gain_global 0x0218 16 |
| |
| HDR_mode 0x0220 8 |
| - b enabled 0 |
| - b separate_analog_gain 1 |
| - b upscaling 2 |
| - b reset_sync 3 |
| - b timing_mode 4 |
| - b exposure_ctrl_direct 5 |
| - b separate_digital_gain 6 |
| HDR_resolution_reduction 0x0221 8 |
| - f row 0 3 |
| - f column 4 7 |
| Exposure_ratio 0x0222 8 |
| HDR_internal_bit_depth 0x0223 8 |
| Direct_short_integration_time 0x0224 16 |
| Short_analog_linear_gain_global 0x0226 16 v1.1 |
| Short_analog_exponential_gain_global 0x0228 16 v1.1 |
| |
| # clock set-up registers |
| vt_pix_clk_div 0x0300 16 |
| vt_sys_clk_div 0x0302 16 |
| pre_pll_clk_div 0x0304 16 |
| #vt_pre_pll_clk_div 0x0304 16 |
| pll_multiplier 0x0306 16 |
| #vt_pll_multiplier 0x0306 16 |
| op_pix_clk_div 0x0308 16 |
| op_sys_clk_div 0x030a 16 |
| op_pre_pll_clk_div 0x030c 16 |
| op_pll_multiplier 0x031e 16 |
| pll_mode 0x0310 8 |
| - f 0 0 |
| - e single 0 |
| - e dual 1 |
| op_pix_clk_div_rev 0x0312 16 v1.1 |
| op_sys_clk_div_rev 0x0314 16 v1.1 |
| |
| # frame timing registers |
| frame_length_lines 0x0340 16 |
| line_length_pck 0x0342 16 |
| |
| # image size registers |
| x_addr_start 0x0344 16 |
| y_addr_start 0x0346 16 |
| x_addr_end 0x0348 16 |
| y_addr_end 0x034a 16 |
| x_output_size 0x034c 16 |
| y_output_size 0x034e 16 |
| |
| # timing mode registers |
| Frame_length_ctrl 0x0350 8 |
| - b automatic 0 |
| Timing_mode_ctrl 0x0352 8 |
| - b manual_readout 0 |
| - b delayed_exposure 1 |
| Start_readout_rs 0x0353 8 |
| - b manual_readout_start 0 |
| Frame_margin 0x0354 16 |
| |
| # sub-sampling registers |
| x_even_inc 0x0380 16 |
| x_odd_inc 0x0382 16 |
| y_even_inc 0x0384 16 |
| y_odd_inc 0x0386 16 |
| |
| # monochrome readout registers |
| monochrome_en 0x0390 v1.1 |
| - e enabled 0 |
| |
| # image scaling registers |
| Scaling_mode 0x0400 16 |
| - e no_scaling 0 |
| - e horizontal 1 |
| scale_m 0x0404 16 |
| scale_n 0x0406 16 |
| digital_crop_x_offset 0x0408 16 |
| digital_crop_y_offset 0x040a 16 |
| digital_crop_image_width 0x040c 16 |
| digital_crop_image_height 0x040e 16 |
| |
| # image compression registers |
| compression_mode 0x0500 16 |
| - e none 0 |
| - e dpcm_pcm_simple 1 |
| |
| # test pattern registers |
| test_pattern_mode 0x0600 16 |
| - e none 0 |
| - e solid_color 1 |
| - e color_bars 2 |
| - e fade_to_grey 3 |
| - e pn9 4 |
| - e color_tile 5 |
| test_data_red 0x0602 16 |
| test_data_greenR 0x0604 16 |
| test_data_blue 0x0606 16 |
| test_data_greenB 0x0608 16 |
| value_step_size_smooth 0x060a 8 |
| value_step_size_quantised 0x060b 8 |
| |
| # phy configuration registers |
| tclk_post 0x0800 8 |
| ths_prepare 0x0801 8 |
| ths_zero_min 0x0802 8 |
| ths_trail 0x0803 8 |
| tclk_trail_min 0x0804 8 |
| tclk_prepare 0x0805 8 |
| tclk_zero 0x0806 8 |
| tlpx 0x0807 8 |
| phy_ctrl 0x0808 8 |
| - e auto 0 |
| - e UI 1 |
| - e manual 2 |
| tclk_post_ex 0x080a 16 |
| ths_prepare_ex 0x080c 16 |
| ths_zero_min_ex 0x080e 16 |
| ths_trail_ex 0x0810 16 |
| tclk_trail_min_ex 0x0812 16 |
| tclk_prepare_ex 0x0814 16 |
| tclk_zero_ex 0x0816 16 |
| tlpx_ex 0x0818 16 |
| |
| # link rate register |
| requested_link_rate 0x0820 32 u16.16 |
| |
| # equalization control registers |
| DPHY_equalization_mode 0x0824 8 v1.1 |
| - b eq2 0 |
| PHY_equalization_ctrl 0x0825 8 v1.1 |
| - b enable 0 |
| |
| # d-phy preamble control registers |
| DPHY_preamble_ctrl 0x0826 8 v1.1 |
| - b enable 0 |
| DPHY_preamble_length 0x0826 8 v1.1 |
| |
| # d-phy spread spectrum control registers |
| PHY_SSC_ctrl 0x0828 8 v1.1 |
| - b enable 0 |
| |
| # manual lp control register |
| manual_LP_ctrl 0x0829 8 v1.1 |
| - b enable 0 |
| |
| # additional phy configuration registers |
| twakeup 0x082a v1.1 |
| tinit 0x082b v1.1 |
| ths_exit 0x082c v1.1 |
| ths_exit_ex 0x082e 16 v1.1 |
| |
| # phy calibration configuration registers |
| PHY_periodic_calibration_ctrl 0x0830 8 |
| - b frame_blanking 0 |
| PHY_periodic_calibration_interval 0x0831 8 |
| PHY_init_calibration_ctrl 0x0832 8 |
| - b stream_start 0 |
| DPHY_calibration_mode 0x0833 8 v1.1 |
| - b also_alternate 0 |
| CPHY_calibration_mode 0x0834 8 v1.1 |
| - e format_1 0 |
| - e format_2 1 |
| - e format_3 2 |
| t3_calpreamble_length 0x0835 8 v1.1 |
| t3_calpreamble_length_per 0x0836 8 v1.1 |
| t3_calaltseq_length 0x0837 8 v1.1 |
| t3_calaltseq_length_per 0x0838 8 v1.1 |
| FM2_init_seed 0x083a 16 v1.1 |
| t3_caludefseq_length 0x083c 16 v1.1 |
| t3_caludefseq_length_per 0x083e 16 v1.1 |
| |
| # c-phy manual control registers |
| TGR_Preamble_Length 0x0841 8 |
| - b preamable_prog_seq 7 |
| - f begin_preamble_length 0 5 |
| TGR_Post_Length 0x0842 8 |
| - f post_length 0 4 |
| TGR_Preamble_Prog_Sequence(n2) 0x0843 |
| - l n2 0 6 1 |
| - f symbol_n_1 3 5 |
| - f symbol_n 0 2 |
| t3_prepare 0x084e 16 |
| t3_lpx 0x0850 16 |
| |
| # alps control register |
| ALPS_ctrl 0x085a 8 |
| - b lvlp_dphy 0 |
| - b lvlp_cphy 1 |
| - b alp_cphy 2 |
| |
| # lrte control registers |
| TX_REG_CSI_EPD_EN_SSP_cphy 0x0860 16 |
| TX_REG_CSI_EPD_OP_SLP_cphy 0x0862 16 |
| TX_REG_CSI_EPD_EN_SSP_dphy 0x0864 16 |
| TX_REG_CSI_EPD_OP_SLP_dphy 0x0866 16 |
| TX_REG_CSI_EPD_MISC_OPTION_cphy 0x0868 v1.1 |
| TX_REG_CSI_EPD_MISC_OPTION_dphy 0x0869 v1.1 |
| |
| # scrambling control registers |
| Scrambling_ctrl 0x0870 |
| - b enabled 0 |
| - f 2 3 |
| - e 1_seed_cphy 0 |
| - e 4_seed_cphy 3 |
| lane_seed_value(seed, lane) 0x0872 16 |
| - l seed 0 3 0x10 |
| - l lane 0 7 0x2 |
| |
| # usl control registers |
| TX_USL_REV_ENTRY 0x08c0 16 v1.1 |
| TX_USL_REV_Clock_Counter 0x08c2 16 v1.1 |
| TX_USL_REV_LP_Counter 0x08c4 16 v1.1 |
| TX_USL_REV_Frame_Counter 0x08c6 16 v1.1 |
| TX_USL_REV_Chronological_Timer 0x08c8 16 v1.1 |
| TX_USL_FWD_ENTRY 0x08ca 16 v1.1 |
| TX_USL_GPIO 0x08cc 16 v1.1 |
| TX_USL_Operation 0x08ce 16 v1.1 |
| - b reset 0 |
| TX_USL_ALP_ctrl 0x08d0 16 v1.1 |
| - b clock_pause 0 |
| TX_USL_APP_BTA_ACK_TIMEOUT 0x08d2 16 v1.1 |
| TX_USL_SNS_BTA_ACK_TIMEOUT 0x08d2 16 v1.1 |
| USL_Clock_Mode_d_ctrl 0x08d2 v1.1 |
| - b cont_clock_standby 0 |
| - b cont_clock_vblank 1 |
| - b cont_clock_hblank 2 |
| |
| # binning configuration registers |
| binning_mode 0x0900 8 |
| binning_type 0x0901 8 |
| binning_weighting 0x0902 8 |
| |
| # data transfer interface registers |
| data_transfer_if_1_ctrl 0x0a00 8 |
| - b enable 0 |
| - b write 1 |
| - b clear_error 2 |
| data_transfer_if_1_status 0x0a01 8 |
| - b read_if_ready 0 |
| - b write_if_ready 1 |
| - b data_corrupted 2 |
| - b improper_if_usage 3 |
| data_transfer_if_1_page_select 0x0a02 8 |
| data_transfer_if_1_data(p) 0x0a04 8 f |
| - l p 0 63 1 |
| |
| # image processing and sensor correction configuration registers |
| shading_correction_en 0x0b00 8 |
| - b enable 0 |
| luminance_correction_level 0x0b01 8 |
| green_imbalance_filter_en 0x0b02 8 |
| - b enable 0 |
| mapped_defect_correct_en 0x0b05 8 |
| - b enable 0 |
| single_defect_correct_en 0x0b06 8 |
| - b enable 0 |
| dynamic_couplet_correct_en 0x0b08 8 |
| - b enable 0 |
| combined_defect_correct_en 0x0b0a 8 |
| - b enable 0 |
| module_specific_correction_en 0x0b0c 8 |
| - b enable 0 |
| dynamic_triplet_defect_correct_en 0x0b13 8 |
| - b enable 0 |
| NF_ctrl 0x0b15 8 |
| - b luma 0 |
| - b chroma 1 |
| - b combined 2 |
| |
| # optical black pixel readout registers |
| OB_readout_control 0x0b30 8 |
| - b enable 0 |
| - b interleaving 1 |
| OB_virtual_channel 0x0b31 8 |
| OB_DT 0x0b32 8 |
| OB_data_format 0x0b33 8 |
| |
| # color temperature feedback registers |
| color_temperature 0x0b8c 16 |
| absolute_gain_greenr 0x0b8e 16 |
| absolute_gain_red 0x0b90 16 |
| absolute_gain_blue 0x0b92 16 |
| absolute_gain_greenb 0x0b94 16 |
| |
| # cfa conversion registers |
| CFA_conversion_ctrl 0x0ba0 v1.1 |
| - b bayer_conversion_enable 0 |
| |
| # flash strobe and sa strobe control registers |
| flash_strobe_adjustment 0x0c12 8 |
| flash_strobe_start_point 0x0c14 16 |
| tflash_strobe_delay_rs_ctrl 0x0c16 16 |
| tflash_strobe_width_high_rs_ctrl 0x0c18 16 |
| flash_mode_rs 0x0c1a 8 |
| - b continuous 0 |
| - b truncate 1 |
| - b async 3 |
| flash_trigger_rs 0x0c1b 8 |
| flash_status 0x0c1c 8 |
| - b retimed 0 |
| sa_strobe_mode 0x0c1d 8 |
| - b continuous 0 |
| - b truncate 1 |
| - b async 3 |
| - b adjust_edge 4 |
| sa_strobe_start_point 0x0c1e 16 |
| tsa_strobe_delay_ctrl 0x0c20 16 |
| tsa_strobe_width_ctrl 0x0c22 16 |
| sa_strobe_trigger 0x0c24 8 |
| sa_strobe_status 0x0c25 8 |
| - b retimed 0 |
| tSA_strobe_re_delay_ctrl 0x0c30 16 |
| tSA_strobe_fe_delay_ctrl 0x0c32 16 |
| |
| # pdaf control registers |
| PDAF_ctrl 0x0d00 16 |
| - b enable 0 |
| - b processed 1 |
| - b interleaved 2 |
| - b visible_pdaf_correction 3 |
| PDAF_VC 0x0d02 8 |
| PDAF_DT 0x0d03 8 |
| pd_x_addr_start 0x0d04 16 |
| pd_y_addr_start 0x0d06 16 |
| pd_x_addr_end 0x0d08 16 |
| pd_y_addr_end 0x0d0a 16 |
| |
| # bracketing interface configuration registers |
| bracketing_LUT_ctrl 0x0e00 8 |
| bracketing_LUT_mode 0x0e01 8 |
| - b continue_streaming 0 |
| - b loop_mode 1 |
| bracketing_LUT_entry_ctrl 0x0e02 8 |
| bracketing_LUT_frame(n) 0x0e10 v1.1 f |
| - l n 0 0xef 1 |
| |
| # integration time and gain parameter limit registers |
| integration_time_capability 0x1000 16 |
| - b fine 0 |
| coarse_integration_time_min 0x1004 16 |
| coarse_integration_time_max_margin 0x1006 16 |
| fine_integration_time_min 0x1008 16 |
| fine_integration_time_max_margin 0x100a 16 |
| |
| # digital gain parameter limit registers |
| digital_gain_capability 0x1081 |
| - e none 0 |
| - e global 2 |
| digital_gain_min 0x1084 16 |
| digital_gain_max 0x1086 16 |
| digital_gain_step_size 0x1088 16 |
| |
| # data pedestal capability registers |
| Pedestal_capability 0x10e0 8 v1.1 |
| |
| # adc capability registers |
| ADC_capability 0x10f0 8 |
| - b bit_depth_ctrl 0 |
| ADC_bit_depth_capability 0x10f4 32 v1.1 |
| |
| # video timing parameter limit registers |
| min_ext_clk_freq_mhz 0x1100 32 float_ireal |
| max_ext_clk_freq_mhz 0x1104 32 float_ireal |
| min_pre_pll_clk_div 0x1108 16 |
| # min_vt_pre_pll_clk_div 0x1108 16 |
| max_pre_pll_clk_div 0x110a 16 |
| # max_vt_pre_pll_clk_div 0x110a 16 |
| min_pll_ip_clk_freq_mhz 0x110c 32 float_ireal |
| # min_vt_pll_ip_clk_freq_mhz 0x110c 32 float_ireal |
| max_pll_ip_clk_freq_mhz 0x1110 32 float_ireal |
| # max_vt_pll_ip_clk_freq_mhz 0x1110 32 float_ireal |
| min_pll_multiplier 0x1114 16 |
| # min_vt_pll_multiplier 0x1114 16 |
| max_pll_multiplier 0x1116 16 |
| # max_vt_pll_multiplier 0x1116 16 |
| min_pll_op_clk_freq_mhz 0x1118 32 float_ireal |
| max_pll_op_clk_freq_mhz 0x111c 32 float_ireal |
| |
| # video timing set-up capability registers |
| min_vt_sys_clk_div 0x1120 16 |
| max_vt_sys_clk_div 0x1122 16 |
| min_vt_sys_clk_freq_mhz 0x1124 32 float_ireal |
| max_vt_sys_clk_freq_mhz 0x1128 32 float_ireal |
| min_vt_pix_clk_freq_mhz 0x112c 32 float_ireal |
| max_vt_pix_clk_freq_mhz 0x1130 32 float_ireal |
| min_vt_pix_clk_div 0x1134 16 |
| max_vt_pix_clk_div 0x1136 16 |
| clock_calculation 0x1138 |
| - b lane_speed 0 |
| - b link_decoupled 1 |
| - b dual_pll_op_sys_ddr 2 |
| - b dual_pll_op_pix_ddr 3 |
| num_of_vt_lanes 0x1139 |
| num_of_op_lanes 0x113a |
| op_bits_per_lane 0x113b 8 v1.1 |
| |
| # frame timing parameter limits |
| min_frame_length_lines 0x1140 16 |
| max_frame_length_lines 0x1142 16 |
| min_line_length_pck 0x1144 16 |
| max_line_length_pck 0x1146 16 |
| min_line_blanking_pck 0x1148 16 |
| min_frame_blanking_lines 0x114a 16 |
| min_line_length_pck_step_size 0x114c |
| timing_mode_capability 0x114d |
| - b auto_frame_length 0 |
| - b rolling_shutter_manual_readout 2 |
| - b delayed_exposure_start 3 |
| - b manual_exposure_embedded_data 4 |
| frame_margin_max_value 0x114e 16 |
| frame_margin_min_value 0x1150 |
| gain_delay_type 0x1151 |
| - e fixed 0 |
| - e variable 1 |
| |
| # output clock set-up capability registers |
| min_op_sys_clk_div 0x1160 16 |
| max_op_sys_clk_div 0x1162 16 |
| min_op_sys_clk_freq_mhz 0x1164 32 float_ireal |
| max_op_sys_clk_freq_mhz 0x1168 32 float_ireal |
| min_op_pix_clk_div 0x116c 16 |
| max_op_pix_clk_div 0x116e 16 |
| min_op_pix_clk_freq_mhz 0x1170 32 float_ireal |
| max_op_pix_clk_freq_mhz 0x1174 32 float_ireal |
| |
| # image size parameter limit registers |
| x_addr_min 0x1180 16 |
| y_addr_min 0x1182 16 |
| x_addr_max 0x1184 16 |
| y_addr_max 0x1186 16 |
| min_x_output_size 0x1188 16 |
| min_y_output_size 0x118a 16 |
| max_x_output_size 0x118c 16 |
| max_y_output_size 0x118e 16 |
| |
| x_addr_start_div_constant 0x1190 v1.1 |
| y_addr_start_div_constant 0x1191 v1.1 |
| x_addr_end_div_constant 0x1192 v1.1 |
| y_addr_end_div_constant 0x1193 v1.1 |
| x_size_div 0x1194 v1.1 |
| y_size_div 0x1195 v1.1 |
| x_output_div 0x1196 v1.1 |
| y_output_div 0x1197 v1.1 |
| non_flexible_resolution_support 0x1198 v1.1 |
| - b new_pix_addr 0 |
| - b new_output_res 1 |
| - b output_crop_no_pad 2 |
| - b output_size_lane_dep 3 |
| |
| min_op_pre_pll_clk_div 0x11a0 16 |
| max_op_pre_pll_clk_div 0x11a2 16 |
| min_op_pll_ip_clk_freq_mhz 0x11a4 32 float_ireal |
| max_op_pll_ip_clk_freq_mhz 0x11a8 32 float_ireal |
| min_op_pll_multiplier 0x11ac 16 |
| max_op_pll_multiplier 0x11ae 16 |
| min_op_pll_op_clk_freq_mhz 0x11b0 32 float_ireal |
| max_op_pll_op_clk_freq_mhz 0x11b4 32 float_ireal |
| clock_tree_pll_capability 0x11b8 8 |
| - b dual_pll 0 |
| - b single_pll 1 |
| - b ext_divider 2 |
| - b flexible_op_pix_clk_div 3 |
| clock_capa_type_capability 0x11b9 v1.1 |
| - b ireal 0 |
| |
| # sub-sampling parameters limit registers |
| min_even_inc 0x11c0 16 |
| min_odd_inc 0x11c2 16 |
| max_even_inc 0x11c4 16 |
| max_odd_inc 0x11c6 16 |
| aux_subsamp_capability 0x11c8 v1.1 |
| - b factor_power_of_2 1 |
| aux_subsamp_mono_capability 0x11c9 v1.1 |
| - b factor_power_of_2 1 |
| monochrome_capability 0x11ca v1.1 |
| - e inc_odd 0 |
| - e inc_even 1 |
| pixel_readout_capability 0x11cb v1.1 |
| - e bayer 0 |
| - e monochrome 1 |
| - e bayer_and_mono 2 |
| min_even_inc_mono 0x11cc 16 v1.1 |
| max_even_inc_mono 0x11ce 16 v1.1 |
| min_odd_inc_mono 0x11d0 16 v1.1 |
| max_odd_inc_mono 0x11d2 16 v1.1 |
| min_even_inc_bc2 0x11d4 16 v1.1 |
| max_even_inc_bc2 0x11d6 16 v1.1 |
| min_odd_inc_bc2 0x11d8 16 v1.1 |
| max_odd_inc_bc2 0x11da 16 v1.1 |
| min_even_inc_mono_bc2 0x11dc 16 v1.1 |
| max_even_inc_mono_bc2 0x11de 16 v1.1 |
| min_odd_inc_mono_bc2 0x11f0 16 v1.1 |
| max_odd_inc_mono_bc2 0x11f2 16 v1.1 |
| |
| # image scaling limit parameters |
| scaling_capability 0x1200 16 |
| - e none 0 |
| - e horizontal 1 |
| - e reserved 2 |
| scaler_m_min 0x1204 16 |
| scaler_m_max 0x1206 16 |
| scaler_n_min 0x1208 16 |
| scaler_n_max 0x120a 16 |
| digital_crop_capability 0x120e |
| - e none 0 |
| - e input_crop 1 |
| |
| # hdr limit registers |
| hdr_capability_1 0x1210 |
| - b 2x2_binning 0 |
| - b combined_analog_gain 1 |
| - b separate_analog_gain 2 |
| - b upscaling 3 |
| - b reset_sync 4 |
| - b direct_short_exp_timing 5 |
| - b direct_short_exp_synthesis 6 |
| min_hdr_bit_depth 0x1211 |
| hdr_resolution_sub_types 0x1212 |
| hdr_resolution_sub_type(n) 0x1213 |
| - l n 0 1 1 |
| - f row 0 3 |
| - f column 4 7 |
| hdr_capability_2 0x121b |
| - b combined_digital_gain 0 |
| - b separate_digital_gain 1 |
| - b timing_mode 3 |
| - b synthesis_mode 4 |
| max_hdr_bit_depth 0x121c |
| |
| # usl capability register |
| usl_support_capability 0x1230 v1.1 |
| - b clock_tree 0 |
| - b rev_clock_tree 1 |
| - b rev_clock_calc 2 |
| usl_clock_mode_d_capability 0x1231 v1.1 |
| - b cont_clock_standby 0 |
| - b cont_clock_vblank 1 |
| - b cont_clock_hblank 2 |
| - b noncont_clock_standby 3 |
| - b noncont_clock_vblank 4 |
| - b noncont_clock_hblank 5 |
| min_op_sys_clk_div_rev 0x1234 v1.1 |
| max_op_sys_clk_div_rev 0x1236 v1.1 |
| min_op_pix_clk_div_rev 0x1238 v1.1 |
| max_op_pix_clk_div_rev 0x123a v1.1 |
| min_op_sys_clk_freq_rev_mhz 0x123c 32 v1.1 float_ireal |
| max_op_sys_clk_freq_rev_mhz 0x1240 32 v1.1 float_ireal |
| min_op_pix_clk_freq_rev_mhz 0x1244 32 v1.1 float_ireal |
| max_op_pix_clk_freq_rev_mhz 0x1248 32 v1.1 float_ireal |
| max_bitrate_rev_d_mode_mbps 0x124c 32 v1.1 ireal |
| max_symrate_rev_c_mode_msps 0x1250 32 v1.1 ireal |
| |
| # image compression capability registers |
| compression_capability 0x1300 |
| - b dpcm_pcm_simple 0 |
| |
| # test mode capability registers |
| test_mode_capability 0x1310 16 |
| - b solid_color 0 |
| - b color_bars 1 |
| - b fade_to_grey 2 |
| - b pn9 3 |
| - b color_tile 5 |
| pn9_data_format1 0x1312 |
| pn9_data_format2 0x1313 |
| pn9_data_format3 0x1314 |
| pn9_data_format4 0x1315 |
| pn9_misc_capability 0x1316 |
| - f num_pixels 0 2 |
| - b compression 3 |
| test_pattern_capability 0x1317 v1.1 |
| - b no_repeat 1 |
| pattern_size_div_m1 0x1318 v1.1 |
| |
| # fifo capability registers |
| fifo_support_capability 0x1502 |
| - e none 0 |
| - e derating 1 |
| - e derating_overrating 2 |
| |
| # csi-2 capability registers |
| phy_ctrl_capability 0x1600 |
| - b auto_phy_ctl 0 |
| - b ui_phy_ctl 1 |
| - b dphy_time_ui_reg_1_ctl 2 |
| - b dphy_time_ui_reg_2_ctl 3 |
| - b dphy_time_ctl 4 |
| - b dphy_ext_time_ui_reg_1_ctl 5 |
| - b dphy_ext_time_ui_reg_2_ctl 6 |
| - b dphy_ext_time_ctl 7 |
| csi_dphy_lane_mode_capability 0x1601 |
| - b 1_lane 0 |
| - b 2_lane 1 |
| - b 3_lane 2 |
| - b 4_lane 3 |
| - b 5_lane 4 |
| - b 6_lane 5 |
| - b 7_lane 6 |
| - b 8_lane 7 |
| csi_signaling_mode_capability 0x1602 |
| - b csi_dphy 2 |
| - b csi_cphy 3 |
| fast_standby_capability 0x1603 |
| - e no_frame_truncation 0 |
| - e frame_truncation 1 |
| csi_address_control_capability 0x1604 |
| - b cci_addr_change 0 |
| - b 2nd_cci_addr 1 |
| - b sw_changeable_2nd_cci_addr 2 |
| data_type_capability 0x1605 |
| - b dpcm_programmable 0 |
| - b bottom_embedded_dt_programmable 1 |
| - b bottom_embedded_vc_programmable 2 |
| - b ext_vc_range 3 |
| csi_cphy_lane_mode_capability 0x1606 |
| - b 1_lane 0 |
| - b 2_lane 1 |
| - b 3_lane 2 |
| - b 4_lane 3 |
| - b 5_lane 4 |
| - b 6_lane 5 |
| - b 7_lane 6 |
| - b 8_lane 7 |
| emb_data_capability 0x1607 v1.1 |
| - b two_bytes_per_raw16 0 |
| - b two_bytes_per_raw20 1 |
| - b two_bytes_per_raw24 2 |
| - b no_one_byte_per_raw16 3 |
| - b no_one_byte_per_raw20 4 |
| - b no_one_byte_per_raw24 5 |
| max_per_lane_bitrate_lane_d_mode_mbps(n) 0x1608 32 ireal |
| - l n 0 7 4 4,0x32 |
| temp_sensor_capability 0x1618 |
| - b supported 0 |
| - b CCS_format 1 |
| - b reset_0x80 2 |
| max_per_lane_bitrate_lane_c_mode_mbps(n) 0x161a 32 ireal |
| - l n 0 7 4 4,0x30 |
| dphy_equalization_capability 0x162b |
| - b equalization_ctrl 0 |
| - b eq1 1 |
| - b eq2 2 |
| cphy_equalization_capability 0x162c |
| - b equalization_ctrl 0 |
| dphy_preamble_capability 0x162d |
| - b preamble_seq_ctrl 0 |
| dphy_ssc_capability 0x162e |
| - b supported 0 |
| cphy_calibration_capability 0x162f |
| - b manual 0 |
| - b manual_streaming 1 |
| - b format_1_ctrl 2 |
| - b format_2_ctrl 3 |
| - b format_3_ctrl 4 |
| dphy_calibration_capability 0x1630 |
| - b manual 0 |
| - b manual_streaming 1 |
| - b alternate_seq 2 |
| phy_ctrl_capability_2 0x1631 |
| - b tgr_length 0 |
| - b tgr_preamble_prog_seq 1 |
| - b extra_cphy_manual_timing 2 |
| - b clock_based_manual_cdphy 3 |
| - b clock_based_manual_dphy 4 |
| - b clock_based_manual_cphy 5 |
| - b manual_lp_dphy 6 |
| - b manual_lp_cphy 7 |
| lrte_cphy_capability 0x1632 |
| - b pdq_short 0 |
| - b spacer_short 1 |
| - b pdq_long 2 |
| - b spacer_long 3 |
| - b spacer_no_pdq 4 |
| lrte_dphy_capability 0x1633 |
| - b pdq_short_opt1 0 |
| - b spacer_short_opt1 1 |
| - b pdq_long_opt1 2 |
| - b spacer_long_opt1 3 |
| - b spacer_short_opt2 4 |
| - b spacer_long_opt2 5 |
| - b spacer_no_pdq_opt1 6 |
| - b spacer_variable_opt2 7 |
| alps_capability_dphy 0x1634 |
| - e lvlp_not_supported 0 0x3 |
| - e lvlp_supported 1 0x3 |
| - e controllable_lvlp 2 0x3 |
| alps_capability_cphy 0x1635 |
| - e lvlp_not_supported 0 0x3 |
| - e lvlp_supported 1 0x3 |
| - e controllable_lvlp 2 0x3 |
| - e alp_not_supported 0xc 0xc |
| - e alp_supported 0xd 0xc |
| - e controllable_alp 0xe 0xc |
| scrambling_capability 0x1636 |
| - b scrambling_supported 0 |
| - f max_seeds_per_lane_c 1 2 |
| - e 1 0 |
| - e 4 3 |
| - f num_seed_regs 3 5 |
| - e 0 0 |
| - e 1 1 |
| - e 4 4 |
| - b num_seed_per_lane 6 |
| dphy_manual_constant 0x1637 |
| cphy_manual_constant 0x1638 |
| CSI2_interface_capability_misc 0x1639 v1.1 |
| - b eotp_short_pkt_opt2 0 |
| PHY_ctrl_capability_3 0x165c v1.1 |
| - b dphy_timing_not_multiple 0 |
| - b dphy_min_timing_value_1 1 |
| - b twakeup_supported 2 |
| - b tinit_supported 3 |
| - b ths_exit_supported 4 |
| - b cphy_timing_not_multiple 5 |
| - b cphy_min_timing_value_1 6 |
| dphy_sf 0x165d v1.1 |
| cphy_sf 0x165e v1.1 |
| - f twakeup 0 3 |
| - f tinit 4 7 |
| dphy_limits_1 0x165f v1.1 |
| - f ths_prepare 0 3 |
| - f ths_zero 4 7 |
| dphy_limits_2 0x1660 v1.1 |
| - f ths_trail 0 3 |
| - f tclk_trail_min 4 7 |
| dphy_limits_3 0x1661 v1.1 |
| - f tclk_prepare 0 3 |
| - f tclk_zero 4 7 |
| dphy_limits_4 0x1662 v1.1 |
| - f tclk_post 0 3 |
| - f tlpx 4 7 |
| dphy_limits_5 0x1663 v1.1 |
| - f ths_exit 0 3 |
| - f twakeup 4 7 |
| dphy_limits_6 0x1664 v1.1 |
| - f tinit 0 3 |
| cphy_limits_1 0x1665 v1.1 |
| - f t3_prepare_max 0 3 |
| - f t3_lpx_max 4 7 |
| cphy_limits_2 0x1666 v1.1 |
| - f ths_exit_max 0 3 |
| - f twakeup_max 4 7 |
| cphy_limits_3 0x1667 v1.1 |
| - f tinit_max 0 3 |
| |
| # binning capability registers |
| min_frame_length_lines_bin 0x1700 16 |
| max_frame_length_lines_bin 0x1702 16 |
| min_line_length_pck_bin 0x1704 16 |
| max_line_length_pck_bin 0x1706 16 |
| min_line_blanking_pck_bin 0x1708 16 |
| fine_integration_time_min_bin 0x170a 16 |
| fine_integration_time_max_margin_bin 0x170c 16 |
| binning_capability 0x1710 |
| - e unsupported 0 |
| - e binning_then_subsampling 1 |
| - e subsampling_then_binning 2 |
| binning_weighting_capability 0x1711 |
| - b averaged 0 |
| - b summed 1 |
| - b bayer_corrected 2 |
| - b module_specific_weight 3 |
| binning_sub_types 0x1712 |
| binning_sub_type(n) 0x1713 |
| - l n 0 63 1 |
| - f row 0 3 |
| - f column 4 7 |
| binning_weighting_mono_capability 0x1771 v1.1 |
| - b averaged 0 |
| - b summed 1 |
| - b bayer_corrected 2 |
| - b module_specific_weight 3 |
| binning_sub_types_mono 0x1772 v1.1 |
| binning_sub_type_mono(n) 0x1773 v1.1 f |
| - l n 0 63 1 |
| |
| # data transfer interface capability registers |
| data_transfer_if_capability 0x1800 |
| - b supported 0 |
| - b polling 2 |
| |
| # sensor correction capability registers |
| shading_correction_capability 0x1900 |
| - b color_shading 0 |
| - b luminance_correction 1 |
| green_imbalance_capability 0x1901 |
| - b supported 0 |
| module_specific_correction_capability 0x1903 |
| defect_correction_capability 0x1904 16 |
| - b mapped_defect 0 |
| - b dynamic_couplet 2 |
| - b dynamic_single 5 |
| - b combined_dynamic 8 |
| defect_correction_capability_2 0x1906 16 |
| - b dynamic_triplet 3 |
| nf_capability 0x1908 |
| - b luma 0 |
| - b chroma 1 |
| - b combined 2 |
| |
| # optical black readout capability registers |
| ob_readout_capability 0x1980 |
| - b controllable_readout 0 |
| - b visible_pixel_readout 1 |
| - b different_vc_readout 2 |
| - b different_dt_readout 3 |
| - b prog_data_format 4 |
| |
| # color feedback capability registers |
| color_feedback_capability 0x1987 |
| - b kelvin 0 |
| - b awb_gain 1 |
| |
| # cfa pattern capability registers |
| CFA_pattern_capability 0x1990 v1.1 |
| - e bayer 0 |
| - e monochrome 1 |
| - e 4x4_quad_bayer 2 |
| - e vendor_specific 3 |
| CFA_pattern_conversion_capability 0x1991 v1.1 |
| - b bayer 0 |
| |
| # timer capability registers |
| flash_mode_capability 0x1a02 |
| - b single_strobe 0 |
| sa_strobe_mode_capability 0x1a03 |
| - b fixed_width 0 |
| - b edge_ctrl 1 |
| |
| # soft reset capability registers |
| reset_max_delay 0x1a10 v1.1 |
| reset_min_time 0x1a11 v1.1 |
| |
| # pdaf capability registers |
| pdaf_capability_1 0x1b80 |
| - b supported 0 |
| - b processed_bottom_embedded 1 |
| - b processed_interleaved 2 |
| - b raw_bottom_embedded 3 |
| - b raw_interleaved 4 |
| - b visible_pdaf_correction 5 |
| - b vc_interleaving 6 |
| - b dt_interleaving 7 |
| pdaf_capability_2 0x1b81 |
| - b ROI 0 |
| - b after_digital_crop 1 |
| - b ctrl_retimed 2 |
| |
| # bracketing interface capability registers |
| bracketing_lut_capability_1 0x1c00 |
| - b coarse_integration 0 |
| - b global_analog_gain 1 |
| - b flash 4 |
| - b global_digital_gain 5 |
| - b alternate_global_analog_gain 6 |
| bracketing_lut_capability_2 0x1c01 |
| - b single_bracketing_mode 0 |
| - b looped_bracketing_mode 1 |
| bracketing_lut_size 0x1c02 |