mirror of
https://github.com/CTCaer/hekate.git
synced 2024-11-26 11:42:09 +00:00
clock: Prevent PLLC4 from glitching
This commit is contained in:
parent
bb2b339b54
commit
1d3d1c8454
2 changed files with 8 additions and 2 deletions
|
@ -349,12 +349,15 @@ static void _clock_disable_pllc4(u32 mask)
|
||||||
{
|
{
|
||||||
pllc4_enabled &= ~mask;
|
pllc4_enabled &= ~mask;
|
||||||
|
|
||||||
if (pllc4_enabled & PLLC4_IN_USE)
|
// Check if currently in use or disabled.
|
||||||
|
if ((pllc4_enabled & PLLC4_IN_USE) || !(pllc4_enabled & PLLC4_ENABLED))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Disable PLLC4.
|
// Disable PLLC4.
|
||||||
|
msleep(1); // Wait at least 1ms to prevent glitching.
|
||||||
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) &= ~PLLCX_BASE_ENABLE;
|
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) &= ~PLLCX_BASE_ENABLE;
|
||||||
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) |= PLLC4_BASE_IDDQ;
|
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) |= PLLC4_BASE_IDDQ;
|
||||||
|
usleep(10);
|
||||||
|
|
||||||
pllc4_enabled = 0;
|
pllc4_enabled = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -349,12 +349,15 @@ static void _clock_disable_pllc4(u32 mask)
|
||||||
{
|
{
|
||||||
pllc4_enabled &= ~mask;
|
pllc4_enabled &= ~mask;
|
||||||
|
|
||||||
if (pllc4_enabled & PLLC4_IN_USE)
|
// Check if currently in use or disabled.
|
||||||
|
if ((pllc4_enabled & PLLC4_IN_USE) || !(pllc4_enabled & PLLC4_ENABLED))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Disable PLLC4.
|
// Disable PLLC4.
|
||||||
|
msleep(1); // Wait at least 1ms to prevent glitching.
|
||||||
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) &= ~PLLCX_BASE_ENABLE;
|
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) &= ~PLLCX_BASE_ENABLE;
|
||||||
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) |= PLLC4_BASE_IDDQ;
|
CLOCK(CLK_RST_CONTROLLER_PLLC4_BASE) |= PLLC4_BASE_IDDQ;
|
||||||
|
usleep(10);
|
||||||
|
|
||||||
pllc4_enabled = 0;
|
pllc4_enabled = 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue