636 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			636 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef DSI_XML
 | |
| #define DSI_XML
 | |
| 
 | |
| /* Autogenerated file, DO NOT EDIT manually!
 | |
| 
 | |
| This file was generated by the rules-ng-ng headergen tool in this git repository:
 | |
| http://github.com/freedreno/envytools/
 | |
| git clone https://github.com/freedreno/envytools.git
 | |
| 
 | |
| The rules-ng-ng source files this header was generated from are:
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/msm.xml                   (    981 bytes, from 2021-06-05 21:37:42)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/freedreno_copyright.xml   (   1572 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/mdp/mdp4.xml              (  20912 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/mdp/mdp_common.xml        (   2849 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/mdp/mdp5.xml              (  37461 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi.xml               (  15291 bytes, from 2021-06-15 22:36:13)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_v2.xml        (   3236 bytes, from 2021-06-05 21:37:42)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_28nm_8960.xml (   4935 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_28nm.xml      (   7004 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_20nm.xml      (   3712 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_14nm.xml      (   5381 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_10nm.xml      (   4499 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_7nm.xml       (  10953 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/dsi_phy_5nm.xml       (  10900 bytes, from 2021-05-21 19:18:08)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/sfpb.xml              (    602 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/dsi/mmss_cc.xml           (   1686 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/hdmi/qfprom.xml           (    600 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/hdmi/hdmi.xml             (  41874 bytes, from 2021-02-18 16:45:44)
 | |
| - /home/robclark/src/mesa/mesa/src/freedreno/registers/edp/edp.xml               (  10416 bytes, from 2021-02-18 16:45:44)
 | |
| 
 | |
| Copyright (C) 2013-2021 by the following authors:
 | |
| - Rob Clark <robdclark@gmail.com> (robclark)
 | |
| - Ilia Mirkin <imirkin@alum.mit.edu> (imirkin)
 | |
| 
 | |
| Permission is hereby granted, free of charge, to any person obtaining
 | |
| a copy of this software and associated documentation files (the
 | |
| "Software"), to deal in the Software without restriction, including
 | |
| without limitation the rights to use, copy, modify, merge, publish,
 | |
| distribute, sublicense, and/or sell copies of the Software, and to
 | |
| permit persons to whom the Software is furnished to do so, subject to
 | |
| the following conditions:
 | |
| 
 | |
| The above copyright notice and this permission notice (including the
 | |
| next paragraph) shall be included in all copies or substantial
 | |
| portions of the Software.
 | |
| 
 | |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 | |
| EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | |
| MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 | |
| IN NO EVENT SHALL THE COPYRIGHT OWNER(S) AND/OR ITS SUPPLIERS BE
 | |
| LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 | |
| OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 | |
| WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | |
| */
 | |
| 
 | |
| 
 | |
| enum dsi_traffic_mode {
 | |
| 	NON_BURST_SYNCH_PULSE = 0,
 | |
| 	NON_BURST_SYNCH_EVENT = 1,
 | |
| 	BURST_MODE = 2,
 | |
| };
 | |
| 
 | |
| enum dsi_vid_dst_format {
 | |
| 	VID_DST_FORMAT_RGB565 = 0,
 | |
| 	VID_DST_FORMAT_RGB666 = 1,
 | |
| 	VID_DST_FORMAT_RGB666_LOOSE = 2,
 | |
| 	VID_DST_FORMAT_RGB888 = 3,
 | |
| };
 | |
| 
 | |
| enum dsi_rgb_swap {
 | |
| 	SWAP_RGB = 0,
 | |
| 	SWAP_RBG = 1,
 | |
| 	SWAP_BGR = 2,
 | |
| 	SWAP_BRG = 3,
 | |
| 	SWAP_GRB = 4,
 | |
| 	SWAP_GBR = 5,
 | |
| };
 | |
| 
 | |
| enum dsi_cmd_trigger {
 | |
| 	TRIGGER_NONE = 0,
 | |
| 	TRIGGER_SEOF = 1,
 | |
| 	TRIGGER_TE = 2,
 | |
| 	TRIGGER_SW = 4,
 | |
| 	TRIGGER_SW_SEOF = 5,
 | |
| 	TRIGGER_SW_TE = 6,
 | |
| };
 | |
| 
 | |
| enum dsi_cmd_dst_format {
 | |
| 	CMD_DST_FORMAT_RGB111 = 0,
 | |
| 	CMD_DST_FORMAT_RGB332 = 3,
 | |
| 	CMD_DST_FORMAT_RGB444 = 4,
 | |
| 	CMD_DST_FORMAT_RGB565 = 6,
 | |
| 	CMD_DST_FORMAT_RGB666 = 7,
 | |
| 	CMD_DST_FORMAT_RGB888 = 8,
 | |
| };
 | |
| 
 | |
| enum dsi_lane_swap {
 | |
| 	LANE_SWAP_0123 = 0,
 | |
| 	LANE_SWAP_3012 = 1,
 | |
| 	LANE_SWAP_2301 = 2,
 | |
| 	LANE_SWAP_1230 = 3,
 | |
| 	LANE_SWAP_0321 = 4,
 | |
| 	LANE_SWAP_1032 = 5,
 | |
| 	LANE_SWAP_2103 = 6,
 | |
| 	LANE_SWAP_3210 = 7,
 | |
| };
 | |
| 
 | |
| #define DSI_IRQ_CMD_DMA_DONE					0x00000001
 | |
| #define DSI_IRQ_MASK_CMD_DMA_DONE				0x00000002
 | |
| #define DSI_IRQ_CMD_MDP_DONE					0x00000100
 | |
| #define DSI_IRQ_MASK_CMD_MDP_DONE				0x00000200
 | |
| #define DSI_IRQ_VIDEO_DONE					0x00010000
 | |
| #define DSI_IRQ_MASK_VIDEO_DONE					0x00020000
 | |
| #define DSI_IRQ_BTA_DONE					0x00100000
 | |
| #define DSI_IRQ_MASK_BTA_DONE					0x00200000
 | |
| #define DSI_IRQ_ERROR						0x01000000
 | |
| #define DSI_IRQ_MASK_ERROR					0x02000000
 | |
| #define REG_DSI_6G_HW_VERSION					0x00000000
 | |
| #define DSI_6G_HW_VERSION_MAJOR__MASK				0xf0000000
 | |
| #define DSI_6G_HW_VERSION_MAJOR__SHIFT				28
 | |
| static inline uint32_t DSI_6G_HW_VERSION_MAJOR(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_6G_HW_VERSION_MAJOR__SHIFT) & DSI_6G_HW_VERSION_MAJOR__MASK;
 | |
| }
 | |
| #define DSI_6G_HW_VERSION_MINOR__MASK				0x0fff0000
 | |
| #define DSI_6G_HW_VERSION_MINOR__SHIFT				16
 | |
| static inline uint32_t DSI_6G_HW_VERSION_MINOR(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_6G_HW_VERSION_MINOR__SHIFT) & DSI_6G_HW_VERSION_MINOR__MASK;
 | |
| }
 | |
| #define DSI_6G_HW_VERSION_STEP__MASK				0x0000ffff
 | |
| #define DSI_6G_HW_VERSION_STEP__SHIFT				0
 | |
| static inline uint32_t DSI_6G_HW_VERSION_STEP(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_6G_HW_VERSION_STEP__SHIFT) & DSI_6G_HW_VERSION_STEP__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CTRL						0x00000000
 | |
| #define DSI_CTRL_ENABLE						0x00000001
 | |
| #define DSI_CTRL_VID_MODE_EN					0x00000002
 | |
| #define DSI_CTRL_CMD_MODE_EN					0x00000004
 | |
| #define DSI_CTRL_LANE0						0x00000010
 | |
| #define DSI_CTRL_LANE1						0x00000020
 | |
| #define DSI_CTRL_LANE2						0x00000040
 | |
| #define DSI_CTRL_LANE3						0x00000080
 | |
| #define DSI_CTRL_CLK_EN						0x00000100
 | |
| #define DSI_CTRL_ECC_CHECK					0x00100000
 | |
| #define DSI_CTRL_CRC_CHECK					0x01000000
 | |
| 
 | |
| #define REG_DSI_STATUS0						0x00000004
 | |
| #define DSI_STATUS0_CMD_MODE_ENGINE_BUSY			0x00000001
 | |
| #define DSI_STATUS0_CMD_MODE_DMA_BUSY				0x00000002
 | |
| #define DSI_STATUS0_CMD_MODE_MDP_BUSY				0x00000004
 | |
| #define DSI_STATUS0_VIDEO_MODE_ENGINE_BUSY			0x00000008
 | |
| #define DSI_STATUS0_DSI_BUSY					0x00000010
 | |
| #define DSI_STATUS0_INTERLEAVE_OP_CONTENTION			0x80000000
 | |
| 
 | |
| #define REG_DSI_FIFO_STATUS					0x00000008
 | |
| #define DSI_FIFO_STATUS_VIDEO_MDP_FIFO_OVERFLOW			0x00000001
 | |
| #define DSI_FIFO_STATUS_VIDEO_MDP_FIFO_UNDERFLOW		0x00000008
 | |
| #define DSI_FIFO_STATUS_CMD_MDP_FIFO_UNDERFLOW			0x00000080
 | |
| #define DSI_FIFO_STATUS_CMD_DMA_FIFO_RD_WATERMARK_REACH		0x00000100
 | |
| #define DSI_FIFO_STATUS_CMD_DMA_FIFO_WR_WATERMARK_REACH		0x00000200
 | |
| #define DSI_FIFO_STATUS_CMD_DMA_FIFO_UNDERFLOW			0x00000400
 | |
| #define DSI_FIFO_STATUS_DLN0_LP_FIFO_EMPTY			0x00001000
 | |
| #define DSI_FIFO_STATUS_DLN0_LP_FIFO_FULL			0x00002000
 | |
| #define DSI_FIFO_STATUS_DLN0_LP_FIFO_OVERFLOW			0x00004000
 | |
| #define DSI_FIFO_STATUS_DLN0_HS_FIFO_EMPTY			0x00010000
 | |
| #define DSI_FIFO_STATUS_DLN0_HS_FIFO_FULL			0x00020000
 | |
| #define DSI_FIFO_STATUS_DLN0_HS_FIFO_OVERFLOW			0x00040000
 | |
| #define DSI_FIFO_STATUS_DLN0_HS_FIFO_UNDERFLOW			0x00080000
 | |
| #define DSI_FIFO_STATUS_DLN1_HS_FIFO_EMPTY			0x00100000
 | |
| #define DSI_FIFO_STATUS_DLN1_HS_FIFO_FULL			0x00200000
 | |
