forked from CTCaer/hekate
bdk: display: deduplicate interrupt code
This commit is contained in:
parent
239c48c790
commit
09dfcfc57d
@ -42,6 +42,26 @@ static bool _nx_aula = false;
|
|||||||
|
|
||||||
static void _display_panel_and_hw_end(bool no_panel_deinit);
|
static void _display_panel_and_hw_end(bool no_panel_deinit);
|
||||||
|
|
||||||
|
void display_enable_interrupt(u32 intr)
|
||||||
|
{
|
||||||
|
DISPLAY_A(_DIREG(DC_CMD_INT_ENABLE)) |= intr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void display_disable_interrupt(u32 intr)
|
||||||
|
{
|
||||||
|
DISPLAY_A(_DIREG(DC_CMD_INT_ENABLE)) &= ~intr;
|
||||||
|
DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) = intr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void display_wait_interrupt(u32 intr)
|
||||||
|
{
|
||||||
|
DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) = intr;
|
||||||
|
|
||||||
|
// Interrupts are masked. Poll status register for checking if fired.
|
||||||
|
while (!(DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) & intr))
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
static void _display_dsi_wait(u32 timeout, u32 off, u32 mask)
|
static void _display_dsi_wait(u32 timeout, u32 off, u32 mask)
|
||||||
{
|
{
|
||||||
u32 end = get_tmr_us() + timeout;
|
u32 end = get_tmr_us() + timeout;
|
||||||
@ -64,22 +84,18 @@ static void _display_dsi_wait_vblank(bool enable)
|
|||||||
if (enable)
|
if (enable)
|
||||||
{
|
{
|
||||||
// Enable vblank interrupt.
|
// Enable vblank interrupt.
|
||||||
DISPLAY_A(_DIREG(DC_CMD_INT_ENABLE)) = DC_CMD_INT_FRAME_END_INT;
|
display_enable_interrupt(DC_CMD_INT_FRAME_END_INT);
|
||||||
|
|
||||||
// Use the 4th line to transmit the host cmd packet.
|
// Use the 4th line to transmit the host cmd packet.
|
||||||
DSI(_DSIREG(DSI_VIDEO_MODE_CONTROL)) = DSI_CMD_PKT_VID_ENABLE | DSI_DSI_LINE_TYPE(4);
|
DSI(_DSIREG(DSI_VIDEO_MODE_CONTROL)) = DSI_CMD_PKT_VID_ENABLE | DSI_DSI_LINE_TYPE(4);
|
||||||
|
|
||||||
// Wait for vblank before starting the transfer.
|
// Wait for vblank before starting the transfer.
|
||||||
DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) = DC_CMD_INT_FRAME_END_INT; // Clear interrupt.
|
display_wait_interrupt(DC_CMD_INT_FRAME_END_INT);
|
||||||
while (!(DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) & DC_CMD_INT_FRAME_END_INT))
|
|
||||||
;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Wait for vblank before resetting sync points.
|
// Wait for vblank before resetting sync points.
|
||||||
DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) = DC_CMD_INT_FRAME_END_INT; // Clear interrupt.
|
display_wait_interrupt(DC_CMD_INT_FRAME_END_INT);
|
||||||
while (!(DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) & DC_CMD_INT_FRAME_END_INT))
|
|
||||||
;
|
|
||||||
usleep(14);
|
usleep(14);
|
||||||
|
|
||||||
// Reset all states of syncpt block.
|
// Reset all states of syncpt block.
|
||||||
@ -94,8 +110,7 @@ static void _display_dsi_wait_vblank(bool enable)
|
|||||||
DSI(_DSIREG(DSI_VIDEO_MODE_CONTROL)) = 0;
|
DSI(_DSIREG(DSI_VIDEO_MODE_CONTROL)) = 0;
|
||||||
|
|
||||||
// Disable and clear vblank interrupt.
|
// Disable and clear vblank interrupt.
|
||||||
DISPLAY_A(_DIREG(DC_CMD_INT_ENABLE)) = 0;
|
display_disable_interrupt(DC_CMD_INT_FRAME_END_INT);
|
||||||
DISPLAY_A(_DIREG(DC_CMD_INT_STATUS)) = DC_CMD_INT_FRAME_END_INT;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -793,6 +793,11 @@ void display_init();
|
|||||||
void display_backlight_pwm_init();
|
void display_backlight_pwm_init();
|
||||||
void display_end();
|
void display_end();
|
||||||
|
|
||||||
|
/*! Interrupt management. */
|
||||||
|
void display_enable_interrupt(u32 intr);
|
||||||
|
void display_disable_interrupt(u32 intr);
|
||||||
|
void display_wait_interrupt(u32 intr);
|
||||||
|
|
||||||
/*! Get/Set Display panel ID. */
|
/*! Get/Set Display panel ID. */
|
||||||
u16 display_get_decoded_panel_id();
|
u16 display_get_decoded_panel_id();
|
||||||
void display_set_decoded_panel_id(u32 id);
|
void display_set_decoded_panel_id(u32 id);
|
||||||
|
Loading…
Reference in New Issue
Block a user