

## 18.6 CCM Memory Map/Register Definition

### NOTE

CCM Register reset values may not be the same in ROM. See [Table 18-1](#) for more information.

**CCM memory map**

| Absolute address (hex) | Register name                                          | Width (in bits) | Access | Reset value | Section/page                |
|------------------------|--------------------------------------------------------|-----------------|--------|-------------|-----------------------------|
| 20C_4000               | CCM Control Register (CCM_CCR)                         | 32              | R/W    | 0401_16FFh  | <a href="#">18.6.1/843</a>  |
| 20C_4004               | CCM Control Divider Register (CCM_CCDDR)               | 32              | R/W    | 0000_0000h  | <a href="#">18.6.2/845</a>  |
| 20C_4008               | CCM Status Register (CCM_CSR)                          | 32              | R      | 0000_0010h  | <a href="#">18.6.3/846</a>  |
| 20C_400C               | CCM Clock Switcher Register (CCM_CCSR)                 | 32              | R/W    | 0000_0100h  | <a href="#">18.6.4/847</a>  |
| 20C_4010               | CCM Arm Clock Root Register (CCM_CACRR)                | 32              | R/W    | 0000_0000h  | <a href="#">18.6.5/849</a>  |
| 20C_4014               | CCM Bus Clock Divider Register (CCM_CBCDR)             | 32              | R/W    | 0001_8D00h  | <a href="#">18.6.6/850</a>  |
| 20C_4018               | CCM Bus Clock Multiplexer Register (CCM_CBCMR)         | 32              | R/W    | 0002_0324h  | <a href="#">18.6.7/852</a>  |
| 20C_401C               | CCM Serial Clock Multiplexer Register 1 (CCM_CSCMR1)   | 32              | R/W    | 00F0_0000h  | <a href="#">18.6.8/855</a>  |
| 20C_4020               | CCM Serial Clock Multiplexer Register 2 (CCM_CSCMR2)   | 32              | R/W    | 02B9_2F06h  | <a href="#">18.6.9/858</a>  |
| 20C_4024               | CCM Serial Clock Divider Register 1 (CCM_CSCDR1)       | 32              | R/W    | 0049_0B00h  | <a href="#">18.6.10/859</a> |
| 20C_4028               | CCM SSI1 Clock Divider Register (CCM_CS1CDR)           | 32              | R/W    | 0EC1_02C1h  | <a href="#">18.6.11/862</a> |
| 20C_402C               | CCM SSI2 Clock Divider Register (CCM_CS2CDR)           | 32              | R/W    | 0007_36C1h  | <a href="#">18.6.12/864</a> |
| 20C_4030               | CCM D1 Clock Divider Register (CCM_CDCCDR)             | 32              | R/W    | 33F7_1F92h  | <a href="#">18.6.13/866</a> |
| 20C_4034               | CCM HSC Clock Divider Register (CCM_CHSCCDR)           | 32              | R/W    | 0002_A150h  | <a href="#">18.6.14/868</a> |
| 20C_4038               | CCM Serial Clock Divider Register 2 (CCM_CSCDR2)       | 32              | R/W    | 0002_A150h  | <a href="#">18.6.15/870</a> |
| 20C_403C               | CCM Serial Clock Divider Register 3 (CCM_CSCDR3)       | 32              | R/W    | 0001_0841h  | <a href="#">18.6.16/872</a> |
| 20C_4048               | CCM Divider Handshake In-Process Register (CCM_CDHIPR) | 32              | R      | 0000_0000h  | <a href="#">18.6.17/874</a> |
| 20C_4054               | CCM Low Power Control Register (CCM_CLPCR)             | 32              | R/W    | 0000_0079h  | <a href="#">18.6.18/877</a> |
| 20C_4058               | CCM Interrupt Status Register (CCM_CISR)               | 32              | w1c    | 0000_0000h  | <a href="#">18.6.19/880</a> |
| 20C_405C               | CCM Interrupt Mask Register (CCM_CIMR)                 | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.20/883</a> |
| 20C_4060               | CCM Clock Output Source Register (CCM_CCOSR)           | 32              | R/W    | 000A_0001h  | <a href="#">18.6.21/886</a> |
| 20C_4064               | CCM General Purpose Register (CCM_CGPR)                | 32              | R/W    | 0000_FE62h  | <a href="#">18.6.22/889</a> |

Table continues on the next page...

## **CCM memory map (continued)**

| Absolute address (hex) | Register name                                   | Width (in bits) | Access | Reset value | Section/page                |
|------------------------|-------------------------------------------------|-----------------|--------|-------------|-----------------------------|
| 20C_4068               | CCM Clock Gating Register 0 (CCM_CCGR0)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.23/890</a> |
| 20C_406C               | CCM Clock Gating Register 1 (CCM_CCGR1)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.24/892</a> |
| 20C_4070               | CCM Clock Gating Register 2 (CCM_CCGR2)         | 32              | R/W    | FC3F_FFFFh  | <a href="#">18.6.25/893</a> |
| 20C_4074               | CCM Clock Gating Register 3 (CCM_CCGR3)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.26/895</a> |
| 20C_4078               | CCM Clock Gating Register 4 (CCM_CCGR4)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.27/896</a> |
| 20C_407C               | CCM Clock Gating Register 5 (CCM_CCGR5)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.28/897</a> |
| 20C_4080               | CCM Clock Gating Register 6 (CCM_CCGR6)         | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.29/899</a> |
| 20C_4088               | CCM Module Enable Override Register (CCM_CMEOR) | 32              | R/W    | FFFF_FFFFh  | <a href="#">18.6.30/900</a> |

### 18.6.1 CCM Control Register (CCM\_CCR)

The figure below represents the CCM Control Register (CCR), which contains bits to control general operation of CCM. The table below provides its field descriptions.

Address: 20C 4000h base + 0h offset = 20C 4000h

**CCM\_CCR field descriptions**

| Field                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 27<br>RBC_EN                  | Enable for REG_BYPASS_COUNTER. If enabled, analog_reg_bypass signal will be asserted after REG_BYPASS_COUNT clocks of CKIL, after standby voltage is requested. If standby voltage is not requested analog_reg_bypass won't be asserted, even if counter is enabled.<br><br>1 REG_BYPASS_COUNTER enabled.<br>0 REG_BYPASS_COUNTER disabled                                                                                                                                                                                                                                                                                                                                                          |
| 26–21<br>REG_BYPASS_<br>COUNT | Counter for analog_reg_bypass signal assertion after standby voltage request by PMIC_STBY_REQ. Should be zeroed and reconfigured after exit from low power mode.<br><br>REG_BYPASS_COUNT can also be used for holding off interrupts when the PGC unit is sending signals to power gate the core.<br><br>000000 no delay<br>000001 1 CKIL clock period delay<br>111111 63 CKIL clock periods delay                                                                                                                                                                                                                                                                                                  |
| 20–19<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 18–16<br>WB_COUNT             | Well Bias counter. Delay, defined by this value, counted by CKIL clock will be applied till well bias is enabled at exit from wait or stop low power mode. Counter will be used if wb_core_at_lpm or wb_per_at_lpm bits are set. Should be zeroed and reconfigured after exit from low power mode.<br><br>000 no delay<br>001 1 CKIL clock delay<br>111 7 CKIL clocks delay                                                                                                                                                                                                                                                                                                                         |
| 15–13<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12<br>COSC_EN                 | On chip oscillator enable bit - this bit value is reflected on the output cosc_en. The system will start with on chip oscillator enabled to supply source for the PLLs. Software can change this bit if a transition to the bypass PLL clocks was performed for all the PLLs. In cases that this bit is changed from '0' to '1' then CCM will enable the on chip oscillator and after counting oscnt ckil clock cycles it will notify that on chip oscillator is ready by a interrupt cosc_ready and by status bit cosc_ready. The cosc_en bit should be changed only when on chip oscillator is not chosen as the clock source.<br><br>0 disable on chip oscillator<br>1 enable on chip oscillator |
| 11–8<br>Reserved              | This field is reserved.<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| OSCNT                         | Oscillator ready counter value. These bits define value of 32KHz counter, that serve as counter for oscillator lock time. This is used for oscillator lock time. Current estimation is ~5ms. This counter will be used in ignition sequence and in wake from stop sequence if sbyos bit was defined, to notify that on chip oscillator output is ready for the dpll_ip to use and only then the gate in dpll_ip can be opened.<br><br>00000000 count 1 ckil<br>11111111 count 256 ckil's                                                                                                                                                                                                            |

## 18.6.2 CCM Control Divider Register (CCM\_CCDR)

The figure below represents the CCM Control Divider Register (CCDR), which contains bits that control the loading of the dividers that need handshake with the modules they affect. The table below provides its field descriptions.

Address: 20C\_4000h base + 4h offset = 20C\_4004h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |   | 23 | 22 | 21 | 20 | 19 | 18 | 17            | 16            |
|-------|----|----|----|----|----|----|----|----|---|----|----|----|----|----|----|---------------|---------------|
| R     |    |    |    |    |    |    |    |    | 0 |    |    |    |    |    |    |               |               |
| W     |    |    |    |    |    |    |    |    |   |    |    |    |    |    |    | mmdc_ch0_mask | mmdc_ch1_mask |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |   | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |   | 7  | 6  | 5  | 4  | 3  | 2  | 1             | 0             |
| R     |    |    |    |    |    |    |    |    | 0 |    |    |    |    |    |    |               |               |
| W     |    |    |    |    |    |    |    |    |   |    |    |    |    |    |    |               |               |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |   | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             |

### CCM\_CCDR field descriptions

| Field               | Description                                                                                                                                                                                                                                                                                   |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–18<br>Reserved   | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                  |
| 17<br>mmdc_ch0_mask | During divider ratio mmdc_ch0_axi_podf change or sync mux periph_clk_sel change (but not jtag) or SRC request during warm reset, mask handshake with mmdc_ch0 module.<br><br>0 allow handshake with mmdc_ch0 module<br>1 mask handshake with mmdc_ch0. Request signal will not be generated.  |
| 16<br>mmdc_ch1_mask | During divider ratio mmdc_ch1_axi_podf change or sync mux periph2_clk_sel change (but not jtag) or SRC request during warm reset, mask handshake with mmdc_ch1 module.<br><br>0 allow handshake with mmdc_ch1 module<br>1 mask handshake with mmdc_ch1. Request signal will not be generated. |
| Reserved            | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                  |

### 18.6.3 CCM Status Register (CCM\_CSR)

The figure below represents the CCM status Register (CSR). The status bits are read-only bits. The table below provides its field descriptions.

Address: 20C\_4000h base + 8h offset = 20C\_4008h



**CCM\_CSR field descriptions**

| Field            | Description                                                                                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–6<br>Reserved | This read-only field is reserved and always has the value 0.                                                                                                                                 |
| 5<br>cosc_ready  | Status indication of on board oscillator. This bit will be asserted if on chip oscillator is enabled and on chip oscillator is not powered down, and if oscnt counter has finished counting. |

*Table continues on the next page...*

**CCM\_CSR field descriptions (continued)**

| Field        | Description                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------|
|              | 0 on board oscillator is not ready.<br>1 on board oscillator is ready.                                                |
| 4 Reserved   | This read-only field is reserved and always has the value 1.                                                          |
| 3–1 Reserved | This read-only field is reserved and always has the value 0.                                                          |
| 0 REF_EN_B   | Status of the value of CCM_REF_EN_B output of ccm<br>0 value of CCM_REF_EN_B is '0'<br>1 value of CCM_REF_EN_B is '1' |

**18.6.4 CCM Clock Switcher Register (CCM\_CCSR)**

The figure below represents the CCM Clock Switcher register (CCSR). The CCSR register contains bits to control the switcher sub-module dividers and multiplexers. The table below provides its field descriptions.

Address: 20C\_4000h base + Ch offset = 20C\_400Ch

| Bit   | 31                | 30                | 29                | 28                | 27                | 26                | 25                | 24       | 23 | 22 | 21 | 20 | 19 | 18              | 17       | 16              |
|-------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------|----|----|----|----|----|-----------------|----------|-----------------|
| R     |                   |                   |                   |                   |                   |                   |                   |          | 0  |    |    |    |    |                 |          |                 |
| W     |                   |                   |                   |                   |                   |                   |                   |          |    |    |    |    |    |                 |          |                 |
| Reset | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0        | 0  | 0  | 0  | 0  | 0  | 0               | 0        | 0               |
| Bit   | 15                | 14                | 13                | 12                | 11                | 10                | 9                 | 8        | 7  | 6  | 5  | 4  | 3  | 2               | 1        | 0               |
| R     | pfd_540m_dis_mask | pfd_720m_dis_mask | pfd_454m_dis_mask | pfd_508m_dis_mask | pfd_594m_dis_mask | pfd_352m_dis_mask | pfd_396m_dis_mask | step_sel |    | 0  |    |    |    | pll1_sw_clk_sel | Reserved | pll3_sw_clk_sel |
| W     | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 1        | 0  | 0  | 0  | 0  | 0  | 0               | 0        | 0               |
| Reset | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 1        | 0  | 0  | 0  | 0  | 0  | 0               | 0        | 0               |

## CCM\_CCSR field descriptions

| Field                       | Description                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved           | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                           |
| 15<br>pfd_540m_dis_<br>mask | Mask of 540M PFD auto-disable.<br>0 - 540M PFD disable=0 (PFD always on)<br>1 540M PFD disable is managed by associated dividers disable. If all 540M-driven dividers are closed, PFD is disabled.                                                                                                                                     |
| 14<br>pfd_720m_dis_<br>mask | Mask of 720M PFD auto-disable.<br>0 720M PFD disable=0 (PFD always on)<br>1 720M PFD disable is managed by associated dividers disable. If all 720M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 13<br>pfd_454m_dis_<br>mask | Mask of 454M PFD auto-disable.<br>0 454M PFD disable=0 (PFD always on)<br>1 454M PFD disable is managed by associated dividers disable. If all 454M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 12<br>pfd_508m_dis_<br>mask | Mask of 508M PFD auto-disable.<br>0 508M PFD disable=0 (PFD always on)<br>1 508M PFD disable is managed by associated dividers disable. If all 508M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 11<br>pfd_594m_dis_<br>mask | Mask of 594M PFD auto-disable.<br>0 594M PFD disable=0 (PFD always on)<br>1 594M PFD disable is managed by associated dividers disable. If all 594M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 10<br>pfd_352m_dis_<br>mask | Mask of 352M PFD auto-disable.<br>0 352M PFD disable=0 (PFD always on)<br>1 352M PFD disable is managed by associated dividers disable. If all 352M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 9<br>pfd_396m_dis_<br>mask  | Mask of 396M PFD auto-disable.<br>0 396M PFD disable=0 (PFD always on)<br>1 396M PFD disable is managed by associated dividers disable. If all 396M-driven dividers are closed, PFD is disabled.                                                                                                                                       |
| 8<br>step_sel               | Selects the option to be chosen for the step frequency when shifting ARM frequency. This will control the step_clk.<br><br><b>NOTE:</b> This mux is allowed to be changed only if its output is not used, i.e. ARM uses the output of pll1, and step_clk is not used.<br><br>0 osc_clk (24M) - source for lp_apm.<br>1 PLL2 PFD2 clock |
| 7–3<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                           |
| 2<br>pll1_sw_clk_sel        | Selects source to generate pll1_sw_clk.<br>0 pll1_main_clk<br>1 step_clk                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

**CCM\_CCSR field descriptions (continued)**

| Field                | Description                                                                                                                          |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>-               | This field is reserved.<br>Reserved                                                                                                  |
| 0<br>pll3_sw_clk_sel | Selects source to generate pll3_sw_clk. This bit should only be used for testing purposes.<br>0 pll3_main_clk<br>1 pll3 bypass clock |

**18.6.5 CCM Arm Clock Root Register (CCM\_CACRR)**

The figure below represents the CCM Arm Clock Root register (CACRR). The CACRR register contains bits to control the ARM clock root generation. The table below provides its field descriptions.

Address: 20C\_4000h base + 10h offset = 20C\_4010h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|----------|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |          |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | arm_podf |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |  |          |

**CCM\_CACRR field descriptions**

| Field            | Description                                                                                                                                                                                                                                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–3<br>Reserved | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                 |
| arm_podf         | Divider for ARM clock root.<br><br><b>NOTE:</b> If arm_freq_shift_divider is set to '1' then any new write to arm_podf will be held until arm_clk_switch_req signal is asserted.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |

## 18.6.6 CCM Bus Clock Divider Register (CCM\_CBCDR)

The figure below represents the CCM Bus Clock Divider Register (CBCDR). The CBCDR register contains bits to control the clock generation sub module dividers. The table below provides its field descriptions.

Address: 20C\_4000h base + 14h offset = 20C\_4014h

| Bit   | 31       | 30 | 29               | 28 | 27              | 26             | 25          | 24       | 23                | 22                | 21                | 20       | 19 | 18 | 17 | 16 |
|-------|----------|----|------------------|----|-----------------|----------------|-------------|----------|-------------------|-------------------|-------------------|----------|----|----|----|----|
| R     | Reserved |    | periph_clk2_podf |    | periph2_clk_sel | periph_clk_sel |             | Reserved |                   | mmdc_ch0_axi_podf |                   | axi_podf |    |    |    |    |
| W     |          |    |                  |    |                 |                |             |          |                   |                   |                   |          |    |    |    |    |
| Reset | 0        | 0  | 0                | 0  | 0               | 0              | 0           | 0        | 0                 | 0                 | 0                 | 0        | 0  | 0  | 0  | 1  |
| Bit   | 15       | 14 | 13               | 12 | 11              | 10             | 9           | 8        | 7                 | 6                 | 5                 | 4        | 3  | 2  | 1  | 0  |
| R     | Reserved |    | ahb_podf         |    | ipg_podf        |                | axi_alt_sel | axi_sel  | mmdc_ch1_axi_podf |                   | periph2_clk2_podf |          |    |    |    |    |
| W     |          |    |                  |    |                 |                |             |          |                   |                   |                   |          |    |    |    |    |
| Reset | 1        | 0  | 0                | 0  | 1               | 1              | 0           | 1        | 0                 | 0                 | 0                 | 0        | 0  | 0  | 0  | 0  |

### CCM\_CBCDR field descriptions

| Field                     | Description                                                                                                                                                                                                                                                                                                                   |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30<br>-                | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                           |
| 29–27<br>periph_clk2_podf | Divider for periph2 clock podf.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                   |
| 26<br>periph2_clk_sel     | Selector for peripheral2 main clock (source of mmdc_ch1_clk_root ).<br><br><b>NOTE:</b> Any change of this mux select will involve handshake with the MMDC. Refer to the CCDR and CDHIPR registers for the handshake bypass and busy bits.<br><br>0 PLL2 (pll2_main_clk)<br>1 derive clock from periph_clk2_clk clock source. |

Table continues on the next page...

## CCM\_CBCDR field descriptions (continued)

| Field                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>periph_clk_sel       | <p>Selector for peripheral main clock (source of MMDC_CH0_CLK_ROOT).</p> <p><b>NOTE:</b> Alternative clock source should be used when PLL is relocked. For PLL relock procedure pls refer to the PLL chapter.</p> <p><b>NOTE:</b> Any change of this sync mux select will involve handshake with the MMDC. Refer to the CCCR and CDHIPR registers for the handshake bypass and busy bits.</p> <p>0 PLL2 (pll2_main_clk)<br/>1 derive clock from periph_clk2_clk clock source.</p> |
| 24–22<br>-                 | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21–19<br>mmdc_ch0_axi_podf | <p>Divider for mmddc_ch0_axi podf.</p> <p>000 divide by 1<br/>001 divide by 2<br/>010 divide by 3<br/>011 divide by 4<br/>100 divide by 5<br/>101 divide by 6<br/>110 divide by 7<br/>111 divide by 8</p>                                                                                                                                                                                                                                                                         |
| 18–16<br>axi_podf          | <p>Divider for axi podf.</p> <p><b>NOTE:</b> Any change of this divider might involve handshake with EMI and IPU. See CDHIPR register for the handshake busy bits.</p> <p>000 divide by 1<br/>001 divide by 2<br/>010 divide by 3<br/>011 divide by 4<br/>100 divide by 5<br/>101 divide by 6<br/>110 divide by 7<br/>111 divide by 8</p>                                                                                                                                         |
| 15–13<br>-                 | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12–10<br>ahb_podf          | <p>Divider for AHB PODF.</p> <p><b>NOTE:</b> Any change of this divider might involve handshake with EMI and IPU. See CDHIPR register for the handshake busy bits.</p> <p>000 divide by 1<br/>001 divide by 2<br/>010 divide by 3<br/>011 divide by 4<br/>100 divide by 5<br/>101 divide by 6<br/>110 divide by 7<br/>111 divide by 8</p>                                                                                                                                         |

*Table continues on the next page...*

**CCM\_CBCDR field descriptions (continued)**

| Field                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------|-----|--------------------------------------------------------------------------|-----|-------------|-----|-------------|-----|-------------|-----|-------------|-----|-------------|-----|-------------|
| 9–8<br>ipg_podf              | <p>Divider for ipg podf.</p> <p><b>NOTE:</b> SDMA module will not support ratio of 1:3 and 1:4 for ahb_clk:ipg_clk. In case SDMA is used, then those ratios should not be used.</p> <table> <tr><td>00</td><td>divide by 1</td></tr> <tr><td>01</td><td>divide by 2</td></tr> <tr><td>10</td><td>divide by 3</td></tr> <tr><td>11</td><td>divide by 4</td></tr> </table>                                                                                                                                                                            | 00  | divide by 1                                                              | 01  | divide by 2                                                              | 10  | divide by 3 | 11  | divide by 4 |     |             |     |             |     |             |     |             |
| 00                           | divide by 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 01                           | divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 10                           | divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 11                           | divide by 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 7<br>axi_alt_sel             | <p>AXI alternative clock select</p> <table> <tr><td>0</td><td>pll2 396MHz PFD will be selected as alternative clock for AXI root clock</td></tr> <tr><td>1</td><td>pll3 540MHz PFD will be selected as alternative clock for AXI root clock</td></tr> </table>                                                                                                                                                                                                                                                                                      | 0   | pll2 396MHz PFD will be selected as alternative clock for AXI root clock | 1   | pll3 540MHz PFD will be selected as alternative clock for AXI root clock |     |             |     |             |     |             |     |             |     |             |     |             |
| 0                            | pll2 396MHz PFD will be selected as alternative clock for AXI root clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 1                            | pll3 540MHz PFD will be selected as alternative clock for AXI root clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 6<br>axi_sel                 | <p>AXI clock source select</p> <table> <tr><td>0</td><td>Periph_clk output will be used as AXI clock root</td></tr> <tr><td>1</td><td>AXI alternative clock will be used as AXI clock root</td></tr> </table>                                                                                                                                                                                                                                                                                                                                       | 0   | Periph_clk output will be used as AXI clock root                         | 1   | AXI alternative clock will be used as AXI clock root                     |     |             |     |             |     |             |     |             |     |             |     |             |
| 0                            | Periph_clk output will be used as AXI clock root                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 1                            | AXI alternative clock will be used as AXI clock root                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 5–3<br>mmdc_ch1_axi_<br>podf | <p>Divider for mmdc_ch1_axi podf.</p> <p><b>NOTE:</b> This design implementation does not use MMDC_CH1_CLK_ROOT as a clock source to the MMDC. Only MMDC_CH0_CLK_ROOT is used.</p> <table> <tr><td>000</td><td>divide by 1</td></tr> <tr><td>001</td><td>divide by 2</td></tr> <tr><td>010</td><td>divide by 3</td></tr> <tr><td>011</td><td>divide by 4</td></tr> <tr><td>100</td><td>divide by 5</td></tr> <tr><td>101</td><td>divide by 6</td></tr> <tr><td>110</td><td>divide by 7</td></tr> <tr><td>111</td><td>divide by 8</td></tr> </table> | 000 | divide by 1                                                              | 001 | divide by 2                                                              | 010 | divide by 3 | 011 | divide by 4 | 100 | divide by 5 | 101 | divide by 6 | 110 | divide by 7 | 111 | divide by 8 |
| 000                          | divide by 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 001                          | divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 010                          | divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 011                          | divide by 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 100                          | divide by 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 101                          | divide by 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 110                          | divide by 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 111                          | divide by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| periph2_clk2_<br>podf        | <p>Divider for periph2_clk2 podf.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <table> <tr><td>000</td><td>divide by 1</td></tr> <tr><td>001</td><td>divide by 2</td></tr> <tr><td>010</td><td>divide by 3</td></tr> <tr><td>011</td><td>divide by 4</td></tr> <tr><td>100</td><td>divide by 5</td></tr> <tr><td>101</td><td>divide by 6</td></tr> <tr><td>110</td><td>divide by 7</td></tr> <tr><td>111</td><td>divide by 8</td></tr> </table>                                                                    | 000 | divide by 1                                                              | 001 | divide by 2                                                              | 010 | divide by 3 | 011 | divide by 4 | 100 | divide by 5 | 101 | divide by 6 | 110 | divide by 7 | 111 | divide by 8 |
| 000                          | divide by 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 001                          | divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 010                          | divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 011                          | divide by 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 100                          | divide by 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 101                          | divide by 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 110                          | divide by 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |
| 111                          | divide by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |                                                                          |     |                                                                          |     |             |     |             |     |             |     |             |     |             |     |             |

**18.6.7 CCM Bus Clock Multiplexer Register (CCM\_CBCMR)**

The figure below represents the CCM Bus Clock Multiplexer Register (CBCMR). The CBCMR register contains bits to control the multiplexers that generate the bus clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and the respective clock is gated in LPCG. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

The change for arm\_clk\_sel should be done through sdma so that ARM will not use this clock during the change and the clock will be gated in LPCG.

Address: 20C\_4000h base + 18h offset = 20C\_4018h

| Bit   | 31                | 30              | 29             | 28               | 27                   | 26       | 25                  | 24                 | 23 | 22                  | 21 | 20                | 19                | 18                 | 17                 | 16 |  |
|-------|-------------------|-----------------|----------------|------------------|----------------------|----------|---------------------|--------------------|----|---------------------|----|-------------------|-------------------|--------------------|--------------------|----|--|
| R     | gpu3d_shader_podf |                 |                | gpu3d_core_podf  |                      |          | gpu2d_core_clk_podf |                    |    | pre_periph2_clk_sel |    |                   | periph2_clk2_sel  | pre_periph_clk_sel | gpu2d_core_clk_sel |    |  |
| W     |                   |                 |                |                  |                      |          |                     |                    |    |                     |    |                   |                   |                    |                    |    |  |
| Reset | 0                 | 0               | 0              | 0                | 0                    | 0        | 0                   | 0                  | 0  | 0                   | 0  | 0                 | 0                 | 0                  | 1                  | 0  |  |
| Bit   | 15                | 14              | 13             | 12               | 11                   | 10       | 9                   | 8                  | 7  | 6                   | 5  | 4                 | 3                 | 2                  | 1                  | 0  |  |
| R     | vpu_axi_clk_sel   | periph_clk2_sel | vdoaxi_clk_sel | pcie_axi_clk_sel | gpu3d_shader_clk_sel | Reserved |                     | gpu3d_core_clk_sel |    | Reserved            |    | gpu3d_axi_clk_sel | gpu2d_axi_clk_sel |                    |                    |    |  |
| W     | 0                 | 0               | 0              | 0                | 0                    | 1        | 1                   | 0                  | 0  | 0                   | 1  | 0                 | 0                 | 1                  | 0                  | 0  |  |
| Reset | 0                 | 0               | 0              | 0                | 0                    | 0        | 1                   | 1                  | 0  | 0                   | 0  | 1                 | 0                 | 1                  | 0                  | 0  |  |

**CCM\_CBCMR field descriptions**

| Field                      | Description                                                                                                                                                                                                                                                           |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–29<br>gpu3d_shader_podf | Divider for gpu3d_shader clock.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 28–26<br>gpu3d_core_podf   | Divider for gpu3d_core clock.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2                                                                                                                     |

Table continues on the next page...

**CCM\_CBCMR field descriptions (continued)**

| Field                        | Description                                                                                                                                                                                                                                                         |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | 010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                                      |
| 25–23<br>gpu2d_core_clk_podf | Divider for gpu2d_core clock.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 22–21<br>pre_periph2_clk_sel | Selector for pre_periph2 clock multiplexer<br><br>00 derive clock from PLL2 main 528MHz clock<br>01 derive clock from 396MHz PLL2 PFD<br>10 derive clock from 352M PFD<br>11 derive clock from 198MHz clock (divided 396MHz PLL2 PFD)                               |
| 20<br>periph2_clk2_sel       | Selector for periph2_clk2 clock multiplexer<br><br>0 derive clock from pll3_sw_clk<br>1 derive clock from PLL2 Main                                                                                                                                                 |
| 19–18<br>pre_periph_clk_sel  | Selector for pre_periph clock multiplexer<br><br>00 derive clock from PLL2 main 528MHz clock<br>01 derive clock from 396MHz PLL2 PFD<br>10 derive clock from 352M PFD<br>11 derive clock from 198MHz clock (divided 396MHz PLL2 PFD)                                |
| 17–16<br>gpu2d_core_clk_sel  | Selector for open vg (GPU2D Core) clock multiplexer<br><br>00 derive clock from axi<br>01 derive clock from pll3_sw_clk<br>10 352M PFD<br>11 derive clock from 396M PFD                                                                                             |
| 15–14<br>vpu_axi_clk_sel     | Selector for VPU axi clock multiplexer<br><br>00 derive clock from AXI<br>01 derive clock from 396M PFD<br>10 derive clock from 352M PFD<br>11 Reserved                                                                                                             |
| 13–12<br>periph_clk2_sel     | Selector for peripheral clk2 clock multiplexer<br><br>00 derive clock from pll3_sw_clk                                                                                                                                                                              |

*Table continues on the next page...*

**CCM\_CBCMR field descriptions (continued)**

| Field                       | Description                                                                                                                                                                                 |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | 01 derive clock from OSC_CLK (pll1_ref_clk)<br>10 derive clock from PLL2 (pll2_main_clk)<br>11 reserved                                                                                     |
| 11<br>vdoaxi_clk_sel        | Selector for vdoaxi clock multiplexer<br><br>0 derive clock from axi clk<br>1 derive clock from 132M clock                                                                                  |
| 10<br>pcie_axi_clk_sel      | Selector for pcie_axi clock multiplexer<br><br>0 derive clock from axi clk<br>1 derive clock from system_133M clk                                                                           |
| 9–8<br>gpu3d_shader_clk_sel | Selector for gpu3d_shader clock multiplexer<br><br>00 derive clock from mmddc_ch0 clk<br>01 derive clock from pll3_sw_clk<br>10 derive clock from PFD 594M<br>11 derive clock from 720M PFD |
| 7–6<br>-                    | This field is reserved.<br>Reserved                                                                                                                                                         |
| 5–4<br>gpu3d_core_clk_sel   | Selector for gpu3d_core clock multiplexer<br><br>00 derive clock from mmddc_ch0<br>01 derive clock from pll3_sw_clk<br>10 derive clock from 594M PFD<br>11 derive clock from 396M PFD       |
| 3–2<br>-                    | This field is reserved.<br>Reserved                                                                                                                                                         |
| 1<br>gpu3d_axi_clk_sel      | Selector for gpu3d_axi clock multiplexer<br><br>0 derive clock from axi<br>1 derive clock from system_133M_clk                                                                              |
| 0<br>gpu2d_axi_clk_sel      | Selector for gpu2d_axi clock multiplexer<br><br>0 derive clock from axi<br>1 derive clock from system_133M_clk                                                                              |

**18.6.8 CCM Serial Clock Multiplexer Register 1 (CCM\_CSCMR1)**

The figure below represents the CCM Serial Clock Multiplexer Register 1 (CSCMR1). The CSCMR1 register contains bits to control the multiplexers that generate the serial clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and

## CCM Memory Map/Register Definition

the clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 20C\_4000h base + 1Ch offset = 20C\_401Ch



### CCM\_CSCMR1 field descriptions

| Field                       | Description                                                                                                                                                                                  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>Reserved              | This read-only field is reserved and always has the value 0.                                                                                                                                 |
| 30–29<br>aclk_eim_slow_sel  | Selector for aclk_eim_slow root clock multiplexer<br>00 derive clock from AXI clk root<br>01 derive clock from pll3_sw_clk<br>10 derive clock from 396M PFD<br>11 derive clock from 352M PFD |
| 28–27<br>aclk_sel           | Selector for aclk root clock multiplexer<br>00 derive clock from 396M PFD<br>01 derive clock from pll3_sw_clk<br>10 derive clock from AXI clk root<br>11 derive clock from 352M PFD          |
| 26<br>-                     | This field is reserved.<br>Reserved                                                                                                                                                          |
| 25–23<br>aclk_eim_slow_podf | Divider for aclk_eim_slow clock root.<br>000 divide by 1                                                                                                                                     |

Table continues on the next page...

## CCM\_CSCMR1 field descriptions (continued)

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | 001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                                                                                                                                                                                                                                                     |
| 22–20<br>aclk_podf    | Divider for aclk clock root.<br><br><b>NOTE:</b> These bits are inverted between R/W and are not sequential. <ul style="list-style-type: none"> <li>000 divide by 7 (Read value 110)</li> <li>001 divide by 8 (Read value 111)</li> <li>010 divide by 5 (Read value 100)</li> <li>011 divide by 6 (Read value 101)</li> <li>100 divide by 3 (Read value 010)</li> <li>101 divide by 4 (Read value 011)</li> <li>110 divide by 1 (Read value 000)</li> <li>111 divide by 2 (Read value 001)</li> </ul> |
| 19<br>usdhc4_clk_sel  | Selector for usdhc4 clock multiplexer<br><br>0 derive clock from 396M PFD<br>1 derive clock from 352M PFD                                                                                                                                                                                                                                                                                                                                                                                             |
| 18<br>usdhc3_clk_sel  | Selector for usdhc3 clock multiplexer<br><br>0 derive clock from 396M PFD<br>1 derive clock from 352M PFD                                                                                                                                                                                                                                                                                                                                                                                             |
| 17<br>usdhc2_clk_sel  | Selector for usdhc2 clock multiplexer<br><br>0 derive clock from 396M PFD<br>1 derive clock from 352M PFD                                                                                                                                                                                                                                                                                                                                                                                             |
| 16<br>usdhc1_clk_sel  | Selector for usdhc1 clock multiplexer<br><br>0 derive clock from 396M PFD<br>1 derive clock from 352M PFD                                                                                                                                                                                                                                                                                                                                                                                             |
| 15–14<br>ssi3_clk_sel | Selector for ssi3 clock multiplexer<br><br>00 derive clock from 508.2M PFD<br>01 derive clock from 454.7M PFD<br>10 derive clock from pll4<br>11 Reserved                                                                                                                                                                                                                                                                                                                                             |
| 13–12<br>ssi2_clk_sel | Selector for ssi2 clock multiplexer<br><br>00 derive clock from 508.2M PFD<br>01 derive clock from 454.7M PFD<br>10 derive clock from pll4<br>11 Reserved                                                                                                                                                                                                                                                                                                                                             |
| 11–10<br>ssi1_clk_sel | Selector for ssi1 clock multiplexer                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Table continues on the next page...

**CCM\_CSCMR1 field descriptions (continued)**

| Field       | Description                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 00 derive clock from 508.2M PFD<br>01 derive clock from 454.7M PFD<br>10 derive clock from pll4<br>11 Reserved                                                                       |
| 9–6<br>-    | This field is reserved.<br>Reserved                                                                                                                                                  |
| perclk_podf | Divider for perclk podf.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |

**18.6.9 CCM Serial Clock Multiplexer Register 2 (CCM\_CSCMR2)**

The figure below represents the CCM Serial Clock Multiplexer Register 2 (CSCMR2). The CSCMR2 register contains bits to control the multiplexers that generate the serial clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and the clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 20C\_4000h base + 20h offset = 20C\_4020h



| Bit   | 15       | 14 | 13 | 12 | 11              | 10              | 9        | 8 | 7            | 6 | 5 | 4 | 3 | 2 | 1        | 0 |
|-------|----------|----|----|----|-----------------|-----------------|----------|---|--------------|---|---|---|---|---|----------|---|
| R     | Reserved |    |    |    | ldb_di1_ipu_div | ldb_di0_ipu_div | Reserved |   | can_clk_podf |   |   |   |   |   | Reserved |   |
| W     | 0        | 0  | 1  | 0  | 1               | 1               | 1        | 1 | 0            | 0 | 0 | 0 | 0 | 1 | 1        | 0 |
| Reset | 0        | 0  | 1  | 0  | 1               | 1               | 1        | 1 | 0            | 0 | 0 | 0 | 0 | 1 | 1        | 0 |

### CCM\_CSCMR2 field descriptions

| Field                 | Description                                                                                                                                                                                          |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–21<br>-            | This field is reserved.<br>Reserved                                                                                                                                                                  |
| 20–19<br>esai_clk_sel | Selector for esai clock multiplexer<br><br>00 derive clock from pll4 divided clock<br>01 derive clock from 508M PFD clock<br>10 derive clock from 454M PFD clock<br>11 derive clock from pll3_sw_clk |
| 18–12<br>-            | This field is reserved.<br>Reserved                                                                                                                                                                  |
| 11<br>ldb_di1_ipu_div | Control for divider of ldb clock for IPU di1<br><br>0 divide by 3.5<br>1 divide by 7                                                                                                                 |
| 10<br>ldb_di0_ipu_div | Control for divider of ldb clock for IPU di0<br><br>0 divide by 3.5<br>1 divide by 7                                                                                                                 |
| 9–8<br>-              | This field is reserved.<br>Reserved                                                                                                                                                                  |
| 7–2<br>can_clk_podf   | Divider for can clock podf.<br><br>000000 divide by 1<br>000111 divide by 8<br>111111 divide by 2^6                                                                                                  |
| -                     | This field is reserved.<br>Reserved                                                                                                                                                                  |

## 18.6.10 CCM Serial Clock Divider Register 1 (CCM\_CSCDR1)

The figure below represents the CCM Serial Clock Divider Register 1 (CSCDR1). The CSCDR1 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

### NOTE

Any change on the above dividers will have to be done while the module that its clock is affected is not functional and the

## CCM Memory Map/Register Definition

affected clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 20C\_4000h base + 24h offset = 20C\_4024h

|       |    |          |    |             |    |              |          |             |    |             |               |             |    |    |    |    |
|-------|----|----------|----|-------------|----|--------------|----------|-------------|----|-------------|---------------|-------------|----|----|----|----|
| Bit   | 31 | 30       | 29 | 28          | 27 | 26           | 25       | 24          | 23 | 22          | 21            | 20          | 19 | 18 | 17 | 16 |
| R     |    |          | 0  |             |    | vpu_axi_podf |          | usdhc4_podf |    | usdhc3_podf |               | usdhc2_podf |    |    |    |    |
| W     |    |          |    |             |    |              |          |             |    |             |               |             |    |    |    |    |
| Reset | 0  | 0        | 0  | 0           | 0  | 0            | 0        | 0           | 0  | 1           | 0             | 0           | 1  | 0  | 0  | 1  |
| Bit   | 15 | 14       | 13 | 12          | 11 | 10           | 9        | 8           | 7  | 6           | 5             | 4           | 3  | 2  | 1  | 0  |
| R     |    | Reserved |    | usdhc1_podf |    |              | Reserved |             |    |             | uart_clk_podf |             |    |    |    |    |
| W     |    |          |    |             |    |              |          |             |    |             |               |             |    |    |    |    |
| Reset | 0  | 0        | 0  | 0           | 1  | 0            | 1        | 1           | 0  | 0           | 0             | 0           | 0  | 0  | 0  | 0  |

### CCM\_CSCDR1 field descriptions

| Field                 | Description                                                                                                                                                                                                                                                       |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                      |
| 27–25<br>vpu_axi_podf | Divider for vpu axi clock podf.<br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 24–22<br>usdhc4_podf  | Divider for esdhc4 clock pred.<br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8  |
| 21–19<br>usdhc3_podf  | Divider for usdhc3 clock podf.<br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4                                                                              |

Table continues on the next page...

**CCM\_CSCDR1 field descriptions (continued)**

| Field                | Description                                                                                                                                                                                                                                                                                                           |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <p>100 divide by 5<br/>     101 divide by 6<br/>     110 divide by 7<br/>     111 divide by 8</p>                                                                                                                                                                                                                     |
| 18–16<br>usdhc2_podf | <p>Divider for usdhc2 clock.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1<br/>     001 divide by 2<br/>     010 divide by 3<br/>     011 divide by 4<br/>     100 divide by 5<br/>     101 divide by 6<br/>     110 divide by 7<br/>     111 divide by 8</p>      |
| 15–14<br>-           | <p>This field is reserved.<br/>     Reserved</p>                                                                                                                                                                                                                                                                      |
| 13–11<br>usdhc1_podf | <p>Divider for usdhc1 clock podf.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1<br/>     001 divide by 2<br/>     010 divide by 3<br/>     011 divide by 4<br/>     100 divide by 5<br/>     101 divide by 6<br/>     110 divide by 7<br/>     111 divide by 8</p> |
| 10–6<br>-            | <p>This field is reserved.<br/>     Reserved.</p>                                                                                                                                                                                                                                                                     |
| uart_clk_podf        | <p>Divider for uart clock podf.</p> <p>000000 divide by 1<br/>     111111 divide by <math>2^6</math></p>                                                                                                                                                                                                              |

### 18.6.11 CCM SSI1 Clock Divider Register (CCM\_CS1CDR)

The figure below represents the CCM SSI1, SSI3, ESAI Clock Divider Register (CS1CDR). The CS1CDR register contains bits to control the ssi1 clock generation dividers. The table below provides its field descriptions.

Address: 20C\_4000h base + 28h offset = 20C\_4028h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     |    |    |    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |    |    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  |

**CCM\_CS1CDR field descriptions**

| Field                  | Description                                                                                                                                                                              |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved      | This read-only field is reserved and always has the value 0.                                                                                                                             |
| 27–25<br>esai_clk_podf | Divider for esai clock podf.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 24–22<br>ssi3_clk_pred | Divider for ssi3 clock pred.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 21–16<br>ssi3_clk_podf | Divider for ssi3 clock podf.<br><br>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.                                             |

*Table continues on the next page...*

**CCM\_CS1CDR field descriptions (continued)**

| Field              | Description                                                                                                                                                                                      |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 000000 divide by 1<br>111111 divide by $2^6$                                                                                                                                                     |
| 15–12 Reserved     | This read-only field is reserved and always has the value 0.                                                                                                                                     |
| 11–9 esai_clk_pred | Divider for esai clock pred.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8         |
| 8–6 ssi1_clk_pred  | Divider for ssi1 clock pred.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8         |
| ssi1_clk_podf      | Divider for ssi1 clock podf.<br><br>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.<br><br>000000 divide by 1<br>111111 divide by $2^6$ |

## 18.6.12 CCM SSI2 Clock Divider Register (CCM\_CS2CDR)

The figure below represents the CCM SSI2, LDB Clock Divider Register (CS2CDR). The CS2CDR register contains bits to control the ssi2 clock generation dividers, and ldb serial clocks select. The table below provides its field descriptions.

Address: 20C\_4000h base + 2Ch offset = 20C\_402Ch

| Bit   | 31 | 30              | 29 | 28 | 27              | 26            | 25 | 24            | 23 | 22            | 21            | 20 | 19           | 18 | 17 | 16 |
|-------|----|-----------------|----|----|-----------------|---------------|----|---------------|----|---------------|---------------|----|--------------|----|----|----|
| R     | 0  |                 |    |    |                 | enfc_clk_podf |    |               |    | enfc_clk_pred |               |    | enfc_clk_sel |    |    |    |
| W     |    |                 |    |    |                 |               |    |               |    |               |               |    |              |    |    |    |
| Reset | 0  | 0               | 0  | 0  | 0               | 0             | 0  | 0             | 0  | 0             | 0             | 0  | 0            | 1  | 1  | 1  |
| Bit   | 15 | 14              | 13 | 12 | 11              | 10            | 9  | 8             | 7  | 6             | 5             | 4  | 3            | 2  | 1  | 0  |
| R     | 0  | ldb_di1_clk_sel |    |    | ldb_di0_clk_sel |               |    | ssi2_clk_pred |    |               | ssi2_clk_podf |    |              |    |    |    |
| W     |    |                 |    |    |                 |               |    |               |    |               |               |    |              |    |    |    |
| Reset | 0  | 0               | 1  | 1  | 0               | 1             | 1  | 0             | 1  | 1             | 0             | 0  | 0            | 0  | 0  | 1  |

**CCM\_CS2CDR field descriptions**

| Field                  | Description                                                                                                                                                                                                                                                                |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–27<br>Reserved      | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                               |
| 26–21<br>enfc_clk_podf | Divider for enfc clock divider.<br><br>000000 divide by 1<br>000001 divide by 2<br>111111 divide by $2^6$                                                                                                                                                                  |
| 20–18<br>enfc_clk_pred | Divider for enfc clock pred divider.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 17–16<br>enfc_clk_sel  | Selector for enfc clock multiplexer<br><br><b>NOTE:</b> Multiplexor should be updated when output clock is gated.<br><br>00 pll2 352M PFD<br>01 pll2 clock                                                                                                                 |

*Table continues on the next page...*

**CCM\_CS2CDR field descriptions (continued)**

| Field                    | Description                                                                                                                                                                                                                                                                                |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | 10    pll3_sw_clk<br>11    pll2 396M PFD                                                                                                                                                                                                                                                   |
| 15<br>Reserved           | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                               |
| 14–12<br>ldb_di1_clk_sel | Selector for ldb_di1 clock multiplexer<br><br><b>NOTE:</b> Multiplexor should be updated when both input and output clocks are gated.<br><br>000    pll5 clock<br>001    pll2 352M PFD<br>010    pll2 396M PFD<br>011    MMDC_CH1 clock<br>100    pll3_sw_clk<br>101-111    Reserved       |
| 11–9<br>ldb_di0_clk_sel  | Selector for ldb_di1 clock multiplexer<br><br><b>NOTE:</b> Multiplexor should be updated when both input and output clocks are gated.<br><br>000    pll5 clock<br>001    pll2 352M PFD<br>010    pll2 396M PFD<br>011    MMDC_CH1 clock<br>100    pll3_sw_clk<br>101-111    Reserved       |
| 8–6<br>ssi2_clk_pred     | Divider for ssi2 clock pred.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000    divide by 1<br>001    divide by 2<br>010    divide by 3<br>011    divide by 4<br>100    divide by 5<br>101    divide by 6<br>110    divide by 7<br>111    divide by 8 |
| ssi2_clk_podf            | Divider for ssi2 clock podf.<br>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000000    divide by 1<br>111111    divide by 2^6                 |

### 18.6.13 CCM D1 Clock Divider Register (CCM\_CDCDR)

The figure below represents the CCM DI Clock Divider Register (CDCDR). The table below provides its field descriptions.

Address: 20C\_4000h base + 30h offset = 20C\_4030h

| Bit   | 31          | 30              | 29 | 28 | 27             | 26              | 25 | 24 | 23 | 22              | 21       | 20 | 19 | 18             | 17       | 16 |  |  |
|-------|-------------|-----------------|----|----|----------------|-----------------|----|----|----|-----------------|----------|----|----|----------------|----------|----|--|--|
| R     | hsi_tx_podf |                 |    |    | hsi_tx_clk_sel | spdif0_clk_pred |    |    |    | spdif0_clk_podf |          |    |    | spdif0_clk_sel | Reserved |    |  |  |
| W     |             |                 |    |    |                |                 |    |    |    |                 |          |    |    |                |          |    |  |  |
| Reset | 0           | 0               | 1  | 1  | 0              | 0               | 1  | 1  | 1  | 1               | 1        | 1  | 0  | 1              | 1        | 1  |  |  |
| Bit   | 15          | 14              | 13 | 12 | 11             | 10              | 9  | 8  | 7  | 6               | 5        | 4  | 3  | 2              | 1        | 0  |  |  |
| R     | 0           | spdif1_clk_pred |    |    |                | spdif1_clk_podf |    |    |    | spdif1_clk_sel  | Reserved |    |    |                |          |    |  |  |
| W     | 0           | 0               | 0  | 1  | 1              | 1               | 1  | 1  | 1  | 0               | 0        | 1  | 0  | 0              | 1        | 0  |  |  |
| Reset | 0           | 0               | 0  | 1  | 1              | 1               | 1  | 1  | 1  | 0               | 0        | 1  | 0  | 0              | 1        | 0  |  |  |

**CCM\_CDCDR field descriptions**

| Field                    | Description                                                                                                                                                                                                                                                                        |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–29<br>hsi_tx_podf     | <p>Divider for hsi_tx clock podf.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1<br/>001 divide by 2<br/>010 divide by 3<br/>011 divide by 4<br/>100 divide by 5<br/>101 divide by 6<br/>110 divide by 7<br/>111 divide by 8</p> |
| 28<br>hsi_tx_clk_sel     | <p>Selector for hsi_tx clock multiplexer</p> <p>0 derive from pll3 120M clock<br/>1 derive from pll2 396M PFD</p>                                                                                                                                                                  |
| 27–25<br>spdif0_clk_pred | <p>Divider for spdif0 clock pred.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1 (do not use with high input frequencies)<br/>001 divide by 2</p>                                                                                |

*Table continues on the next page...*

**CCM\_CDCDR field descriptions (continued)**

| Field                    | Description                                                                                                                                                                                                                                                                                                   |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | <p>010 divide by 3<br/>111 divide by 8</p>                                                                                                                                                                                                                                                                    |
| 24–22<br>spdif0_clk_podf | <p>Divider for spdif0 clock podf.<br/><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1<br/>111 divide by 8</p>                                                                                                                                                       |
| 21–20<br>spdif0_clk_sel  | <p>Selector for spdif0 clock multiplexer</p> <p>00 derive clock from pll4 divided clock<br/>01 derive clock from 508M PFD clock<br/>10 derive clock from 454M PFD clock<br/>11 derive clock from pll3_sw_clk</p>                                                                                              |
| 19–16<br>-               | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                           |
| 15<br>Reserved           | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                  |
| 14–12<br>spdif1_clk_pred | <p>Divider for spdif1 clock pred.<br/><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p><b>NOTE:</b> Used for ASRC clock, not related to SPDIF module</p> <p>000 divide by 1 (do not use with high input frequencies)<br/>001 divide by 2<br/>010 divide by 3<br/>111 divide by 8</p> |
| 11–9<br>spdif1_clk_podf  | <p>Divider for spdif1 clock podf.<br/><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p><b>NOTE:</b> Used for ASRC clock, not related to SPDIF module</p> <p>000 divide by 1<br/>111 divide by 8</p>                                                                                  |
| 8–7<br>spdif1_clk_sel    | <p>Selector for spdif1 clock multiplexer<br/><b>NOTE:</b> Used for ASRC clock, not related to SPDIF module</p> <p>00 derive clock from pll4 divided clock<br/>01 derive clock from 508M PFD clock<br/>10 derive clock from 454M PFD clock<br/>11 derive clock from pll3_sw_clk</p>                            |
| -                        | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                           |

## 18.6.14 CCM HSC Clock Divider Register (CCM\_CHSCCDR)

The figure below represents the CCM HSC Clock Divider Register (CHSCCDR). The CHSCCDR register contains bits to control the ipu di clock generation dividers. The table below provides its field descriptions.

Address: 20C\_4000h base + 34h offset = 20C\_4034h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   | 15            | 14               | 13                   | 12            | 11               | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|---------------|------------------|----------------------|---------------|------------------|----|---|---|---|---|---|---|---|---|---|---|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ipu1_di1_pre_clk_sel | ipu1_di1_podf | ipu1_di1_clk_sel | ipu1_di0_pre_clk_sel | ipu1_di0_podf | ipu1_di0_clk_sel |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |               |                  |                      |               |                  |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0                    | 1             | 0                | 1                    | 0             | 0                | 0  | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |   |

### CCM\_CHSCCDR field descriptions

| Field                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–18<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17–15<br>ipu1_di1_pre_clk_sel | Selector for ipu1 di1 root clock pre-multiplexer<br><br><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.<br><br>000 derive clock from mmddc_ch0 clock<br>001 derive clock from pll3_sw_clk<br>010 derive clock from pll5<br>011 derive clock from 352M PFD<br>100 derive clock from 396M PFD<br>101 derive clock from 540M PFD<br>110-111 Reserved |
| 14–12<br>ipu1_di1_podf        | Divider for ipu1_di clock divider.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                                                                                     |
| 11–9<br>ipu1_di1_clk_sel      | Selector for ipu1 di1 root clock multiplexer<br><br><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.                                                                                                                                                                                                                                               |

Table continues on the next page...

## CCM\_CHSCCDR field descriptions (continued)

| Field                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | <p>000 derive clock from divided pre-muxed ipu1 di1 clock<br/>     001 derive clock from ipp_di0_clk<br/>     010 derive clock from ipp_di1_clk<br/>     011 derive clock from ldb_di0_clk<br/>     100 derive clock from ldb_di1_clk<br/>     101-111 Reserved</p>                                                                                                                                                                                                                                                     |
| 8–6<br>ipu1_di0_pre_clk_sel | <p>Selector for ipu1 di0 root clock pre-multiplexer</p> <p><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.</p> <p>000 derive clock from mmddc_ch0 clock<br/>     001 derive clock from pll3_sw_clk<br/>     010 derive clock from pll5<br/>     011 derive clock from 352M PFD<br/>     100 derive clock from 396M PFD<br/>     101 derive clock from 540M PFD<br/>     110-111 Reserved</p> |
| 5–3<br>ipu1_di0_podf        | <p>Divider for ipu1_di0 clock divider.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <p>000 divide by 1<br/>     001 divide by 2<br/>     010 divide by 3<br/>     011 divide by 4<br/>     100 divide by 5<br/>     101 divide by 6<br/>     110 divide by 7<br/>     111 divide by 8</p>                                                                                                                                                                                              |
| ipu1_di0_clk_sel            | <p>Selector for ipu1 di0 root clock multiplexer</p> <p><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.</p> <p>000 derive clock from divided pre-muxed ipu1 di0 clock<br/>     001 derive clock from ipp_di0_clk<br/>     010 derive clock from ipp_di1_clk<br/>     011 derive clock from ldb_di0_clk<br/>     100 derive clock from ldb_di1_clk<br/>     101-111 Reserved</p>               |

### 18.6.15 CCM Serial Clock Divider Register 2 (CCM\_CSCDR2)

The figure below represents the CCM Serial Clock Divider Register 2(CSCDR2). The CSCDR2 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

Address: 20C\_4000h base + 38h offset = 20C\_4038h



**CCM\_CSCDR2 field descriptions**

| Field                   | Description                                                                                                                                                                                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>Reserved          | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                               |
| 30–25<br>-              | This field is reserved.<br>Reserved                                                                                                                                                                                                                                        |
| 24–19<br>ecspi_clk_podf | Divider for ecspi clock podf.<br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><b>NOTE:</b> The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.<br>000000 divide by 1<br>111111 divide by 2^6 |

Table continues on the next page...

**CCM\_CSCDR2 field descriptions (continued)**

| Field                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18<br>-                           | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17–15<br>ipu2_di1_pre_<br>clk_sel | Selector for ipu2 di1 root clock pre-multiplexer<br><br><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.<br><br>000 derive clock from mmdc_ch0 clock<br>001 derive clock from pll3_sw_clk<br>010 derive clock from pll5<br>011 derive clock from 352M PFD<br>100 derive clock from 396M PFD<br>101 derive clock from 540M PFD<br>110-111 Reserved |
| 14–12<br>ipu2_di1_podf            | Divider for ipu2_di1 clock divider.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                                                                                   |
| 11–9<br>ipu2_di1_clk_sel          | Selector for ipu1 di2 root clock multiplexer<br><br><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.<br><br>000 derive clock from divided pre-muxed ipu1 di1 clock<br>001 derive clock from ipp_di0_clk<br>010 derive clock from ipp_di1_clk<br>011 derive clock from ldb_di0_clk<br>100 derive clock from ldb_di1_clk<br>101-111 Reserved        |
| 8–6<br>ipu2_di0_pre_<br>clk_sel   | Selector for ipu2 di0 root clock pre-multiplexer<br><br><b>NOTE:</b> Multiplexor should only be updated when the output clock is gated. Please refer to <a href="#">System Clocks</a> for the respective output clock gating bits.<br><br>000 derive clock from mmdc_ch0 clock<br>001 derive clock from pll3_sw_clk<br>010 derive clock from pll5<br>011 derive clock from 352M PFD<br>100 derive clock from 396M PFD                                                       |

*Table continues on the next page...*

## CCM\_CSCDR2 field descriptions (continued)

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | 101 derive clock from 540M PFD<br>110-111 Reserved                                                                                                                                                                                                                                                                                                                          |
| 5-3<br>ipu2_di0_podf | Divider for ipu2_di0 clock divider.<br><br><b>NOTE:</b> Divider should be updated when output clock is gated.<br><br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                   |
| ipu2_di0_clk_sel     | Selector for ipu2 di0 root clock multiplexer<br><br><b>NOTE:</b> Multiplexor should be updated only when the output clock is gated.<br><br>000 derive clock from divided pre-muxed ipu1 di0 clock<br>001 derive clock from ippp_di0_clk<br>010 derive clock from ippp_di1_clk<br>011 derive clock from ldb_di0_clk<br>100 derive clock from ldb_di1_clk<br>101-111 Reserved |

## 18.6.16 CCM Serial Clock Divider Register 3 (CCM\_CSCDR3)

The figure below represents the CCM Serial Clock Divider Register 3(CSCDR3). The CSCDR3 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

Address: 20C\_4000h base + 3Ch offset = 20C\_403Ch

|       |                  |    |               |    |                  |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|---------------|----|------------------|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29            | 28 | 27               | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R     |                  |    |               |    |                  |    | 0  |    |    |    |    |    |    |    |    |    |
| W     |                  |    |               |    |                  |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0             | 0  | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |
| Bit   | 15               | 14 | 13            | 12 | 11               | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | ipu2_hsp_clk_sel |    | ipu1_hsp_podf |    | ipu1_hsp_clk_sel |    |    |    |    |    |    |    |    |    |    |    |
| W     |                  |    |               |    |                  |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0             | 0  | 1                | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  |

**CCM\_CSCDR3 field descriptions**

| Field                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------|-----|----------------------------|-----|------------------------|-----|----------------------------|-----|-------------|-----|-------------|-----|-------------|-----|-------------|
| 31–19<br>Reserved         | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                  |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 18–16<br>ipu2_hsp_podf    | <p>Divider for ipu2_hsp clock.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <table> <tr><td>000</td><td>divide by 1</td></tr> <tr><td>001</td><td>divide by 2</td></tr> <tr><td>010</td><td>divide by 3</td></tr> <tr><td>011</td><td>divide by 4</td></tr> <tr><td>100</td><td>divide by 5</td></tr> <tr><td>101</td><td>divide by 6</td></tr> <tr><td>110</td><td>divide by 7</td></tr> <tr><td>111</td><td>divide by 8</td></tr> </table> | 000 | divide by 1                       | 001 | divide by 2                | 010 | divide by 3            | 011 | divide by 4                | 100 | divide by 5 | 101 | divide by 6 | 110 | divide by 7 | 111 | divide by 8 |
| 000                       | divide by 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 001                       | divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 010                       | divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 011                       | divide by 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 100                       | divide by 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 101                       | divide by 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 110                       | divide by 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 111                       | divide by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 15–14<br>ipu2_hsp_clk_sel | <p>Selector for ipu2_hsp clock multiplexer</p> <table> <tr><td>00</td><td>derive clock from mmddc_ch0 clock</td></tr> <tr><td>01</td><td>derive clock from 396M PFD</td></tr> <tr><td>10</td><td>derive clock from 120M</td></tr> <tr><td>11</td><td>derive clock from 540M PFD</td></tr> </table>                                                                                                                                                                            | 00  | derive clock from mmddc_ch0 clock | 01  | derive clock from 396M PFD | 10  | derive clock from 120M | 11  | derive clock from 540M PFD |     |             |     |             |     |             |     |             |
| 00                        | derive clock from mmddc_ch0 clock                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 01                        | derive clock from 396M PFD                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 10                        | derive clock from 120M                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 11                        | derive clock from 540M PFD                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 13–11<br>ipu1_hsp_podf    | <p>Divider for ipu1_hsp clock.</p> <p><b>NOTE:</b> Divider should be updated when output clock is gated.</p> <table> <tr><td>000</td><td>divide by 1</td></tr> <tr><td>001</td><td>divide by 2</td></tr> <tr><td>010</td><td>divide by 3</td></tr> <tr><td>011</td><td>divide by 4</td></tr> <tr><td>100</td><td>divide by 5</td></tr> <tr><td>101</td><td>divide by 6</td></tr> <tr><td>110</td><td>divide by 7</td></tr> <tr><td>111</td><td>divide by 8</td></tr> </table> | 000 | divide by 1                       | 001 | divide by 2                | 010 | divide by 3            | 011 | divide by 4                | 100 | divide by 5 | 101 | divide by 6 | 110 | divide by 7 | 111 | divide by 8 |
| 000                       | divide by 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 001                       | divide by 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 010                       | divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 011                       | divide by 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 100                       | divide by 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 101                       | divide by 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 110                       | divide by 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 111                       | divide by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 10–9<br>ipu1_hsp_clk_sel  | <p>Selector for ipu1_hsp clock multiplexer</p> <table> <tr><td>00</td><td>derive clock from mmddc_ch0 clock</td></tr> <tr><td>01</td><td>derive clock from 396M PFD</td></tr> <tr><td>10</td><td>derive clock from 120M</td></tr> <tr><td>11</td><td>derive clock from 540M PFD</td></tr> </table>                                                                                                                                                                            | 00  | derive clock from mmddc_ch0 clock | 01  | derive clock from 396M PFD | 10  | derive clock from 120M | 11  | derive clock from 540M PFD |     |             |     |             |     |             |     |             |
| 00                        | derive clock from mmddc_ch0 clock                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 01                        | derive clock from 396M PFD                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 10                        | derive clock from 120M                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| 11                        | derive clock from 540M PFD                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |
| -                         | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |                                   |     |                            |     |                        |     |                            |     |             |     |             |     |             |     |             |

### 18.6.17 CCM Divider Handshake In-Process Register (CCM\_CDHIPR)

The figure below represents the CCM Divider Handshake In-Process Register (CDHIPR). The CDHIPR register contains read-only bits that indicate that CCM is in the process of updating dividers or muxes that might need handshake with modules.

Address: 20C\_4000h base + 48h offset = 20C\_4048h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| R     |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |               |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | arm_podf_busy |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                   | 4                  | 3                    | 2                  | 1             | 0             |
|-------|----|----|----|----|----|----|---|---|---|---|---------------------|--------------------|----------------------|--------------------|---------------|---------------|
| R     |    |    |    |    |    |    |   | 0 |   |   | periph_clk_sel_busy | mmdc_ch0_podf_busy | periph2_clk_sel_busy | mmdc_ch1_podf_busy | ahb_podf_busy | axi_podf_busy |
| W     |    |    |    |    |    |    |   |   |   |   |                     |                    |                      |                    |               |               |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0                   | 0                  | 0                    | 0                  | 0             | 0             |

**CCM\_CDHIPR field descriptions**

| Field                    | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–17<br>Reserved        | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                  |
| 16<br>arm_podf_busy      | Busy indicator for arm_podf.<br>0 divider is not busy and its value represents the actual division.<br>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the arm_podf will be applied.                   |
| 15–6<br>Reserved         | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                  |
| 5<br>periph_clk_sel_busy | Busy indicator for periph_clk_sel mux control.<br>0 mux is not busy and its value represents the actual division.<br>1 mux is busy with handshake process with module. The value read in the periph_clk_sel represents the previous value of select, and after the handshake periph_clk_sel value will be applied.                            |
| 4<br>mmdc_ch0_podf_busy  | Busy indicator for mmdc_ch0_axi_podf.<br>0 divider is not busy and its value represents the actual division.<br>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the mmdc_ch0_axi_podf will be applied. |

Table continues on the next page...

**CCM\_CDHIPR field descriptions (continued)**

| Field                  | Description                                                                                                                                                                                                                                                                                                                                   |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 periph2_clk_sel_busy | Busy indicator for periph2_clk_sel mux control.<br>0 mux is not busy and its value represents the actual division.<br>1 mux is busy with handshake process with module. The value read in the periph2_clk_sel represents the previous value of select, and after the handshake periph2_clk_sel value will be applied.                         |
| 2 mmdc_ch1_podf_busy   | Busy indicator for mmdc_ch1_axi_podf.<br>0 divider is not busy and its value represents the actual division.<br>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the mmdc_ch1_axi_podf will be applied. |
| 1 ahb_podf_busy        | Busy indicator for ahb_podf.<br>0 divider is not busy and its value represents the actual division.<br>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the ahb_podf will be applied.                   |
| 0 axi_podf_busy        | Busy indicator for axi_podf.<br>0 divider is not busy and its value represents the actual division.<br>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the axi_podf will be applied.                   |

### 18.6.18 CCM Low Power Control Register (CCM\_CLPCR)

The figure below represents the CCM Low Power Control Register (CLPCR). The CLPCR register contains bits to control the low power modes operation. The table below provides its field descriptions.

Address: 20C\_4000h base + 54h offset = 20C\_4054h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26             | 25            | 24             | 23             | 22             | 21                  | 20                   | 19       | 18       | 17       | 16             |
|-------|----|----|----|----|----|----------------|---------------|----------------|----------------|----------------|---------------------|----------------------|----------|----------|----------|----------------|
| R     |    |    |    |    | 0  | mask_l2cc_idle | mask_scu_idle | mask_core3_wfi | mask_core2_wfi | mask_core1_wfi | mask_core0_wfi      | bypass_mmdc_ch1_lpms | 0        | 0        | 0        | wb_per_at_lpms |
| W     |    |    |    |    | 0  | 0              | 0             | 0              | 0              | 0              | 0                   | 0                    | 0        | 0        | Reserved |                |
| Reset | 0  | 0  | 0  | 0  | 0  | 0              | 0             | 0              | 0              | 0              | 0                   | 0                    | 0        | 0        | 0        | 0              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10             | 9             | 8              | 7              | 6              | 5                   | 4                    | 3        | 2        | 1        | 0              |
| R     |    |    |    |    | 0  | cosc_pwrdown   | stby_count    | VSTBY          | dis_ref_osc    | SBYOS          | ARM_clk_dis_on_lpms | Reserved             | Reserved | Reserved | LPM      |                |
| W     |    |    |    |    | 0  | 0              | 0             | 0              | 0              | 1              | 1                   | 1                    | 1        | 0        | 0        | 1              |
| Reset | 0  | 0  | 0  | 0  | 0  | 0              | 0             | 0              | 0              | 1              | 1                   | 1                    | 1        | 0        | 0        | 1              |

**CCM\_CLPCR field descriptions**

| Field                | Description                                                                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved    | This read-only field is reserved and always has the value 0.                                                                                                                        |
| 27<br>mask_l2cc_idle | Mask L2CC IDLE for entering low power mode.<br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br>1 L2CC IDLE is masked<br>0 L2CC IDLE is not masked |
| 26<br>mask_scu_idle  | Mask SCU IDLE for entering low power mode<br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br>1 SCU IDLE is masked<br>0 SCU IDLE is not masked     |

*Table continues on the next page...*

## CCM\_CLPCR field descriptions (continued)

| Field                        | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>mask_core3_wfi         | Mask WFI of core3 for entering low power mode<br><br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br><br>1 WFI of core3 is masked<br>0 WFI of core3 is not masked                                                                                                                                                                                         |
| 24<br>mask_core2_wfi         | Mask WFI of core2 for entering low power mode<br><br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br><br>1 WFI of core2 is masked<br>0 WFI of core2 is not masked                                                                                                                                                                                         |
| 23<br>mask_core1_wfi         | Mask WFI of core1 for entering low power mode<br><br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br><br>1 WFI of core1 is masked<br>0 WFI of core1 is not masked                                                                                                                                                                                         |
| 22<br>mask_core0_wfi         | Mask WFI of core0 for entering low power mode<br><br><b>NOTE:</b> Assertion of all bits[27:22] will generate low power mode request<br><br>0 WFI of core0 is not masked<br>1 WFI of core0 is masked                                                                                                                                                                                         |
| 21<br>bypass_mmdc_ch1_lpm_hs | Bypass handshake with mmdc_ch1 on next entrance to low power mode (STOP or WAIT). CCM doesn't wait for the module's acknowledge.<br><br>0 Handshake with mmdc_ch1 on next entrance to low power mode will be performed.<br>1 Handshake with mmdc_ch1 on next entrance to low power mode will be bypassed.                                                                                   |
| 20<br>Reserved               | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                |
| 19<br>bypass_mmdc_ch0_lpm_hs | Bypass handshake with mmdc_ch0 on next entrance to low power mode (STOP or WAIT). CCM doesn't wait for the module's acknowledge. Handshake will also be bypassed, if CGR3 CG10 is set to gate fast mmdc_ch0 clock.<br><br>0 Handshake with mmdc_ch0 on next entrance to low power mode will be performed.<br>1 Handshake with mmdc_ch0 on next entrance to low power mode will be bypassed. |
| 18<br>Reserved               | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                |
| 17<br>-                      | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                         |
| 16<br>wb_per_at_lpm          | Enable periphery charge pump for well biasing at low power mode (stop or wait)<br><br>0 Periphery charge pump won't be enabled at STOP or WAIT low power modes<br>1 Periphery charge pump will be enabled at STOP or WAIT low power modes                                                                                                                                                   |
| 15–12<br>Reserved            | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                |
| 11<br>cosc_pwrdown           | In run mode, software can manually control powering down of on chip oscillator, i.e. generating '1' on cosc_pwrdown signal. If software manually powered down the on chip oscillator, then sbyos functionality for on chip oscillator will be bypassed.                                                                                                                                     |

*Table continues on the next page...*

## CCM\_CLPCR field descriptions (continued)

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <p>The manual closing of onchip oscillator should be performed only in case the reference oscillator is not the source of all the clocks generation.</p> <p>0 On chip oscillator will not be powered down, i.e. cosc_pwrdown = '0'.<br/>1 On chip oscillator will be powered down, i.e. cosc_pwrdown = '1'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10–9<br>stby_count      | <p>Standby counter definition. These two bits define, in the case of stop exit (if VSTBY bit was set).</p> <p><b>NOTE:</b> Clock cycles ratio depends on pmic_delay_scaler, defined by CGPR[0] bit.</p> <p>00 CCM will wait (1*pmic_delay_scaler)+1 ckil clock cycles<br/>01 CCM will wait (3*pmic_delay_scaler)+1 ckil clock cycles<br/>10 CCM will wait (7*pmic_delay_scaler)+1 ckil clock cycles<br/>11 CCM will wait (15*pmic_delay_scaler)+1 ckil clock cycles</p>                                                                                                                                                                                                                                                                                                                 |
| 8<br>VSTBY              | <p>Voltage standby request bit. This bit defines if PMIC_STBY_REQ pin, which notifies external power management IC to move from functional voltage to standby voltage, will be asserted in STOP mode.</p> <p>0 Voltage will not be changed to standby voltage after next entrance to STOP mode.<br/>( PMIC_STBY_REQ will remain negated - '0' )<br/>1 Voltage will be requested to change to standby voltage after next entrance to stop mode.<br/>( PMIC_STBY_REQ will be asserted - '1' ).</p>                                                                                                                                                                                                                                                                                        |
| 7<br>dis_ref_osc        | <p>dis_ref_osc - in run mode, software can manually control closing of external reference oscillator clock, i.e. generating '1' on CCM_REF_EN_B signal. If software closed manually the external reference clock, then sbyos functionality will be bypassed.</p> <p>The manual closing of external reference oscillator should be performed only in case the reference oscillator is not the source of any clock generation.</p> <p><b>NOTE:</b> When returning from stop mode, the PMIC_STBY_REQ will be deasserted (if it was asserted when entering stop mode). See stby_count bits.</p> <p>0 external high frequency oscillator will be enabled, i.e. CCM_REF_EN_B = '0'.<br/>1 external high frequency oscillator will be disabled, i.e. CCM_REF_EN_B = '1'</p>                    |
| 6<br>SBYOS              | <p>Standby clock oscillator bit. This bit defines if cosc_pwrdown, which power down the on chip oscillator, will be asserted in STOP mode. This bit is discarded if cosc_pwrdown='1' for the on chip oscillator.</p> <p>0 On-chip oscillator will not be powered down, after next entrance to STOP mode. (CCM_REF_EN_B will remain asserted - '0' and cosc_pwrdown will remain de asserted - '0')<br/>1 On-chip oscillator will be powered down, after next entrance to STOP mode. (CCM_REF_EN_B will be deasserted - '1' and cosc_pwrdown will be asserted - '1'). When returning from STOP mode, external oscillator will be enabled again, on-chip oscillator will return to oscillator mode, and after oscnt count, CCM will continue with the exit from the STOP mode process.</p> |
| 5<br>ARM_clk_dis_on_lpm | <p>Define if ARM clocks (arm_clk, soc_mxclk, soc_pclk, soc_dbg_pclk, vl_wrck) will be disabled on wait mode. This is useful for debug mode, when the user still wants to simulate entering wait mode and still keep ARM clock functioning.</p> <p><b>NOTE:</b> Software should not enable ARM power gating in wait mode if this bit is cleared.</p> <p>0 ARM clock enabled on wait mode.<br/>1 ARM clock disabled on wait mode. .</p>                                                                                                                                                                                                                                                                                                                                                   |
| 4–3<br>-                | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2<br>-                  | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table continues on the next page...

**CCM\_CLPCR field descriptions (continued)**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPM   | <p>Setting the low power mode that system will enter on next assertion of dsm_request signal.</p> <p><b>NOTE:</b> Set CCM_CGPR[INT_MEM_CLK_LPM] and CCM_CGPR[1] bits to 1 when setting CCM_CLPCR[LPM] bits to 01 (WAIT Mode) or 10 (STOP mode) without power gating. CCM_CGPR[INT_MEM_CLK_LPM] and CCM_CGPR[1] bits do not have to be set for STOP mode entry.</p> <ul style="list-style-type: none"> <li>00 Remain in run mode</li> <li>01 Transfer to wait mode</li> <li>10 Transfer to stop mode</li> <li>11 Reserved</li> </ul> |

**18.6.19 CCM Interrupt Status Register (CCM\_CISR)**

The figure below represents the CCM Interrupt Status Register (CISR). This is a write one to clear register. Once a interrupt is generated, software should write one to clear it. The table below provides its field descriptions.

**NOTE**

CCM interrupt request 1 can be masked by CCM interrupt request 1 mask bit. CCM interrupt request 2 can be masked by CCM interrupt request 2 mask bit.

Address: 20C\_4000h base + 58h offset = 20C\_4058h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26              | 25 | 24  | 23                   | 22                    | 21                   | 20              | 19                     | 18  | 17              | 16 |
|-------|----|----|----|----|----|-----------------|----|-----|----------------------|-----------------------|----------------------|-----------------|------------------------|-----|-----------------|----|
| R     | 0  |    |    |    |    | arm_podf_loaded | 0  |     | mmdc_ch0_podf_loaded | periph_clk_sel_loaded | mmdc_ch1_podf_loaded | arb_podf_loaded | periph2_clk_sel_loaded | 0   | axi_podf_loaded | 0  |
| W     |    |    |    |    |    | w1c             |    | w1c | w1c                  | w1c                   | w1c                  | w1c             | w1c                    | w1c | w1c             |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0               | 0  | 0   | 0                    | 0                     | 0                    | 0               | 0                      | 0   | 0               | 0  |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|----|----|----|----|----|----|---|---|---|------------|---|---|---|---|---|---------|
| R     |    |    |    |    |    |    |   |   |   | cosc_ready |   |   |   |   |   | lrf_pll |
|       |    |    |    |    |    |    |   |   |   |            |   |   |   |   |   |         |
| W     |    |    |    |    |    |    |   |   |   | w1c        |   |   |   |   |   | w1c     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0          | 0 | 0 | 0 | 0 | 0 | 0       |

**CCM\_CISR field descriptions**

| Field                        | Description                                                                                                                                                                                                                                                                                     |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–27<br>Reserved            | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                    |
| 26<br>arm_podf_loaded        | CCM interrupt request 1 generated due to frequency change of arm_podf. The interrupt will commence only if arm_podf is loaded during a arm dvfs operation.<br><br>0 interrupt is not generated due to frequency change of arm_podf<br>1 interrupt generated due to frequency change of arm_podf |
| 25–24<br>Reserved            | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                    |
| 23<br>mmdc_ch0_podf_loaded   | CCM interrupt request 1 generated due to update of mmdc_ch0_axi_podf.<br><br>0 interrupt is not generated due to update of mmdc_ch0_axi_podf.<br>1 interrupt generated due to update of mmdc_ch0_axi_podf*                                                                                      |
| 22<br>periph_clk_sel_loaded  | CCM interrupt request 1 generated due to update of periph_clk_sel.<br><br>0 interrupt is not generated due to update of periph_clk_sel.<br>1 interrupt generated due to update of periph_clk_sel.                                                                                               |
| 21<br>mmdc_ch1_podf_loaded   | CCM interrupt request 1 generated due to frequency change of mmdc_ch1_podf_loaded<br><br>0 interrupt is not generated due to frequency change of mmdc_ch1_podf_loaded<br>1 interrupt generated due to frequency change of mmdc_ch1_podf_loaded                                                  |
| 20<br>ahb_podf_loaded        | CCM interrupt request 1 generated due to frequency change of ahb_podf<br><br>0 interrupt is not generated due to frequency change of ahb_podf<br>1 interrupt generated due to frequency change of ahb_podf                                                                                      |
| 19<br>periph2_clk_sel_loaded | CCM interrupt request 1 generated due to frequency change of periph2_clk_sel                                                                                                                                                                                                                    |

Table continues on the next page...

**CCM\_CISR field descriptions (continued)**

| Field              | Description                                                                                                                                                                                                                                               |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 0 interrupt is not generated due to frequency change of periph2_clk_sel<br>1 interrupt generated due to frequency change of periph2_clk_sel                                                                                                               |
| 18 Reserved        | This read-only field is reserved and always has the value 0.<br>0 interrupt is not generated due to frequency change of mmdc_ch0_axi_podf<br>1 interrupt generated due to frequency change of mmdc_ch0_axi_podf                                           |
| 17 axi_podf_loaded | CCM interrupt request 1 generated due to frequency change of axi_podf<br>0 interrupt is not generated due to frequency change of axi_podf<br>1 interrupt generated due to frequency change of axi_podf                                                    |
| 16–7 Reserved      | This read-only field is reserved and always has the value 0.                                                                                                                                                                                              |
| 6 cosc_ready       | CCM interrupt request 2 generated due to on board oscillator ready, i.e. oscnt has finished counting.<br>0 interrupt is not generated due to on board oscillator ready<br>1 interrupt generated due to on board oscillator ready                          |
| 5–1 Reserved       | This read-only field is reserved and always has the value 0.                                                                                                                                                                                              |
| 0 lrf_pll          | CCM interrupt request 2 generated due to lock of all enabled and not bypassed PLLs<br>0 interrupt is not generated due to lock ready of all enabled and not bypassed PLLs<br>1 interrupt generated due to lock ready of all enabled and not bypassed PLLs |

### 18.6.20 CCM Interrupt Mask Register (CCM\_CIMR)

The figure below represents the CCM Interrupt Mask Register (CIMR). The table below provides its field descriptions.

Address: 20C\_4000h base + 5Ch offset = 20C\_405Ch

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

Field Descriptions:

- Bit 26: arm\_podf\_loaded (R/W)
- Bit 24: mask\_mmdc\_ch0\_podf\_loaded (R/W)
- Bit 22: mask\_periph\_clk\_sel\_loaded (R/W)
- Bit 20: mask\_mmdc\_ch1\_podf\_loaded (R/W)
- Bit 19: mask\_ahb\_podf\_loaded (R/W)
- Bit 18: mask\_periph2\_clk\_sel\_loaded (R/W)
- Bit 17: mask\_mmdc\_ch0\_axi\_podf\_loaded (R/W)
- Bit 16: mask\_axi\_podf\_loaded (R/W)

**CCM\_CIMR field descriptions**

| Field                            | Description                                                                                                                                                                                                     |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–27<br>Reserved                | This read-only field is reserved and always has the value 1.                                                                                                                                                    |
| 26<br>arm_podf_loaded            | mask interrupt generation due to frequency change of arm_podf<br>0 don't mask interrupt due to frequency change of arm_podf - interrupt will be created<br>1 mask interrupt due to frequency change of arm_podf |
| 25–24<br>Reserved                | This read-only field is reserved and always has the value 1.                                                                                                                                                    |
| 23<br>mask_mmdc_ch0_podf_loaded  | mask interrupt generation due to update of mask_mmdc_ch0_podf<br>0 don't mask interrupt due to update of mask_mmdc_ch0_podf - interrupt will be created<br>1 mask interrupt due to update of mask_mmdc_ch0_podf |
| 22<br>mask_periph_clk_sel_loaded | mask interrupt generation due to update of periph_clk_sel.<br>0 don't mask interrupt due to update of periph_clk_sel - interrupt will be created<br>1 mask interrupt due to update of periph_clk_sel            |
| 21<br>mask_mmdc_ch1_podf_loaded  | mask interrupt generation due to update of mask_mmdc_ch1_podf<br>0 don't mask interrupt due to update of mask_mmdc_ch1_podf - interrupt will be created<br>1 mask interrupt due to update of mask_mmdc_ch1_podf |

*Table continues on the next page...*

**CCM\_CIMR field descriptions (continued)**

| Field                               | Description                                                                                                                                                                                                                                |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20<br>mask_ahb_podf_loaded          | mask interrupt generation due to frequency change of ahb_podf<br>0 don't mask interrupt due to frequency change of ahb_podf - interrupt will be created<br>1 mask interrupt due to frequency change of ahb_podf                            |
| 19<br>mask_periph2_clk_sel_loaded   | mask interrupt generation due to update of periph2_clk_sel.<br>0 don't mask interrupt due to update of periph2_clk_sel - interrupt will be created<br>1 mask interrupt due to update of periph2_clk_sel                                    |
| 18<br>mask_mmdc_ch0_axi_podf_loaded | mask interrupt generation due to frequency change of mmdc_ch0_axi_podf<br>0 don't mask interrupt due to frequency change of mmdc_ch0_axi_podf - interrupt will be created<br>1 mask interrupt due to frequency change of mmdc_ch0_axi_podf |
| 17<br>mask_axi_podf_loaded          | mask interrupt generation due to frequency change of axi_podf<br>0 don't mask interrupt due to frequency change of axi_podf - interrupt will be created<br>1 mask interrupt due to frequency change of axi_podf                            |
| 16–7<br>Reserved                    | This read-only field is reserved and always has the value 1.                                                                                                                                                                               |
| 6<br>mask_cosc_ready                | mask interrupt generation due to on board oscillator ready<br>0 don't mask interrupt due to on board oscillator ready - interrupt will be created<br>1 mask interrupt due to on board oscillator ready                                     |
| 5–1<br>Reserved                     | This read-only field is reserved and always has the value 1.                                                                                                                                                                               |
| 0<br>mask_lrf_pll                   | mask interrupt generation due to lrf of PLLs<br>0 don't mask interrupt due to lrf of PLLs - interrupt will be created<br>1 mask interrupt due to lrf of PLLs                                                                               |

### 18.6.21 CCM Clock Output Source Register (CCM\_CCOSR)

The figure below represents the CCM Clock Output Source Register (CCOSR). The CCOSR register contains bits to control the clocks that will be generated on the output ipp\_do\_clko1 (CCM\_CLKO1) and ipp\_do\_clko2 (CCM\_CLKO2). The table below provides its field descriptions.

Address: 20C\_4000h base + 60h offset = 20C\_4060h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|--|----|----|----|----|----|----|----|----|
| R     |    |    |    |    |    |    |    | 0  |  |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |  |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |    |    |    |    |    |    | 0  |  |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |  |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

#### CCM\_CCOSR field descriptions

| Field              | Description                                                                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–25<br>Reserved  | This read-only field is reserved and always has the value 0.                                                                                                                             |
| 24<br>CLKO2_EN     | Enable of CCM_CLKO2 clock<br>0 CCM_CLKO2 disabled.<br>1 CCM_CLKO2 enabled.                                                                                                               |
| 23–21<br>CLKO2_DIV | Setting the divider of CCM_CLKO2<br>000 divide by 1<br>001 divide by 2<br>010 divide by 3<br>011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8 |
| 20–16<br>CLKO2_SEL | Selection of the clock to be generated on CCM_CLKO2                                                                                                                                      |

*Table continues on the next page...*

**CCM\_CCOSR field descriptions (continued)**

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 00000 mmdc_ch0_clk_root<br>00001 mmdc_ch1_clk_root<br>00010 usdhc4_clk_root<br>00011 usdhc1_clk_root<br>00100 gpu2d_axi_clk_root<br>00101 wrck_clk_root<br>00110 ecspi_clk_root<br>00111 gpu3d_axi_clk_root<br>01000 usdhc3_clk_root<br>01001 125M_clk_root<br>01010 arm_clk_root<br>01011 ipu1_hsp_clk_root<br>01100 ipu2_hsp_clk_root<br>01101 vdo_axi_clk_root<br>01110 osc_clk<br>01111 gpu2d_core_clk_root<br>10000 gpu3d_core_clk_root<br>10001 usdhc2_clk_root<br>10010 ssi1_clk_root<br>10011 ssi2_clk_root<br>10100 ssi3_clk_root<br>10101 gpu3d_shader_clk_root<br>10110 vpu_axi_clk_root<br>10111 can_clk_root<br>11000 ldb_di0_serial_clk_root<br>11001 ldb_di1_serial_clk_root<br>11010 esai_clk_root<br>11011 aclk_eim_slow_clk_root<br>11100 uart_clk_root<br>11101 spdif0_clk_root<br>11110 spdif1_clk_root<br>11111 hsi_tx_clk_root |
| 15–9<br>Reserved | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8<br>CLK_OUT_SEL | CCM_CLKO1 output to reflect CCM_CLKO1 or CCM_CLKO2 clocks<br>0 CCM_CLKO1 output drives CCM_CLKO1 clock<br>1 CCM_CLKO1 output drives CCM_CLKO2 clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7<br>CLKO1_EN    | Enable of CCM_CLKO1 clock<br>0 CCM_CLKO1 disabled.<br>1 CCM_CLKO1 enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6–4<br>CLKO1_DIV | Setting the divider of CCM_CLKO1<br>000 divide by 1<br>001 divide by 2<br>010 divide by 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

**CCM\_CCOSR field descriptions (continued)**

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 011 divide by 4<br>100 divide by 5<br>101 divide by 6<br>110 divide by 7<br>111 divide by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CLKO1_SEL | Selection of the clock to be generated on CCM_CLKO1<br><br>0000 pll3_sw_clk (this inputs has additional constant division /2)<br>0001 pll2_main_clk (this inputs has additional constant division /2)<br>0010 pll1_main_clk (this inputs has additional constant division /2)<br>0011 pll5_main_clk (this inputs has additional constant division /2)<br>0100 video_27M_clk_root<br>0101 axi_clk_root<br>0110 enfc_clk_root<br>0111 ipu1_di0_clk_root<br>1000 ipu1_di1_clk_root<br>1001 ipu2_di0_clk_root<br>1010 ipu2_di1_clk_root<br>1011 ahb_clk_root<br>1100 ipg_clk_root<br>1101 perclk_root<br>1110 ckil_sync_clk_root<br>1111 pll4_main_clk |

## 18.6.22 CCM General Purpose Register (CCM(CGPR))

Fast PLL enable. Can be used to engage PLL faster after STOP mode, if 24MHz OSC was active

Address: 20C\_4000h base + 64h offset = 20C\_4064h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                     | 19               | 18 | 17                | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|------------------------|------------------|----|-------------------|-----|
| R     |    |    |    |    |    |    |    | 0  |    |    |    |                        |                  |    |                   |     |
| W     |    |    |    |    |    |    |    |    |    |    |    |                        |                  |    | INT_MEM_CLK_LPM   | FPL |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                      | 0                | 0  | 0                 | 0   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                      | 3                | 2  | 1                 | 0   |
| R     |    |    |    | 1  |    |    |    | 0  |    | 1  |    | eruse_prog_supply_gate |                  |    |                   |     |
| W     |    |    |    |    |    |    |    |    |    |    |    | Reserved               | mmdc_ext_clk_dis | 1  | pmic_delay_scaler |     |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 1  | 1  | 0                      | 0                | 0  | 1                 | 0   |

### CCM(CGPR) field descriptions

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–18<br>Reserved     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17<br>INT_MEM_CLK_LPM | Control for the Deep Sleep signal to the ARM Platform memories with additional control logic based on the ARM WFI signal. Used to keep the ARM Platform memory clocks enabled if an interrupt is pending when entering low power mode.<br><br><b>NOTE:</b> This bit should always be set when the CCM_CLPCR_LPM bits are set to 01(WAIT Mode) or 10 (STOP mode) without power gating. This bit does not have to be set for STOP mode entry.<br><br>0 Disable the clock to the ARM platform memories when entering Low Power Mode<br>1 Keep the clocks to the ARM platform memories enabled only if an interrupt is pending when entering Low Power Modes (WAIT and STOP without power gating) |
| 16<br>FPL             | Fast PLL enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Table continues on the next page...

**CCM\_CGPR field descriptions (continued)**

| Field                       | Description                                                                                                                                                                                       |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | 0 Engage PLL enable default way.<br>1 Engage PLL enable 3 CKIL clocks earlier at exiting low power mode (STOP). Should be used only if 24MHz OSC was active in low power mode.                    |
| 15–9<br>Reserved            | This read-only field is reserved and always has the value 1.                                                                                                                                      |
| 8–7<br>Reserved             | This read-only field is reserved and always has the value 0.                                                                                                                                      |
| 6–5<br>Reserved             | This read-only field is reserved and always has the value 1.                                                                                                                                      |
| 4<br>efuse_prog_supply_gate | Defines the value of the output signal cgpr_dout[4]. Gate of program supply for efuse programing<br>0 fuse programing supply voltage is gated off to the efuse module<br>1 allow fuse programing. |
| 3<br>-                      | This field is reserved.<br>Reserved                                                                                                                                                               |
| 2<br>mmdc_ext_clk_dis       | Disable external clock driver of MMDC during STOP mode<br>1 disable during stop mode<br>0 don't disable during stop mode.                                                                         |
| 1<br>-                      | Reserved. Keep default value set to '1' for proper operation.                                                                                                                                     |
| 0<br>pmic_delay_scaler      | Defines clock dividion of clock for stby_count (pmic delay counter)<br>0 clock is not divided<br>1 clock is divided /8                                                                            |

**18.6.23 CCM Clock Gating Register 0 (CCM\_CCGR0)**

CG(i) bits CCGR 0-6

These bits are used to turn on/off the clock to each module independently. The following table details the possible clock activity conditions for each module.

| CGR value | Clock Activity Description                                                |
|-----------|---------------------------------------------------------------------------|
| 00        | Clock is off during all modes. Stop enter hardware handshake is disabled. |
| 01        | Clock is on in run mode, but off in WAIT and STOP modes                   |
| 10        | Not applicable (Reserved).                                                |
| 11        | Clock is on during all modes, except STOP mode.                           |

Module should be stopped, before set its bits to "0"; clocks to the module will be stopped immediately.

The tables above show the register mapings for the different CGRs. The clock connectivity table should be used to match the "CCM output affected" to the actual clocks going into the modules.

The figure below represents the CCM Clock Gating Register 0 (CCM\_CCGR0). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 7 CGR registers. The number of registers required is according to the number of peripherals in the system.

Address: 20C\_4000h base + 68h offset = 20C\_4068h

| Bit    | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|--------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R<br>W | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Bit    | 15   | 14 | 13   | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2  | 1   | 0  |
| R<br>W | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |

### CCM\_CCGR0 field descriptions

| Field         | Description                                        |
|---------------|----------------------------------------------------|
| 31–30<br>CG15 | Reserved                                           |
| 29–28<br>CG14 | dtcp clocks (dtcp_clk_enable)                      |
| 27–26<br>CG13 | dcic2 clocks (dcic2_clk_enable)                    |
| 25–24<br>CG12 | dcic 1 clocks (dcic1_clk_enable)                   |
| 23–22<br>CG11 | CPU debug clocks (arm_dbg_clk_enable)              |
| 21–20<br>CG10 | can2_serial clock (can2_serial_clk_enable)         |
| 19–18<br>CG9  | can2 clock (can2_clk_enable)                       |
| 17–16<br>CG8  | can1_serial clock (can1_serial_clk_enable)         |
| 15–14<br>CG7  | can1 clock (can1_clk_enable)                       |
| 13–12<br>CG6  | caam_wrapper_ipg clock (caam_wrapper_ipg_enable)   |
| 11–10<br>CG5  | caam_wrapper_aclk clock (caam_wrapper_aclk_enable) |
| 9–8<br>CG4    | caam_secure_mem clock (caam_secure_mem_clk_enable) |
| 7–6<br>CG3    | asrc clock (asrc_clk_enable)                       |

Table continues on the next page...

**CCM\_CCGR0 field descriptions (continued)**

| Field      | Description                              |
|------------|------------------------------------------|
| 5–4<br>CG2 | apbhdma_hclk clock (apbhdma_hclk_enable) |
| 3–2<br>CG1 | aips_tz2 clocks (aips_tz2_clk_enable)    |
| CG0        | aips_tz1 clocks (aips_tz1_clk_enable)    |

**18.6.24 CCM Clock Gating Register 1 (CCM\_CCGR1)**

The figure below represents the CCM Clock Gating Register 1(CCM\_CCGR1). The clock gating registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 6Ch offset = 20C\_406Ch

| Bit   | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|-------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R     | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| W     | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Reset | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| R     | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| W     | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Reset | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |

**CCM\_CCGR1 field descriptions**

| Field         | Description                                                                                                                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30<br>CG15 | Reserved                                                                                                                                                                                                   |
| 29–28<br>CG14 | Reserved                                                                                                                                                                                                   |
| 27–26<br>CG13 | gpu3d clock (gpu3d_clk_enable)                                                                                                                                                                             |
| 25–24<br>CG12 | gpu2d clock (gpu2d_clk_enable)<br><b>NOTE:</b> GPU2D clock cannot be gated without gating OPENVG clock as well. Configure both CG bits (CCM_ANALOG_CCGR1[CG12] and CCM_ANALOG_CCGR3[CG15]), to gate GPU2D. |
| 23–22<br>CG11 | gpt serial clock (gpt_serial_clk_enable)                                                                                                                                                                   |
| 21–20<br>CG10 | gpt bus clock (gpt_clk_enable)                                                                                                                                                                             |
| 19–18<br>CG9  | Reserved                                                                                                                                                                                                   |

Table continues on the next page...

**CCM\_CCGR1 field descriptions (continued)**

| Field        | Description                       |
|--------------|-----------------------------------|
| 17–16<br>CG8 | esai clocks (esai_clk_enable)     |
| 15–14<br>CG7 | epit2 clocks (epit2_clk_enable)   |
| 13–12<br>CG6 | epit1 clocks (epit1_clk_enable)   |
| 11–10<br>CG5 | enet clock (enet_clk_enable)      |
| 9–8<br>CG4   | ecspi5 clocks (ecspi5_clk_enable) |
| 7–6<br>CG3   | ecspi4 clocks (ecspi4_clk_enable) |
| 5–4<br>CG2   | ecspi3 clocks (ecspi3_clk_enable) |
| 3–2<br>CG1   | ecspi2 clocks (ecspi2_clk_enable) |
| CG0          | ecspi1 clocks (ecspi1_clk_enable) |

**18.6.25 CCM Clock Gating Register 2 (CCM\_CCGR2)**

The figure below represents the CCM Clock Gating Register 2 (CCM\_CCGR2). The clock gating registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 70h offset = 20C\_4070h

| Bit    | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|--------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R<br>W | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 0    | 0  | 0    | 0  | 1    | 1  | 1   | 1  | 1   | 1  |
| Bit    | 15   | 14 | 13   | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2  | 1   | 0  |
| R<br>W | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 0  |

**CCM\_CCGR2 field descriptions**

| Field         | Description |
|---------------|-------------|
| 31–30<br>CG15 | Reserved    |
| 29–28<br>CG14 | Reserved    |

*Table continues on the next page...*

**CCM\_CCGR2 field descriptions (continued)**

| Field         | Description                                                                    |
|---------------|--------------------------------------------------------------------------------|
| 27–26<br>CG13 | ipsync_vdoa_ipg clocks (ipsync_vdoa_ipg_master_clk_enable)                     |
| 25–24<br>CG12 | ipsync_ip2apb_tzasc2_ipg clocks (ipsync_ip2apb_tzasc2_ipg_master_clk_enable) > |
| 23–22<br>CG11 | ipsync_ip2apb_tzasc1_ipg clocks (ipsync_ip2apb_tzasc1_ipg_master_clk_enable)   |
| 21–20<br>CG10 | ipmux3 clock (ipmux3_clk_enable)                                               |
| 19–18<br>CG9  | ipmux2 clock (ipmux2_clk_enable)                                               |
| 17–16<br>CG8  | ipmux1 clock (ipmux1_clk_enable)                                               |
| 15–14<br>CG7  | iomux_ipt_clk_io clock (iomux_ipt_clk_io_enable)                               |
| 13–12<br>CG6  | OCOTP_CTRL clock (iim_clk_enable)                                              |
| 11–10<br>CG5  | i2c3_serial clock (i2c3_serial_clk_enable)                                     |
| 9–8<br>CG4    | i2c2_serial clock (i2c2_serial_clk_enable)                                     |
| 7–6<br>CG3    | i2c1_serial clock (i2c1_serial_clk_enable)                                     |
| 5–4<br>CG2    | hdmi_tx_isfrclk clock (hdmi_tx_isfrclk_enable)                                 |
| 3–2<br>CG1    | Reserved                                                                       |
| CG0           | hdmi_tx_iahbclk, hdmi_tx_ihclk clock (hdmi_tx_enable)                          |

## 18.6.26 CCM Clock Gating Register 3 (CCM\_CCGR3)

The figure below represents the CCM Clock Gating Register 3 (CCM\_CCGR3). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 74h offset = 20C\_4074h

| Bit    | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|--------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R<br>W | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Bit    | 15   | 14 | 13   | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2  | 1   | 0  |
| R<br>W | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |

### CCM\_CCGR3 field descriptions

| Field         | Description                                                                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30<br>CG15 | openvgaxiclk clock (openvgaxiclk_clk_root_enable)<br><br><b>NOTE:</b> OPENVG clock cannot be gated without gating GPU2D clock as well. Configure both CG bits (CCM_ANALOG_CCGR1[CG12] and CCM_ANALOG_CCGR3[CG15]) to gate OPENVG. |
| 29–28<br>CG14 | ocram clock (ocram_clk_enable)                                                                                                                                                                                                    |
| 27–26<br>CG13 | Reserved                                                                                                                                                                                                                          |
| 25–24<br>CG12 | mmdc_core_ipg_clk_p0 clock (mmdc_core_ipg_clk_p0_enable)                                                                                                                                                                          |
| 23–22<br>CG11 | Reserved                                                                                                                                                                                                                          |
| 21–20<br>CG10 | mmdc_core_aclk_fast_core_p0 clock (mmdc_core_aclk_fast_core_p0_enable)                                                                                                                                                            |
| 19–18<br>CG9  | mlb clock (mlb_clk_enable)                                                                                                                                                                                                        |
| 17–16<br>CG8  | mipi_core_cfg clock (mipi_core_cfg_clk_enable)                                                                                                                                                                                    |
| 15–14<br>CG7  | ldb_di1 clock (ldb_di1_clk_enable)                                                                                                                                                                                                |
| 13–12<br>CG6  | ldb_di0 clock (ldb_di0_clk_enable)                                                                                                                                                                                                |
| 11–10<br>CG5  | ipu2_di1 clock and pre-clock (ipu2_ipu_di1_clk_enable)                                                                                                                                                                            |
| 9–8<br>CG4    | ipu2_di0 clock and pre-clock (ipu2_ipu_di0_clk_enable)                                                                                                                                                                            |

Table continues on the next page...

**CCM\_CCGR3 field descriptions (continued)**

| Field      | Description                                            |
|------------|--------------------------------------------------------|
| 7–6<br>CG3 | ipu2_ipu clock (ipu2_ipu_clk_enable)                   |
| 5–4<br>CG2 | ipu1_di1 clock and pre-clock (ipu1_ipu_di1_clk_enable) |
| 3–2<br>CG1 | ipu1_di0 clock and pre-clock (ipu1_ipu_di0_clk_enable) |
| CG0        | ipu1_ipu clock (ipu1_ipu_clk_enable)                   |

**18.6.27 CCM Clock Gating Register 4 (CCM\_CCGR4)**

The figure below represents the CCM Clock Gating Register 4 (CCM\_CCGR4). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 78h offset = 20C\_4078h

| Bit    | 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|------|------|------|------|------|------|-----|-----|----|----|----|----|----|----|----|----|
| R<br>W | CG15 | CG14 | CG13 | CG12 | CG11 | CG10 | CG9 | CG8 |    |    |    |    |    |    |    |    |
| Reset  | 1    | 1    | 1    | 1    | 1    | 1    | 1   | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

  

| Bit    | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|---|---|---|---|---|---|---|---|
| R<br>W | CG7 | CG6 | CG5 | CG4 | CG3 | CG2 | CG1 | CG0 |   |   |   |   |   |   |   |   |
| Reset  | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

**CCM\_CCGR4 field descriptions**

| Field         | Description                                                                          |
|---------------|--------------------------------------------------------------------------------------|
| 31–30<br>CG15 | rawnand_u_gpmi_input_apb clock (rawnand_u_gpmi_input_apb_clk_enable)                 |
| 29–28<br>CG14 | rawnand_u_gpmi_bch_input_gpmi_io clock (rawnand_u_gpmi_bch_input_gpmi_io_clk_enable) |
| 27–26<br>CG13 | rawnand_u_gpmi_bch_input_bch clock (rawnand_u_gpmi_bch_input_bch_clk_enable)         |
| 25–24<br>CG12 | rawnand_u_bch_input_apb clock (rawnand_u_bch_input_apb_clk_enable)                   |
| 23–22<br>CG11 | pwm4 clocks (pwm4_clk_enable)                                                        |
| 21–20<br>CG10 | pwm3 clocks (pwm3_clk_enable)                                                        |
| 19–18<br>CG9  | pwm2 clocks (pwm2_clk_enable)                                                        |

Table continues on the next page...

**CCM\_CCGR4 field descriptions (continued)**

| Field        | Description                                                   |
|--------------|---------------------------------------------------------------|
| 17–16<br>CG8 | pwm1 clocks (pwm1_clk_enable)                                 |
| 15–14<br>CG7 | pl301_mx6qper2_mainclk_enable (pl301_mx6qper2_mainclk_enable) |
| 13–12<br>CG6 | pl301_mx6qper1_bch clocks (pl301_mx6qper1_bchclk_enable)      |
| 11–10<br>CG5 | Reserved                                                      |
| 9–8<br>CG4   | pl301_mx6qfast1_s133 clock (pl301_mx6qfast1_s133clk_enable)   |
| 7–6<br>CG3   | Reserved.                                                     |
| 5–4<br>CG2   | Reserved.                                                     |
| 3–2<br>CG1   | Reserved.                                                     |
| CG0          | pcie clock (pcie_root_enable)                                 |

**18.6.28 CCM Clock Gating Register 5 (CCM\_CCGR5)**

The figure below represents the CCM Clock Gating Register 5 (CCM\_CCGR5). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 7Ch offset = 20C\_407Ch

| Bit    | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|--------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R<br>W | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Bit    | 15   | 14 | 13   | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2  | 1   | 0  |
| R<br>W | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 0  |

**CCM\_CCGR5 field descriptions**

| Field         | Description |
|---------------|-------------|
| 31–30<br>CG15 | Reserved    |
| 29–28<br>CG14 | Reserved    |

*Table continues on the next page...*

**CCM\_CCGR5 field descriptions (continued)**

| Field         | Description                                |
|---------------|--------------------------------------------|
| 27–26<br>CG13 | uart_serial clock (uart_serial_clk_enable) |
| 25–24<br>CG12 | uart clock (uart_clk_enable)               |
| 23–22<br>CG11 | ssi3 clocks (ssi3_clk_enable)              |
| 21–20<br>CG10 | ssi2 clocks (ssi2_clk_enable)              |
| 19–18<br>CG9  | ssi1 clocks (ssi1_clk_enable)              |
| 17–16<br>CG8  | Reserved                                   |
| 15–14<br>CG7  | spdif clock (spdif_clk_enable)             |
| 13–12<br>CG6  | spba clock (spba_clk_enable)               |
| 11–10<br>CG5  | Reserved                                   |
| 9–8<br>CG4    | Reserved                                   |
| 7–6<br>CG3    | sdma clock (sdma_clk_enable)               |
| 5–4<br>CG2    | sata clock (sata_clk_enable)               |
| 3–2<br>CG1    | Reserved                                   |
| CG0           | rom clock (rom_clk_enable)                 |

## 18.6.29 CCM Clock Gating Register 6 (CCM\_CCGR6)

The figure below represents the CCM Clock Gating Register 6 (CCM\_CCGR6). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 20C\_4000h base + 80h offset = 20C\_4080h

| Bit    | 31   | 30 | 29   | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18 | 17  | 16 |
|--------|------|----|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|
| R<br>W | CG15 |    | CG14 |    | CG13 |    | CG12 |    | CG11 |    | CG10 |    | CG9 |    | CG8 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |
| Bit    | 15   | 14 | 13   | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2  | 1   | 0  |
| R<br>W | CG7  |    | CG6  |    | CG5  |    | CG4  |    | CG3  |    | CG2  |    | CG1 |    | CG0 |    |
| Reset  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1    | 1  | 1   | 1  | 1   | 1  |

### CCM\_CCGR6 field descriptions

| Field         | Description                                 |
|---------------|---------------------------------------------|
| 31–30<br>CG15 | Reserved                                    |
| 29–28<br>CG14 | Reserved                                    |
| 27–26<br>CG13 | Reserved                                    |
| 25–24<br>CG12 | Reserved                                    |
| 23–22<br>CG11 | Reserved                                    |
| 21–20<br>CG10 | Reserved                                    |
| 19–18<br>CG9  | Reserved                                    |
| 17–16<br>CG8  | Reserved                                    |
| 15–14<br>CG7  | vpu clocks (vpu_clk_enable)                 |
| 13–12<br>CG6  | vdoaxiclk root clock (vdoaxiclk_clk_enable) |
| 11–10<br>CG5  | eim_slow clocks (eim_slow_clk_enable)       |
| 9–8<br>CG4    | usdhc4 clocks (usdhc4_clk_enable)           |

Table continues on the next page...

**CCM\_CCGR6 field descriptions (continued)**

| Field      | Description                       |
|------------|-----------------------------------|
| 7–6<br>CG3 | usdhc3 clocks (usdhc3_clk_enable) |
| 5–4<br>CG2 | usdhc2 clocks (usdhc2_clk_enable) |
| 3–2<br>CG1 | usdhc1 clocks (usdhc1_clk_enable) |
| CG0        | usboh3 clock (usboh3_clk_enable)  |

**18.6.30 CCM Module Enable Override Register (CCM\_CMEOR)**

The following figure represents the CCM Module Enable Override Register (CMEOR). The CMEOR register contains bits to override the clock enable signal from the module. This bit is applicable only for modules whose clock enable signals are used. The following table provides its field descriptions.

Address: 20C\_4000h base + 88h offset = 20C\_4088h

| Bit   | 31 | 30            | 29 | 28            | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------|----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|
| R     | 1  | mod_en_ov_cpi | 1  | mod_en_ov_cpi |    |    |    |    |    |    |    |    |    |    |    | 1  |
| W     |    |               |    |               |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1  | 1             | 1  | 1             | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

  

| Bit   | 15 | 14 | 13 | 12 | 11              | 10              | 9             | 8             | 7            | 6              | 5             | 4              | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|-----------------|-----------------|---------------|---------------|--------------|----------------|---------------|----------------|---|---|---|---|
| R     |    |    | 1  |    | mod_en_ov_gpu3d | mod_en_ov_gpu2d | mod_en_ov_vpu | mod_en_ov_dap | mod_en_usdhc | mod_en_ov_epit | mod_en_ov_gpt | mod_en_ov_vdoa |   |   | 1 |   |
| W     |    |    |    |    |                 |                 |               |               |              |                |               |                |   |   |   |   |
| Reset | 1  | 1  | 1  | 1  | 1               | 1               | 1             | 1             | 1            | 1              | 1             | 1              | 1 | 1 | 1 | 1 |

**CCM\_CMEOR field descriptions**

| Field          | Description                                                  |
|----------------|--------------------------------------------------------------|
| 31<br>Reserved | This read-only field is reserved and always has the value 1. |

*Table continues on the next page...*

**CCM\_CMEOR field descriptions (continued)**

| Field                        | Description                                                                                                                                                                           |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30<br>mod_en_ov_<br>can1_cpi | Overide clock enable signal from CAN1 - clock will not be gated based on CAN's signal 'enable_clk_cpi'.<br>0 don't override module enable signal<br>1 override module enable signal   |
| 29<br>Reserved               | This read-only field is reserved and always has the value 1.                                                                                                                          |
| 28<br>mod_en_ov_<br>can2_cpi | Overide clock enable signal from CAN2 - clock will not be gated based on CAN's signal 'enable_clk_cpi'.<br>0 don't override module enable signal<br>1 override module enable signal   |
| 27–12<br>Reserved            | This read-only field is reserved and always has the value 1.                                                                                                                          |
| 11<br>mod_en_ov_<br>gpu3d    | Overide clock enable signal from GPU3D - clock will not be gated based on GPU3D's signal.<br>0 don't override module enable signal<br>1 override module enable signal                 |
| 10<br>mod_en_ov_<br>gpu2d    | Overide clock enable signal from GPU2D - clock will not be gated based on GPU's signal 'gpu2d_busy' .<br>0 don't override module enable signal<br>1 override module enable signal     |
| 9<br>mod_en_ov_vpu           | Overide clock enable signal from VPU- clock will not be gated based on VPU's signal 'vpu_idle' .<br>0 don't override module enable signal<br>1 override module enable signal          |
| 8<br>mod_en_ov_dap           | Overide clock enable signal from DAP- clock will not be gated based on DAP's signal 'dap_dbgen' .<br>0 don't override module enable signal<br>1 override module enable signal         |
| 7<br>mod_en_usdhc            | Overide clock enable signal from USDHC.<br>0 don't override module enable signal<br>1 override module enable signal                                                                   |
| 6<br>mod_en_ov_epit          | Overide clock enable signal from EPIT - clock will not be gated based on EPIT's signal 'ipg_enable_clk' .<br>0 don't override module enable signal<br>1 override module enable signal |
| 5<br>mod_en_ov_gpt           | Overide clock enable signal from GPT - clock will not be gated based on GPT's signal 'ipg_enable_clk' .<br>0 don't override module enable signal<br>1 override module enable signal   |
| 4<br>mod_en_ov_<br>vdoa      | Overide clock enable signal from vdoa - clock will not be gated based on vdoa signal.<br>0 don't override module enable signal<br>1 override module enable signal                     |
| Reserved                     | This read-only field is reserved and always has the value 1.                                                                                                                          |