| #define DSI_FIFO_STATUS_DLN1_HS_FIFO_OVERFLOW			0x00400000
 | |
| #define DSI_FIFO_STATUS_DLN1_HS_FIFO_UNDERFLOW			0x00800000
 | |
| #define DSI_FIFO_STATUS_DLN2_HS_FIFO_EMPTY			0x01000000
 | |
| #define DSI_FIFO_STATUS_DLN2_HS_FIFO_FULL			0x02000000
 | |
| #define DSI_FIFO_STATUS_DLN2_HS_FIFO_OVERFLOW			0x04000000
 | |
| #define DSI_FIFO_STATUS_DLN2_HS_FIFO_UNDERFLOW			0x08000000
 | |
| #define DSI_FIFO_STATUS_DLN3_HS_FIFO_EMPTY			0x10000000
 | |
| #define DSI_FIFO_STATUS_DLN3_HS_FIFO_FULL			0x20000000
 | |
| #define DSI_FIFO_STATUS_DLN3_HS_FIFO_OVERFLOW			0x40000000
 | |
| #define DSI_FIFO_STATUS_DLN3_HS_FIFO_UNDERFLOW			0x80000000
 | |
| 
 | |
| #define REG_DSI_VID_CFG0					0x0000000c
 | |
| #define DSI_VID_CFG0_VIRT_CHANNEL__MASK				0x00000003
 | |
| #define DSI_VID_CFG0_VIRT_CHANNEL__SHIFT			0
 | |
| static inline uint32_t DSI_VID_CFG0_VIRT_CHANNEL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_VID_CFG0_VIRT_CHANNEL__SHIFT) & DSI_VID_CFG0_VIRT_CHANNEL__MASK;
 | |
| }
 | |
| #define DSI_VID_CFG0_DST_FORMAT__MASK				0x00000030
 | |
| #define DSI_VID_CFG0_DST_FORMAT__SHIFT				4
 | |
| static inline uint32_t DSI_VID_CFG0_DST_FORMAT(enum dsi_vid_dst_format val)
 | |
| {
 | |
| 	return ((val) << DSI_VID_CFG0_DST_FORMAT__SHIFT) & DSI_VID_CFG0_DST_FORMAT__MASK;
 | |
| }
 | |
| #define DSI_VID_CFG0_TRAFFIC_MODE__MASK				0x00000300
 | |
| #define DSI_VID_CFG0_TRAFFIC_MODE__SHIFT			8
 | |
| static inline uint32_t DSI_VID_CFG0_TRAFFIC_MODE(enum dsi_traffic_mode val)
 | |
| {
 | |
| 	return ((val) << DSI_VID_CFG0_TRAFFIC_MODE__SHIFT) & DSI_VID_CFG0_TRAFFIC_MODE__MASK;
 | |
| }
 | |
| #define DSI_VID_CFG0_BLLP_POWER_STOP				0x00001000
 | |
| #define DSI_VID_CFG0_EOF_BLLP_POWER_STOP			0x00008000
 | |
| #define DSI_VID_CFG0_HSA_POWER_STOP				0x00010000
 | |
| #define DSI_VID_CFG0_HBP_POWER_STOP				0x00100000
 | |
| #define DSI_VID_CFG0_HFP_POWER_STOP				0x01000000
 | |
| #define DSI_VID_CFG0_PULSE_MODE_HSA_HE				0x10000000
 | |
| 
 | |
| #define REG_DSI_VID_CFG1					0x0000001c
 | |
| #define DSI_VID_CFG1_R_SEL					0x00000001
 | |
| #define DSI_VID_CFG1_G_SEL					0x00000010
 | |
| #define DSI_VID_CFG1_B_SEL					0x00000100
 | |
| #define DSI_VID_CFG1_RGB_SWAP__MASK				0x00007000
 | |
| #define DSI_VID_CFG1_RGB_SWAP__SHIFT				12
 | |
| static inline uint32_t DSI_VID_CFG1_RGB_SWAP(enum dsi_rgb_swap val)
 | |
| {
 | |
| 	return ((val) << DSI_VID_CFG1_RGB_SWAP__SHIFT) & DSI_VID_CFG1_RGB_SWAP__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACTIVE_H					0x00000020
 | |
| #define DSI_ACTIVE_H_START__MASK				0x00000fff
 | |
| #define DSI_ACTIVE_H_START__SHIFT				0
 | |
| static inline uint32_t DSI_ACTIVE_H_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_H_START__SHIFT) & DSI_ACTIVE_H_START__MASK;
 | |
| }
 | |
| #define DSI_ACTIVE_H_END__MASK					0x0fff0000
 | |
| #define DSI_ACTIVE_H_END__SHIFT					16
 | |
| static inline uint32_t DSI_ACTIVE_H_END(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_H_END__SHIFT) & DSI_ACTIVE_H_END__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACTIVE_V					0x00000024
 | |
| #define DSI_ACTIVE_V_START__MASK				0x00000fff
 | |
| #define DSI_ACTIVE_V_START__SHIFT				0
 | |
| static inline uint32_t DSI_ACTIVE_V_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_V_START__SHIFT) & DSI_ACTIVE_V_START__MASK;
 | |
| }
 | |
| #define DSI_ACTIVE_V_END__MASK					0x0fff0000
 | |
| #define DSI_ACTIVE_V_END__SHIFT					16
 | |
| static inline uint32_t DSI_ACTIVE_V_END(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_V_END__SHIFT) & DSI_ACTIVE_V_END__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_TOTAL						0x00000028
 | |
