Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
DSI.h
Go to the documentation of this file.
1// (c) IMT - Information Management Technology AG, CH-9470 Buchs, www.imt.ch.
2
3#ifndef STM32F769_DSI_H
4#define STM32F769_DSI_H
5
12
13namespace imt {
14namespace base {
15namespace hal {
16namespace stm32f769 {
17namespace peripherals {
18
23class DSI {
24public:
25
29 struct State {
30 enum Id {
31 Reset = 0x00U,
32 Ready = 0x01U,
33 Error = 0x02U,
34 Busy = 0x03U,
35 Timeout = 0x04U
36 };
37 };
38
42 union Error {
43 struct Bit {
54 };
57 };
58
59 /* Exported constants, unused but kept for comletenes */
60
61 // DSI_Exported_Constants DSI Exported Constants
62
63 // DSI_DCS_Command DSI DCS Command
64
65 //#define DSI_ENTER_IDLE_MODE 0x39U
66 //#define DSI_ENTER_INVERT_MODE 0x21U
67 //#define DSI_ENTER_NORMAL_MODE 0x13U
68 //#define DSI_ENTER_PARTIAL_MODE 0x12U
69 //#define DSI_ENTER_SLEEP_MODE 0x10U
70 //#define DSI_EXIT_IDLE_MODE 0x38U
71 //#define DSI_EXIT_INVERT_MODE 0x20U
72 //#define DSI_EXIT_SLEEP_MODE 0x11U
73 //#define DSI_GET_3D_CONTROL 0x3FU
74 //#define DSI_GET_ADDRESS_MODE 0x0BU
75 //#define DSI_GET_BLUE_CHANNEL 0x08U
76 //#define DSI_GET_DIAGNOSTIC_RESULT 0x0FU
77 //#define DSI_GET_DISPLAY_MODE 0x0DU
78 //#define DSI_GET_GREEN_CHANNEL 0x07U
79 //#define DSI_GET_PIXEL_FORMAT 0x0CU
80 //#define DSI_GET_POWER_MODE 0x0AU
81 //#define DSI_GET_RED_CHANNEL 0x06U
82 //#define DSI_GET_SCANLINE 0x45U
83 //#define DSI_GET_SIGNAL_MODE 0x0EU
84 //#define DSI_NOP 0x00U
85 //#define DSI_READ_DDB_CONTINUE 0xA8U
86 //#define DSI_READ_DDB_START 0xA1U
87 //#define DSI_READ_MEMORY_CONTINUE 0x3EU
88 //#define DSI_READ_MEMORY_START 0x2EU
89 //#define DSI_SET_3D_CONTROL 0x3DU
90 //#define DSI_SET_ADDRESS_MODE 0x36U
91 //#define DSI_SET_COLUMN_ADDRESS 0x2AU
92 //#define DSI_SET_DISPLAY_OFF 0x28U
93 //#define DSI_SET_DISPLAY_ON 0x29U
94 //#define DSI_SET_GAMMA_CURVE 0x26U
95 //#define DSI_SET_PAGE_ADDRESS 0x2BU
96 //#define DSI_SET_PARTIAL_COLUMNS 0x31U
97 //#define DSI_SET_PARTIAL_ROWS 0x30U
98 //#define DSI_SET_PIXEL_FORMAT 0x3AU
99 //#define DSI_SET_SCROLL_AREA 0x33U
100 //#define DSI_SET_SCROLL_START 0x37U
101 //#define DSI_SET_TEAR_OFF 0x34U
102 //#define DSI_SET_TEAR_ON 0x35U
103 //#define DSI_SET_TEAR_SCANLINE 0x44U
104 //#define DSI_SET_VSYNC_TIMING 0x40U
105 //#define DSI_SOFT_RESET 0x01U
106 //#define DSI_WRITE_LUT 0x2DU
107 //#define DSI_WRITE_MEMORY_CONTINUE 0x3CU
108 //#define DSI_WRITE_MEMORY_START 0x2CU
109
110 // DSI_SHORT_READ_PKT_Data_Type DSI SHORT READ PKT Data Type
111
112 //#define DSI_DCS_SHORT_PKT_READ 0x00000006U /*!< DCS short read */
113 //#define DSI_GEN_SHORT_PKT_READ_P0 0x00000004U /*!< Generic short read, no parameters */
114 //#define DSI_GEN_SHORT_PKT_READ_P1 0x00000014U /*!< Generic short read, one parameter */
115 //#define DSI_GEN_SHORT_PKT_READ_P2 0x00000024U /*!< Generic short read, two parameters */
116
117 // DSI_Lane_Group DSI Lane Group
118
119 //#define DSI_CLOCK_LANE 0x00000000U
120 //#define DSI_DATA_LANES 0x00000001U
121
122 // DSI_Communication_Delay DSI Communication Delay
123
124 //#define DSI_SLEW_RATE_HSTX 0x00000000U
125 //#define DSI_SLEW_RATE_LPTX 0x00000001U
126 //#define DSI_HS_DELAY 0x00000002U
127
128 // DSI_CustomLane DSI CustomLane
129
130 //#define DSI_SWAP_LANE_PINS 0x00000000U
131 //#define DSI_INVERT_HS_SIGNAL 0x00000001U
132
133 // DSI_Lane_Select DSI Lane Select
134
135 //#define DSI_CLK_LANE 0x00000000U
136 //#define DSI_DATA_LANE0 0x00000001U
137 //#define DSI_DATA_LANE1 0x00000002U
138
139 // DSI_PHY_Timing DSI PHY Timing
140
141 //#define DSI_TCLK_POST 0x00000000U
142 //#define DSI_TLPX_CLK 0x00000001U
143 //#define DSI_THS_EXIT 0x00000002U
144 //#define DSI_TLPX_DATA 0x00000003U
145 //#define DSI_THS_ZERO 0x00000004U
146 //#define DSI_THS_TRAIL 0x00000005U
147 //#define DSI_THS_PREPARE 0x00000006U
148 //#define DSI_TCLK_ZERO 0x00000007U
149 //#define DSI_TCLK_PREPARE 0x00000008U
150
151 static void registerCallbacks(DSIIrqIfc* const appIrqHandler);
152
153 // Initialization and Configuration Methods
154
165
172
178 static void initInterrupts();
179
180 // Peripheral Control Methods
181
187 static void configVideoMode(DSITypes::VidCfgTypeDef const& VidCfg);
188
192 static void start();
193
197 static void stop();
198
210 uint32_t const ChannelID,
212 uint32_t const Param1,
213 uint32_t const Param2);
214
227 uint32_t const ChannelID,
229 uint32_t const NbParams,
230 uint32_t const Param1,
231 uint8_t const* const ParametersTable);
232
236 static void refresh();
237
241 static void enableWrapper();
242
246 static void disableWrapper();
247
253
259 static void configHostTimeouts(DSITypes::HOST_TimeoutTypeDef const& hostTimeouts);
260
266 static void configPhyTimer(DSITypes::PHY_TimerTypeDef const& phyTimers);
267
273
278 static void configErrorMonitor(Error const& activeErrors);
279
286 static void configCommand(DSITypes::LPCmdTypeDef const& lpCmd);
287
294
299 static void setGenericVCID(uint32_t const VirtualChannelID);
300
301private:
302
306 DSI();
307
311 DSI(const DSI& other);
312
316 DSI& operator=(const DSI& other);
317
318 static void configPacketHeader(
319 uint32_t const ChannelID,
320 uint32_t const DataType,
321 uint32_t const Data0,
322 uint32_t const Data1);
323
324 static uint32_t const TIMEOUT_VALUE = 1000U;
325
326 static Error m_ErrorCode;
327 static Error m_ErrorMsk;
328 static State::Id m_State;
329
330 static DSIIrqIfc* s_applicationIrqHandler;
331};
332
333} // namespace peripherals
334} // namespace stm32f769
335} // namespace hal
336} // namespace base
337} // namespace imt
338
339#endif // STM32F769_DSI_H
Display Serial Interface (DSI) module.
Definition DSI.h:23
static void configPhyTimer(DSITypes::PHY_TimerTypeDef const &phyTimers)
Configure the DSI PHY timer parameters.
static void configVideoMode(DSITypes::VidCfgTypeDef const &VidCfg)
Select video mode and configure the corresponding parameters.
static Status::Id shortWrite(uint32_t const ChannelID, DSITypes::DsiShortPktWrite::Id const Mode, uint32_t const Param1, uint32_t const Param2)
write short DCS or short Generic command
static void disableWrapper()
Disable Wrapper Hardware.
static void enableWrapper()
Enable Wrapper Hardware.
static void initInterrupts()
Initializes interrupts listed below TE : Tearing Effect Interrupt Flag ER : End of Refresh Interrupt ...
static Status::Id longWrite(uint32_t const ChannelID, DSITypes::DsiLongPktWrite::Id const Mode, uint32_t const NbParams, uint32_t const Param1, uint8_t const *const ParametersTable)
write long DCS or long Generic command
static void configErrorMonitor(Error const &activeErrors)
Enable the error monitor flags.
static Status::Id init(DSITypes::InitTypeDef &config, DSITypes::PLLConfigStruct &PLLInit)
Initializes the DSI according to the specified parameters in the DSI_InitTypeDef and create the assoc...
static void refresh()
refresh the display in command mode
static void registerCallbacks(DSIIrqIfc *const appIrqHandler)
static void configHostTimeouts(DSITypes::HOST_TimeoutTypeDef const &hostTimeouts)
Configure the DSI HOST timeout parameters.
static void start()
Starts the DSI module.
static void setGenericVCID(uint32_t const VirtualChannelID)
Configure the Generic interface read-back Virtual Channel ID.
static void configFlowControl(::imt::base::hal::stm32f769::registers::DSIRegisters::DSI_PCR const &flowControl)
Configure the flow control parameters.
static void configCommand(DSITypes::LPCmdTypeDef const &lpCmd)
Configure command transmission mode: High-speed or Low-power and enable/disable acknowledge request a...
static void stop()
Stops the DSI module.
static Status::Id deInit()
De-initializes the DSI peripheral registers to their default reset values.
static void configAdaptedCommandMode(DSITypes::CmdCfgTypeDef const &cmdCfg)
Select adapted command mode and configure the corresponding parameters.
static uint32_t IRQHandler()
Intrrupt handler.
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int32 uint32_t
Definition stdint.h:64
unsigned __int8 uint8_t
Definition stdint.h:62
DSI States Structure definition.
Definition DSI.h:29
DSI command transmission mode configuration.
Definition DSITypes.h:218
DSI Host Protocol Configuration Register (DSI_PCR), chapter 20.15.8.