| #define DSI_TOTAL_H_TOTAL__MASK					0x00000fff
 | |
| #define DSI_TOTAL_H_TOTAL__SHIFT				0
 | |
| static inline uint32_t DSI_TOTAL_H_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_TOTAL_H_TOTAL__SHIFT) & DSI_TOTAL_H_TOTAL__MASK;
 | |
| }
 | |
| #define DSI_TOTAL_V_TOTAL__MASK					0x0fff0000
 | |
| #define DSI_TOTAL_V_TOTAL__SHIFT				16
 | |
| static inline uint32_t DSI_TOTAL_V_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_TOTAL_V_TOTAL__SHIFT) & DSI_TOTAL_V_TOTAL__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACTIVE_HSYNC					0x0000002c
 | |
| #define DSI_ACTIVE_HSYNC_START__MASK				0x00000fff
 | |
| #define DSI_ACTIVE_HSYNC_START__SHIFT				0
 | |
| static inline uint32_t DSI_ACTIVE_HSYNC_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_HSYNC_START__SHIFT) & DSI_ACTIVE_HSYNC_START__MASK;
 | |
| }
 | |
| #define DSI_ACTIVE_HSYNC_END__MASK				0x0fff0000
 | |
| #define DSI_ACTIVE_HSYNC_END__SHIFT				16
 | |
| static inline uint32_t DSI_ACTIVE_HSYNC_END(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_HSYNC_END__SHIFT) & DSI_ACTIVE_HSYNC_END__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACTIVE_VSYNC_HPOS				0x00000030
 | |
| #define DSI_ACTIVE_VSYNC_HPOS_START__MASK			0x00000fff
 | |
| #define DSI_ACTIVE_VSYNC_HPOS_START__SHIFT			0
 | |
| static inline uint32_t DSI_ACTIVE_VSYNC_HPOS_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_VSYNC_HPOS_START__SHIFT) & DSI_ACTIVE_VSYNC_HPOS_START__MASK;
 | |
| }
 | |
| #define DSI_ACTIVE_VSYNC_HPOS_END__MASK				0x0fff0000
 | |
| #define DSI_ACTIVE_VSYNC_HPOS_END__SHIFT			16
 | |
| static inline uint32_t DSI_ACTIVE_VSYNC_HPOS_END(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_VSYNC_HPOS_END__SHIFT) & DSI_ACTIVE_VSYNC_HPOS_END__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACTIVE_VSYNC_VPOS				0x00000034
 | |
| #define DSI_ACTIVE_VSYNC_VPOS_START__MASK			0x00000fff
 | |
| #define DSI_ACTIVE_VSYNC_VPOS_START__SHIFT			0
 | |
| static inline uint32_t DSI_ACTIVE_VSYNC_VPOS_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_VSYNC_VPOS_START__SHIFT) & DSI_ACTIVE_VSYNC_VPOS_START__MASK;
 | |
| }
 | |
| #define DSI_ACTIVE_VSYNC_VPOS_END__MASK				0x0fff0000
 | |
| #define DSI_ACTIVE_VSYNC_VPOS_END__SHIFT			16
 | |
| static inline uint32_t DSI_ACTIVE_VSYNC_VPOS_END(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_ACTIVE_VSYNC_VPOS_END__SHIFT) & DSI_ACTIVE_VSYNC_VPOS_END__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CMD_DMA_CTRL					0x00000038
 | |
| #define DSI_CMD_DMA_CTRL_BROADCAST_EN				0x80000000
 | |
| #define DSI_CMD_DMA_CTRL_FROM_FRAME_BUFFER			0x10000000
 | |
| #define DSI_CMD_DMA_CTRL_LOW_POWER				0x04000000
 | |
| 
 | |
| #define REG_DSI_CMD_CFG0					0x0000003c
 | |
| #define DSI_CMD_CFG0_DST_FORMAT__MASK				0x0000000f
 | |
| #define DSI_CMD_CFG0_DST_FORMAT__SHIFT				0
 | |
| static inline uint32_t DSI_CMD_CFG0_DST_FORMAT(enum dsi_cmd_dst_format val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_CFG0_DST_FORMAT__SHIFT) & DSI_CMD_CFG0_DST_FORMAT__MASK;
 | |
| }
 | |
| #define DSI_CMD_CFG0_R_SEL					0x00000010
 | |
| #define DSI_CMD_CFG0_G_SEL					0x00000100
 | |
| #define DSI_CMD_CFG0_B_SEL					0x00001000
 | |
| #define DSI_CMD_CFG0_INTERLEAVE_MAX__MASK			0x00f00000
 | |
| #define DSI_CMD_CFG0_INTERLEAVE_MAX__SHIFT			20
 | |
| static inline uint32_t DSI_CMD_CFG0_INTERLEAVE_MAX(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_CFG0_INTERLEAVE_MAX__SHIFT) & DSI_CMD_CFG0_INTERLEAVE_MAX__MASK;
 | |
| }
 | |
| #define DSI_CMD_CFG0_RGB_SWAP__MASK				0x00070000
 | |
| #define DSI_CMD_CFG0_RGB_SWAP__SHIFT				16
 | |
| static inline uint32_t DSI_CMD_CFG0_RGB_SWAP(enum dsi_rgb_swap val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_CFG0_RGB_SWAP__SHIFT) & DSI_CMD_CFG0_RGB_SWAP__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CMD_CFG1					0x00000040
 | |
| #define DSI_CMD_CFG1_WR_MEM_START__MASK				0x000000ff
 | |
| #define DSI_CMD_CFG1_WR_MEM_START__SHIFT			0
 | |
| static inline uint32_t DSI_CMD_CFG1_WR_MEM_START(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_CFG1_WR_MEM_START__SHIFT) & DSI_CMD_CFG1_WR_MEM_START__MASK;
 | |
| }
 | |
| #define DSI_CMD_CFG1_WR_MEM_CONTINUE__MASK			0x0000ff00
 | |
| #define DSI_CMD_CFG1_WR_MEM_CONTINUE__SHIFT			8
 | |
| static inline uint32_t DSI_CMD_CFG1_WR_MEM_CONTINUE(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_CFG1_WR_MEM_CONTINUE__SHIFT) & DSI_CMD_CFG1_WR_MEM_CONTINUE__MASK;
 | |
| }
 | |
| #define DSI_CMD_CFG1_INSERT_DCS_COMMAND				0x00010000
 | |
| 
 | |
| #define REG_DSI_DMA_BASE					0x00000044
 | |
| 
 | |
| #define REG_DSI_DMA_LEN						0x00000048
 | |
| 
 | |
| #define REG_DSI_CMD_MDP_STREAM0_CTRL				0x00000054
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_DATA_TYPE__MASK		0x0000003f
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_DATA_TYPE__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM0_CTRL_DATA_TYPE(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM0_CTRL_DATA_TYPE__SHIFT) & DSI_CMD_MDP_STREAM0_CTRL_DATA_TYPE__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_VIRTUAL_CHANNEL__MASK		0x00000300
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_VIRTUAL_CHANNEL__SHIFT		8
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM0_CTRL_VIRTUAL_CHANNEL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM0_CTRL_VIRTUAL_CHANNEL__SHIFT) & DSI_CMD_MDP_STREAM0_CTRL_VIRTUAL_CHANNEL__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_WORD_COUNT__MASK		0xffff0000
 | |
| #define DSI_CMD_MDP_STREAM0_CTRL_WORD_COUNT__SHIFT		16
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM0_CTRL_WORD_COUNT(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM0_CTRL_WORD_COUNT__SHIFT) & DSI_CMD_MDP_STREAM0_CTRL_WORD_COUNT__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CMD_MDP_STREAM0_TOTAL				0x00000058
 | |
| #define DSI_CMD_MDP_STREAM0_TOTAL_H_TOTAL__MASK			0x00000fff
 | |
| #define DSI_CMD_MDP_STREAM0_TOTAL_H_TOTAL__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM0_TOTAL_H_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM0_TOTAL_H_TOTAL__SHIFT) & DSI_CMD_MDP_STREAM0_TOTAL_H_TOTAL__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM0_TOTAL_V_TOTAL__MASK			0x0fff0000
 | |
| #define DSI_CMD_MDP_STREAM0_TOTAL_V_TOTAL__SHIFT		16
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM0_TOTAL_V_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM0_TOTAL_V_TOTAL__SHIFT) & DSI_CMD_MDP_STREAM0_TOTAL_V_TOTAL__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CMD_MDP_STREAM1_CTRL				0x0000005c
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_DATA_TYPE__MASK		0x0000003f
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_DATA_TYPE__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM1_CTRL_DATA_TYPE(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM1_CTRL_DATA_TYPE__SHIFT) & DSI_CMD_MDP_STREAM1_CTRL_DATA_TYPE__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_VIRTUAL_CHANNEL__MASK		0x00000300
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_VIRTUAL_CHANNEL__SHIFT		8
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM1_CTRL_VIRTUAL_CHANNEL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM1_CTRL_VIRTUAL_CHANNEL__SHIFT) & DSI_CMD_MDP_STREAM1_CTRL_VIRTUAL_CHANNEL__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_WORD_COUNT__MASK		0xffff0000
 | |
| #define DSI_CMD_MDP_STREAM1_CTRL_WORD_COUNT__SHIFT		16
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM1_CTRL_WORD_COUNT(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM1_CTRL_WORD_COUNT__SHIFT) & DSI_CMD_MDP_STREAM1_CTRL_WORD_COUNT__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CMD_MDP_STREAM1_TOTAL				0x00000060
 | |
| #define DSI_CMD_MDP_STREAM1_TOTAL_H_TOTAL__MASK			0x0000ffff
 | |
| #define DSI_CMD_MDP_STREAM1_TOTAL_H_TOTAL__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM1_TOTAL_H_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM1_TOTAL_H_TOTAL__SHIFT) & DSI_CMD_MDP_STREAM1_TOTAL_H_TOTAL__MASK;
 | |
| }
 | |
| #define DSI_CMD_MDP_STREAM1_TOTAL_V_TOTAL__MASK			0xffff0000
 | |
| #define DSI_CMD_MDP_STREAM1_TOTAL_V_TOTAL__SHIFT		16
 | |
| static inline uint32_t DSI_CMD_MDP_STREAM1_TOTAL_V_TOTAL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MDP_STREAM1_TOTAL_V_TOTAL__SHIFT) & DSI_CMD_MDP_STREAM1_TOTAL_V_TOTAL__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ACK_ERR_STATUS					0x00000064
 | |
| 
 | |
| static inline uint32_t REG_DSI_RDBK(uint32_t i0) { return 0x00000068 + 0x4*i0; }
 | |
| 
 | |
| static inline uint32_t REG_DSI_RDBK_DATA(uint32_t i0) { return 0x00000068 + 0x4*i0; }
 | |
| 
 | |
| #define REG_DSI_TRIG_CTRL					0x00000080
 | |
| #define DSI_TRIG_CTRL_DMA_TRIGGER__MASK				0x00000007
 | |
| #define DSI_TRIG_CTRL_DMA_TRIGGER__SHIFT			0
 | |
| static inline uint32_t DSI_TRIG_CTRL_DMA_TRIGGER(enum dsi_cmd_trigger val)
 | |
| {
 | |
| 	return ((val) << DSI_TRIG_CTRL_DMA_TRIGGER__SHIFT) & DSI_TRIG_CTRL_DMA_TRIGGER__MASK;
 | |
| }
 | |
| #define DSI_TRIG_CTRL_MDP_TRIGGER__MASK				0x00000070
 | |
| #define DSI_TRIG_CTRL_MDP_TRIGGER__SHIFT			4
 | |
| static inline uint32_t DSI_TRIG_CTRL_MDP_TRIGGER(enum dsi_cmd_trigger val)
 | |
| {
 | |
| 	return ((val) << DSI_TRIG_CTRL_MDP_TRIGGER__SHIFT) & DSI_TRIG_CTRL_MDP_TRIGGER__MASK;
 | |
| }
 | |
| #define DSI_TRIG_CTRL_STREAM__MASK				0x00000300
 | |
| #define DSI_TRIG_CTRL_STREAM__SHIFT				8
 | |
| static inline uint32_t DSI_TRIG_CTRL_STREAM(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_TRIG_CTRL_STREAM__SHIFT) & DSI_TRIG_CTRL_STREAM__MASK;
 | |
| }
 | |
| #define DSI_TRIG_CTRL_BLOCK_DMA_WITHIN_FRAME			0x00001000
 | |
| #define DSI_TRIG_CTRL_TE					0x80000000
 | |
| 
 | |
| #define REG_DSI_TRIG_DMA					0x0000008c
 | |
| 
 | |
| #define REG_DSI_DLN0_PHY_ERR					0x000000b0
 | |
| #define DSI_DLN0_PHY_ERR_DLN0_ERR_ESC				0x00000001
 | |
| #define DSI_DLN0_PHY_ERR_DLN0_ERR_SYNC_ESC			0x00000010
 | |
| #define DSI_DLN0_PHY_ERR_DLN0_ERR_CONTROL			0x00000100
 | |
| #define DSI_DLN0_PHY_ERR_DLN0_ERR_CONTENTION_LP0		0x00001000
 | |
| #define DSI_DLN0_PHY_ERR_DLN0_ERR_CONTENTION_LP1		0x00010000
 | |
| 
 | |
| #define REG_DSI_LP_TIMER_CTRL					0x000000b4
 | |
| #define DSI_LP_TIMER_CTRL_LP_RX_TO__MASK			0x0000ffff
 | |
| #define DSI_LP_TIMER_CTRL_LP_RX_TO__SHIFT			0
 | |
| static inline uint32_t DSI_LP_TIMER_CTRL_LP_RX_TO(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_LP_TIMER_CTRL_LP_RX_TO__SHIFT) & DSI_LP_TIMER_CTRL_LP_RX_TO__MASK;
 | |
| }
 | |
| #define DSI_LP_TIMER_CTRL_BTA_TO__MASK				0xffff0000
 | |
| #define DSI_LP_TIMER_CTRL_BTA_TO__SHIFT				16
 | |
| static inline uint32_t DSI_LP_TIMER_CTRL_BTA_TO(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_LP_TIMER_CTRL_BTA_TO__SHIFT) & DSI_LP_TIMER_CTRL_BTA_TO__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_HS_TIMER_CTRL					0x000000b8
 | |
| #define DSI_HS_TIMER_CTRL_HS_TX_TO__MASK			0x0000ffff
 | |
| #define DSI_HS_TIMER_CTRL_HS_TX_TO__SHIFT			0
 | |
| static inline uint32_t DSI_HS_TIMER_CTRL_HS_TX_TO(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_HS_TIMER_CTRL_HS_TX_TO__SHIFT) & DSI_HS_TIMER_CTRL_HS_TX_TO__MASK;
 | |
| }
 | |
| #define DSI_HS_TIMER_CTRL_TIMER_RESOLUTION__MASK		0x000f0000
 | |
| #define DSI_HS_TIMER_CTRL_TIMER_RESOLUTION__SHIFT		16
 | |
| static inline uint32_t DSI_HS_TIMER_CTRL_TIMER_RESOLUTION(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_HS_TIMER_CTRL_TIMER_RESOLUTION__SHIFT) & DSI_HS_TIMER_CTRL_TIMER_RESOLUTION__MASK;
 | |
| }
 | |
| #define DSI_HS_TIMER_CTRL_HS_TX_TO_STOP_EN			0x10000000
 | |
| 
 | |
| #define REG_DSI_TIMEOUT_STATUS					0x000000bc
 | |
| 
 | |
| #define REG_DSI_CLKOUT_TIMING_CTRL				0x000000c0
 | |
| #define DSI_CLKOUT_TIMING_CTRL_T_CLK_PRE__MASK			0x0000003f
 | |
| #define DSI_CLKOUT_TIMING_CTRL_T_CLK_PRE__SHIFT			0
 | |
| static inline uint32_t DSI_CLKOUT_TIMING_CTRL_T_CLK_PRE(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CLKOUT_TIMING_CTRL_T_CLK_PRE__SHIFT) & DSI_CLKOUT_TIMING_CTRL_T_CLK_PRE__MASK;
 | |
| }
 | |
| #define DSI_CLKOUT_TIMING_CTRL_T_CLK_POST__MASK			0x00003f00
 | |
| #define DSI_CLKOUT_TIMING_CTRL_T_CLK_POST__SHIFT		8
 | |
| static inline uint32_t DSI_CLKOUT_TIMING_CTRL_T_CLK_POST(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CLKOUT_TIMING_CTRL_T_CLK_POST__SHIFT) & DSI_CLKOUT_TIMING_CTRL_T_CLK_POST__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_EOT_PACKET_CTRL					0x000000c8
 | |
| #define DSI_EOT_PACKET_CTRL_TX_EOT_APPEND			0x00000001
 | |
| #define DSI_EOT_PACKET_CTRL_RX_EOT_IGNORE			0x00000010
 | |
| 
 | |
| #define REG_DSI_LANE_STATUS					0x000000a4
 | |
| #define DSI_LANE_STATUS_DLN0_STOPSTATE				0x00000001
 | |
| #define DSI_LANE_STATUS_DLN1_STOPSTATE				0x00000002
 | |
| #define DSI_LANE_STATUS_DLN2_STOPSTATE				0x00000004
 | |
| #define DSI_LANE_STATUS_DLN3_STOPSTATE				0x00000008
 | |
| #define DSI_LANE_STATUS_CLKLN_STOPSTATE				0x00000010
 | |
| #define DSI_LANE_STATUS_DLN0_ULPS_ACTIVE_NOT			0x00000100
 | |
| #define DSI_LANE_STATUS_DLN1_ULPS_ACTIVE_NOT			0x00000200
 | |
| #define DSI_LANE_STATUS_DLN2_ULPS_ACTIVE_NOT			0x00000400
 | |
| #define DSI_LANE_STATUS_DLN3_ULPS_ACTIVE_NOT			0x00000800
 | |
| #define DSI_LANE_STATUS_CLKLN_ULPS_ACTIVE_NOT			0x00001000
 | |
| #define DSI_LANE_STATUS_DLN0_DIRECTION				0x00010000
 | |
| 
 | |
| #define REG_DSI_LANE_CTRL					0x000000a8
 | |
| #define DSI_LANE_CTRL_CLKLN_HS_FORCE_REQUEST			0x10000000
 | |
| 
 | |
| #define REG_DSI_LANE_SWAP_CTRL					0x000000ac
 | |
| #define DSI_LANE_SWAP_CTRL_DLN_SWAP_SEL__MASK			0x00000007
 | |
| #define DSI_LANE_SWAP_CTRL_DLN_SWAP_SEL__SHIFT			0
 | |
| static inline uint32_t DSI_LANE_SWAP_CTRL_DLN_SWAP_SEL(enum dsi_lane_swap val)
 | |
| {
 | |
| 	return ((val) << DSI_LANE_SWAP_CTRL_DLN_SWAP_SEL__SHIFT) & DSI_LANE_SWAP_CTRL_DLN_SWAP_SEL__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_ERR_INT_MASK0					0x00000108
 | |
| 
 | |
| #define REG_DSI_INTR_CTRL					0x0000010c
 | |
| 
 | |
| #define REG_DSI_RESET						0x00000114
 | |
| 
 | |
| #define REG_DSI_CLK_CTRL					0x00000118
 | |
| #define DSI_CLK_CTRL_AHBS_HCLK_ON				0x00000001
 | |
| #define DSI_CLK_CTRL_AHBM_SCLK_ON				0x00000002
 | |
| #define DSI_CLK_CTRL_PCLK_ON					0x00000004
 | |
| #define DSI_CLK_CTRL_DSICLK_ON					0x00000008
 | |
| #define DSI_CLK_CTRL_BYTECLK_ON					0x00000010
 | |
| #define DSI_CLK_CTRL_ESCCLK_ON					0x00000020
 | |
| #define DSI_CLK_CTRL_FORCE_ON_DYN_AHBM_HCLK			0x00000200
 | |
| 
 | |
| #define REG_DSI_CLK_STATUS					0x0000011c
 | |
| #define DSI_CLK_STATUS_DSI_AON_AHBM_HCLK_ACTIVE			0x00000001
 | |
| #define DSI_CLK_STATUS_DSI_DYN_AHBM_HCLK_ACTIVE			0x00000002
 | |
| #define DSI_CLK_STATUS_DSI_AON_AHBS_HCLK_ACTIVE			0x00000004
 | |
| #define DSI_CLK_STATUS_DSI_DYN_AHBS_HCLK_ACTIVE			0x00000008
 | |
| #define DSI_CLK_STATUS_DSI_AON_DSICLK_ACTIVE			0x00000010
 | |
| #define DSI_CLK_STATUS_DSI_DYN_DSICLK_ACTIVE			0x00000020
 | |
| #define DSI_CLK_STATUS_DSI_AON_BYTECLK_ACTIVE			0x00000040
 | |
| #define DSI_CLK_STATUS_DSI_DYN_BYTECLK_ACTIVE			0x00000080
 | |
| #define DSI_CLK_STATUS_DSI_AON_ESCCLK_ACTIVE			0x00000100
 | |
| #define DSI_CLK_STATUS_DSI_AON_PCLK_ACTIVE			0x00000200
 | |
| #define DSI_CLK_STATUS_DSI_DYN_PCLK_ACTIVE			0x00000400
 | |
| #define DSI_CLK_STATUS_DSI_DYN_CMD_PCLK_ACTIVE			0x00001000
 | |
| #define DSI_CLK_STATUS_DSI_CMD_PCLK_ACTIVE			0x00002000
 | |
| #define DSI_CLK_STATUS_DSI_VID_PCLK_ACTIVE			0x00004000
 | |
| #define DSI_CLK_STATUS_DSI_CAM_BIST_PCLK_ACT			0x00008000
 | |
| #define DSI_CLK_STATUS_PLL_UNLOCKED				0x00010000
 | |
| 
 | |
| #define REG_DSI_PHY_RESET					0x00000128
 | |
| #define DSI_PHY_RESET_RESET					0x00000001
 | |
| 
 | |
| #define REG_DSI_T_CLK_PRE_EXTEND				0x0000017c
 | |
| #define DSI_T_CLK_PRE_EXTEND_INC_BY_2_BYTECLK			0x00000001
 | |
| 
 | |
| #define REG_DSI_CMD_MODE_MDP_CTRL2				0x000001b4
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_DST_FORMAT2__MASK		0x0000000f
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_DST_FORMAT2__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_CTRL2_DST_FORMAT2(enum dsi_cmd_dst_format val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_CTRL2_DST_FORMAT2__SHIFT) & DSI_CMD_MODE_MDP_CTRL2_DST_FORMAT2__MASK;
 | |
| }
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_R_SEL				0x00000010
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_G_SEL				0x00000020
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_B_SEL				0x00000040
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_BYTE_MSB_LSB_FLIP		0x00000080
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_RGB_SWAP__MASK			0x00000700
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_RGB_SWAP__SHIFT			8
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_CTRL2_RGB_SWAP(enum dsi_rgb_swap val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_CTRL2_RGB_SWAP__SHIFT) & DSI_CMD_MODE_MDP_CTRL2_RGB_SWAP__MASK;
 | |
| }
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_INPUT_RGB_SWAP__MASK		0x00007000
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_INPUT_RGB_SWAP__SHIFT		12
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_CTRL2_INPUT_RGB_SWAP(enum dsi_rgb_swap val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_CTRL2_INPUT_RGB_SWAP__SHIFT) & DSI_CMD_MODE_MDP_CTRL2_INPUT_RGB_SWAP__MASK;
 | |
| }
 | |
| #define DSI_CMD_MODE_MDP_CTRL2_BURST_MODE			0x00010000
 | |
| 
 | |
| #define REG_DSI_CMD_MODE_MDP_STREAM2_CTRL			0x000001b8
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_DATA_TYPE__MASK		0x0000003f
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_DATA_TYPE__SHIFT		0
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_STREAM2_CTRL_DATA_TYPE(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_STREAM2_CTRL_DATA_TYPE__SHIFT) & DSI_CMD_MODE_MDP_STREAM2_CTRL_DATA_TYPE__MASK;
 | |
| }
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_VIRTUAL_CHANNEL__MASK	0x00000300
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_VIRTUAL_CHANNEL__SHIFT	8
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_STREAM2_CTRL_VIRTUAL_CHANNEL(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_STREAM2_CTRL_VIRTUAL_CHANNEL__SHIFT) & DSI_CMD_MODE_MDP_STREAM2_CTRL_VIRTUAL_CHANNEL__MASK;
 | |
| }
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_WORD_COUNT__MASK		0xffff0000
 | |
| #define DSI_CMD_MODE_MDP_STREAM2_CTRL_WORD_COUNT__SHIFT		16
 | |
| static inline uint32_t DSI_CMD_MODE_MDP_STREAM2_CTRL_WORD_COUNT(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_CMD_MODE_MDP_STREAM2_CTRL_WORD_COUNT__SHIFT) & DSI_CMD_MODE_MDP_STREAM2_CTRL_WORD_COUNT__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_RDBK_DATA_CTRL					0x000001d0
 | |
| #define DSI_RDBK_DATA_CTRL_COUNT__MASK				0x00ff0000
 | |
| #define DSI_RDBK_DATA_CTRL_COUNT__SHIFT				16
 | |
| static inline uint32_t DSI_RDBK_DATA_CTRL_COUNT(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_RDBK_DATA_CTRL_COUNT__SHIFT) & DSI_RDBK_DATA_CTRL_COUNT__MASK;
 | |
| }
 | |
| #define DSI_RDBK_DATA_CTRL_CLR					0x00000001
 | |
| 
 | |
| #define REG_DSI_VERSION						0x000001f0
 | |
| #define DSI_VERSION_MAJOR__MASK					0xff000000
 | |
| #define DSI_VERSION_MAJOR__SHIFT				24
 | |
| static inline uint32_t DSI_VERSION_MAJOR(uint32_t val)
 | |
| {
 | |
| 	return ((val) << DSI_VERSION_MAJOR__SHIFT) & DSI_VERSION_MAJOR__MASK;
 | |
| }
 | |
| 
 | |
| #define REG_DSI_CPHY_MODE_CTRL					0x000002d4
 | |
| 
 | |
| 
 | |
| #endif /* DSI_XML */
 |