# M3 Power Management Unit (Version 10) Documentation (PMUv10)

Revision 1.0

Yejoong Kim\*1, Wanyeong Jung\*1, Zhiyoong Foo\*1, Inhee Lee§1, and Sechang Oh¶1

¹Michigan Integrated Circuits Laboratory, University of Michigan, Ann Arbor

March 16, 2019

<sup>\*</sup>yejoong@umich.edu

<sup>†</sup>wanyeong@umich.edu

<sup>‡</sup>zhiyoong@umich.edu

<sup>§</sup>inhee@umich.edu

<sup>¶</sup>chaseoh@umich.edu

# **Contents**

| 1 | MΒι | ıs Regi           | ster File                           | 7  |
|---|-----|-------------------|-------------------------------------|----|
|   | 1.1 | MBus              | Register File Mapping               | 7  |
|   | 1.2 | PMUv <sup>2</sup> | 10 Register Write/Read Operation    | 10 |
|   |     | 1.2.1             | Register 0x00: PMU_READ_ADDR        | 10 |
|   |     | 1.2.2             | Register $0x01 \sim 0x48$           | 11 |
|   |     | 1.2.3             | Register $0x50 \sim 0x53$           | 11 |
|   | 1.3 | MBus              | Register Descriptions               | 11 |
|   |     | 1.3.1             | Register 0 (0x00)                   | 11 |
|   |     |                   | PMU_READ_ADDR                       | 11 |
|   |     | 1.3.2             | Register 1 (0x01)                   | 11 |
|   |     |                   | PMU_EN_ADC_CONFIG                   | 11 |
|   |     | 1.3.3             | Register 2 (0x02)                   | 11 |
|   |     |                   | PMU_EN_ADC_CONFIG_OVERRIDE          | 11 |
|   |     | 1.3.4             | Register 3 (0x03)                   | 11 |
|   |     |                   | PMU_EN_ADC_STORED_OUT               | 11 |
|   |     | 1.3.5             | Register 4 (0x04)                   | 11 |
|   |     |                   | PMU_EN_SAR_RATIO                    | 11 |
|   |     | 1.3.6             | Register 5 (0x05)                   | 11 |
|   |     |                   | PMU_EN_SAR_RATIO_OVERRIDE           | 11 |
|   |     | 1.3.7             | Register 6 (0x06)                   | 11 |
|   |     |                   | PMU_EN_SAR_RATIO_OFFSET_DOWN_SLEEP  | 11 |
|   |     | 1.3.8             | Register 7 (0x07)                   | 12 |
|   |     |                   | PMU_EN_SAR_RATIO_OFFSET_DOWN_ACTIVE | 12 |
|   |     | 1.3.9             | Register 8 (0x08)                   | 12 |
|   |     |                   | PMU_EN_SAR_RATIO_OFFSET_UP_SLEEP    | 12 |
|   |     | 1.3.10            | Register 9 (0x09)                   | 12 |
|   |     |                   | PMU_EN_SAR_RATIO_OFFSET_UP_ACTIVE   | 12 |
|   |     | 1.3.11            | Register 10 (0x0A)                  | 12 |
|   |     |                   | PMU_EN_SAR_RATIO_MINIMUM            | 12 |
|   |     | 1.3.12            | Register 11 (0x0B)                  | 12 |
|   |     |                   | PMU_EN_VOLTAGE_CLAMP_OUT            | 12 |
|   |     | 1.3.13            | Register 12 (0x0C)                  | 12 |
|   |     |                   | PMU_EN_REFERENCE_TRIM_SLEEP         | 12 |
|   |     | 1.3.14            | Register 13 (0x0D)                  | 12 |
|   |     |                   | PMU_EN_REFERENCE_TRIM_ACTIVE        | 12 |
|   |     | 1.3.15            | Register 14 (0x0E)                  | 12 |

|        | PMU_EN_VOLTAGE_CLAMP_TRIM            | 12 |
|--------|--------------------------------------|----|
| 1.3.16 | Register 15 (0x0F)                   | 12 |
|        | PMU_EN_SAR_TRIM_SLEEP                | 12 |
| 1.3.17 | Register 16 (0x10)                   | 12 |
|        | PMU_EN_SAR_TRIM_ACTIVE               | 12 |
| 1.3.18 | Register 17 (0x11)                   | 12 |
|        | PMU_EN_UPCONVERTER_TRIM_SLEEP        | 12 |
| 1.3.19 | Register 18 (0x12)                   | 13 |
|        | PMU_EN_UPCONVERTER_TRIM_ACTIVE       | 13 |
| 1.3.20 | Register 19 (0x13)                   | 13 |
|        | PMU_EN_DOWNCONVERTER_TRIM_SLEEP      | 13 |
| 1.3.21 | Register 20 (0x14)                   | 13 |
|        | PMU_EN_DOWNCONVERTER_TRIM_ACTIVE     | 13 |
| 1.3.22 | Register 21 (0x15)                   | 13 |
|        | PMU_EN_SAR_TRIM_V3_SLEEP             | 13 |
| 1.3.23 | Register 22 (0x16)                   | 13 |
|        | PMU_EN_SAR_TRIM_V3_ACTIVE            | 13 |
| 1.3.24 | Register 23 (0x17)                   | 13 |
|        | PMU_EN_UPCONVERTER_TRIM_V3_SLEEP     | 13 |
| 1.3.25 | Register 24 (0x18)                   | 13 |
|        | PMU_EN_UPCONVERTER_TRIM_V3_ACTIVE    | 13 |
| 1.3.26 | Register 25 (0x19)                   | 13 |
|        | PMU_EN_DOWNCONVERTER_TRIM_V3_SLEEP   | 13 |
| 1.3.27 | Register 26 (0x1A)                   | 13 |
|        | PMU_EN_DOWNCONVERTER_TRIM_V3_ACTIVE  | 13 |
| 1.3.28 | Register 27 (0x1B)                   | 13 |
|        | PMU_EN_SAR_TRIM_V3_STARTUP           | 13 |
| 1.3.29 | Register 28 (0x1C)                   | 13 |
|        | PMU_EN_UPCONVERTER_TRIM_V3_STARTUP   | 13 |
| 1.3.30 | Register 29 (0x1D)                   | 14 |
|        | PMU_EN_DOWNCONVERTER_TRIM_V3_STARTUP | 14 |
| 1.3.31 | Register 30 (0x1E)                   | 14 |
|        | PMU_EN_SAR_TRIM_V3_OUTPUT            | 14 |
| 1.3.32 | Register 31 (0x1F)                   | 14 |
|        | PMU_EN_UPCONVERTER_TRIM_V3_OUTPUT    | 14 |
| 1.3.33 | Register 32 (0x20)                   | 14 |
|        | PMU_EN_DOWNCONVERTER_TRIM_V3_OUTPUT  | 14 |
| 1.3.34 | Register 33 (0x21)                   | 14 |

|        | PMU_EN_TICK_SAR_SCN_RESET                | 14 |
|--------|------------------------------------------|----|
| 1.3.35 | Register 34 (0x22)                       | 14 |
|        | PMU_EN_TICK_SAR_SCN_POST_RESET           | 14 |
| 1.3.36 | Register 35 (0x23)                       | 14 |
|        | PMU_EN_TICK_SAR_SCN_RST_STABILIZE        | 14 |
| 1.3.37 | Register 36 (0x24)                       | 14 |
|        | PMU_EN_TICK_SAR_SCN_STABILIZE            | 14 |
| 1.3.38 | Register 37 (0x25)                       | 14 |
|        | PMU_EN_TICK_SAR_SCN_POST_STABILIZE       | 14 |
| 1.3.39 | Register 38 (0x26)                       | 14 |
|        | PMU_EN_TICK_REFGEN_ON                    | 14 |
| 1.3.40 | Register 39 (0x27)                       | 14 |
|        | PMU_EN_TICK_UPCONVERTER_ON               | 14 |
| 1.3.41 | Register 40 (0x28)                       | 15 |
|        | PMU_EN_TICK_UPCONVERTER_RST_STABILIZE    | 15 |
| 1.3.42 | Register 41 (0x29)                       | 15 |
|        | PMU_EN_TICK_UPCONVERTER_STABILIZE        | 15 |
| 1.3.43 | Register 42 (0x2A)                       | 15 |
|        | PMU_EN_TICK_UPCONVERTER_POST_STABILIZE   | 15 |
| 1.3.44 | Register 43 (0x2B)                       | 15 |
|        | PMU_EN_TICK_DOWNCONVERTER_ON             | 15 |
| 1.3.45 | Register 44 (0x2C)                       | 15 |
|        | PMU_EN_TICK_DOWNCONVERTER_RST_STABILIZE  | 15 |
| 1.3.46 | Register 45 (0x2D)                       | 15 |
|        | PMU_EN_TICK_DOWNCONVERTER_STABILIZE      | 15 |
| 1.3.47 | Register 46 (0x2E)                       | 15 |
|        | PMU_EN_TICK_DOWNCONVERTER_POST_STABILIZE | 15 |
| 1.3.48 | Register 47 (0x2F)                       | 15 |
|        | PMU_EN_TICK_OUTPUT_PRE_3P6_ON            | 15 |
| 1.3.49 | Register 48 (0x30)                       | 15 |
|        | PMU_EN_TICK_OUTPUT_POST_3P6_ON           | 15 |
| 1.3.50 | Register 49 (0x31)                       | 15 |
|        | PMU_EN_TICK_OUTPUT_POST_1P2_ON           | 15 |
| 1.3.51 | Register 50 (0x32)                       | 15 |
|        | PMU_EN_TICK_OUTPUT_WEAK                  | 15 |
| 1.3.52 | Register 51 (0x33)                       | 16 |
|        | PMU_EN_TICK_ADC_RESET                    | 16 |
| 1 3 53 | Register 52 (0v34)                       | 16 |

|        | PMU_EN_TICK_ADC_CLK                    | 16 |
|--------|----------------------------------------|----|
| 1.3.54 | Register 53 (0x35)                     | 16 |
|        | PMU_EN_TICK_CONTROLLER_CLK             | 16 |
| 1.3.55 | Register 54 (0x36)                     | 16 |
|        | PMU_EN_TICK_REPEAT_VBAT_ADJUST         | 16 |
| 1.3.56 | Register 55 (0x37)                     | 16 |
|        | PMU_EN_TICK_WAKEUP_WAIT                | 16 |
| 1.3.57 | Register 56 (0x38)                     | 16 |
|        | PMU_EN_TICK_SLEEP_WAIT                 | 16 |
| 1.3.58 | Register 57 (0x39)                     | 16 |
|        | PMU_EN_CONTROLLER_STALL_SLEEP          | 16 |
| 1.3.59 | Register 58 (0x3A)                     | 16 |
|        | PMU_EN_CONTROLLER_STALL_ACTIVE         | 16 |
| 1.3.60 | Register 59 (0x3B)                     | 16 |
|        | PMU_EN_CONTROLLER_DESIRED_STATE_SLEEP  | 16 |
| 1.3.61 | Register 60 (0x3C)                     | 16 |
|        | PMU_EN_CONTROLLER_DESIRED_STATE_ACTIVE | 16 |
| 1.3.62 | Register 61 (0x3D)                     | 16 |
|        | PMU_EN_CONTROLLER_STATE_MAIN           | 16 |
| 1.3.63 | Register 62 (0x3E)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_SAR            | 17 |
| 1.3.64 | Register 63 (0x3F)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_UPCONVERTER    | 17 |
| 1.3.65 | Register 64 (0x40)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_DOWNCONVERTER  | 17 |
| 1.3.66 | Register 65 (0x41)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_ADC            | 17 |
| 1.3.67 | Register 66 (0x42)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_TICKCOUNT      | 17 |
| 1.3.68 | Register 67 (0x43)                     | 17 |
|        | PMU_EN_CONTROLLER_STATE_OUTPUT         | 17 |
| 1.3.69 | Register 68 (0x44)                     | 17 |
|        | PMU_EN_RESERVED_1                      | 17 |
| 1.3.70 | Register 69 (0x45)                     | 17 |
|        | PMU_EN_RESERVED_2                      | 17 |
| 1.3.71 | Register 70 (0x46)                     | 17 |
|        | PMU_EN_RESERVED_3                      | 17 |
| 1 3 72 | Register 71 (0v47)                     | 17 |

|        | PMU_EN_RESERVED_4   | 17 |
|--------|---------------------|----|
| 1.3.73 | Register 72 (0x48)  | 17 |
|        | PMU_EN_RESERVED_5   | 17 |
| 1.3.74 | Register 80 (0x50)  | 18 |
|        | IRQ_PAYLOAD         | 18 |
| 1.3.75 | Register 81 (0x51)  | 18 |
|        | MBUS_IGNORE_RX_FAIL | 18 |
|        | EN_GLITCH_FILT      | 18 |
|        | PMU_CHECK_WRITE     | 18 |
|        | PMU_IRQ_EN          | 18 |
|        | LC_CLK_DIV          | 18 |
|        | LC_CLK_RING         | 18 |
| 1.3.76 | Register 82 (0x52)  | 18 |
|        | INT_RPLY_SHORT_ADDR | 18 |
|        | INT_RPLY_REG_ADDR   | 18 |
| 1.3.77 | Register 83 (0x53)  | 18 |
|        | VCO_CNT_ENABLE      | 18 |
|        | VCO_CNT_MODE        | 18 |
|        | VCO CNT THRESHOLD   | 18 |

# 1 MBus Register File

# 1.1 MBus Register File Mapping

Table 1 shows MBus Register File mapping information. 'NR' indicates a non-retentive register.

| Reg Addr   | Bit Field   | Reg Name                            | Property | Size & Reset | Remark |
|------------|-------------|-------------------------------------|----------|--------------|--------|
|            |             | ault: 24'h000000                    |          |              |        |
| 0x00       | [0]         | PMU_READ_ADDR                       | W        | 1'h0         |        |
| Register 1 | (0x01) Def  | ault: 24'h000000                    |          |              |        |
| 0x01       | [0]         | PMU_EN_ADC_CONFIG                   | W        | 1'h0         |        |
| Register 2 | (0x02) Def  | ault: 24'h000000                    |          |              |        |
| 0x02       | [0]         | PMU_EN_ADC_CONFIG_OVERRIDE          | W        | 1'h0         |        |
| Register 3 | (0x03) Def  | ault: 24'h000000                    |          |              |        |
| 0x03       | [0]         | PMU_EN_ADC_STORED_OUT               | W        | 1'h0         |        |
| Register 4 | (0x04) Def  | ault: 24'h000000                    |          |              |        |
| 0x04       | [0]         | PMU_EN_SAR_RATIO                    | W        | 1'h0         |        |
|            | (0x05) Def  | ault: 24'h000000                    |          |              |        |
| 0x05       | [0]         | PMU_EN_SAR_RATIO_OVERRIDE           | W        | 1'h0         |        |
|            | (0x06) Def  | ault: 24'h000000                    |          |              |        |
| 0x06       | [0]         | PMU_EN_SAR_RATIO_OFFSET_DOWN_SLEEP  | W        | 1'h0         |        |
| Register 7 | (0x07) Def  | ault: 24'h000000                    |          |              |        |
| 0x07       | [0]         | PMU_EN_SAR_RATIO_OFFSET_DOWN_ACTIVE | W        | 1'h0         |        |
| Register 8 | (0x08) Def  | ault: 24'h000000                    | '        | 1            |        |
| 0x08       | [0]         | PMU_EN_SAR_RATIO_OFFSET_UP_SLEEP    | W        | 1'h0         |        |
| Register 9 | (0x09) Def  | ault: 24'h000000                    |          |              |        |
| 0x09       | [0]         | PMU_EN_SAR_RATIO_OFFSET_UP_ACTIVE   | W        | 1'h0         |        |
| Register 1 | 0 (0x0A) D  | efault: 24'h000000                  | <b>'</b> | 1            |        |
| 0x0A       | [0]         | PMU_EN_SAR_RATIO_MINIMUM            | W        | 1'h0         |        |
| Register 1 | 1 (0x0B) D  | efault: 24'h000000                  |          |              |        |
| 0x0B       | [0]         | PMU_EN_VOLTAGE_CLAMP_OUT            | W        | 1'h0         |        |
| Register 1 | 2 (0x0C) D  | efault: 24'h000000                  | <b>'</b> | 1            |        |
| 0x0C       | [0]         | PMU_EN_REFERENCE_TRIM_SLEEP         | W        | 1'h0         |        |
| Register 1 | 3 (0x0D) D  | efault: 24'h000000                  | '        | 1            |        |
| 0x0D       | [0]         | PMU_EN_REFERENCE_TRIM_ACTIVE        | W        | 1'h0         |        |
| Register 1 | 4 (0x0E) De | efault: 24'h000000                  | <b>'</b> | 1            |        |
| 0x0E       | [0]         | PMU_EN_VOLTAGE_CLAMP_TRIM           | W        | 1'h0         |        |
| Register 1 | 5 (0x0F) De | efault: 24'h000000                  |          |              |        |
| 0x0F       | [0]         | PMU_EN_SAR_TRIM_SLEEP               | W        | 1'h0         |        |
| Register 1 | 6 (0x10) De | efault: 24'h000000                  |          |              |        |
| 0x10       | [0]         | PMU_EN_SAR_TRIM_ACTIVE              | W        | 1'h0         |        |
| Register 1 |             | efault: 24'h000000                  | ,        |              |        |
| 0x11       | [0]         | PMU_EN_UPCONVERTER_TRIM_SLEEP       | W        | 1'h0         |        |
| Register 1 | 8 (0x12) De | efault: 24'h000000                  |          |              |        |
| 0x12       | [0]         | PMU_EN_UPCONVERTER_TRIM_ACTIVE      | W        | 1'h0         |        |
| Register 1 | 9 (0x13) De | efault: 24'h000000                  |          |              |        |
| 0x13       | [0]         | PMU_EN_DOWNCONVERTER_TRIM_SLEEP     | W        | 1'h0         |        |
| Register 2 |             | efault: 24'h000000                  |          |              |        |
| 0x14       | [0]         | PMU_EN_DOWNCONVERTER_TRIM_ACTIVE    | W        | 1'h0         |        |
|            |             | Continued on next page              |          | 1            | ı      |

|            |                    | Continued from previous page            |          |              |        |
|------------|--------------------|-----------------------------------------|----------|--------------|--------|
| Reg Addr   | Bit Field          |                                         | Property | Size & Reset | Remark |
| Register 2 | 1 (0x15) De        | fault: 24'h000000                       |          |              |        |
| 0x15       | [0]                | PMU_EN_SAR_TRIM_V3_SLEEP                | W        | 1'h0         |        |
| Register 2 | <b>2 (0x16)</b> De | fault: 24'h000000                       |          |              |        |
| 0x16       | [0]                | PMU_EN_SAR_TRIM_V3_ACTIVE               | W        | 1'h0         |        |
| Register 2 | 3 (0x17) De        | fault: 24'h000000                       |          |              |        |
| 0x17       | [0]                | PMU_EN_UPCONVERTER_TRIM_V3_SLEEP        | W        | 1'h0         |        |
| Register 2 | 4 (0x18) De        | fault: 24'h000000                       |          |              |        |
| 0x18       | [0]                | PMU_EN_UPCONVERTER_TRIM_V3_ACTIVE       | W        | 1'h0         |        |
| Register 2 | <b>5 (0x19)</b> De | fault: 24'h000000                       |          |              |        |
| 0x19       | [0]                | PMU_EN_DOWNCONVERTER_TRIM_V3_SLEEP      | W        | 1'h0         |        |
| •          | •                  | efault: 24'h000000                      |          |              |        |
| 0x1A       | [0]                | PMU_EN_DOWNCONVERTER_TRIM_V3_ACTIVE     | W        | 1'h0         |        |
| Register 2 | 7 (0x1B) De        | efault: 24'h000000                      |          |              |        |
| 0x1B       | [0]                | PMU_EN_SAR_TRIM_V3_STARTUP              | W        | 1'h0         |        |
| Register 2 | 8 (0x1C) De        | efault: 24'h000000                      |          |              |        |
| 0x1C       | [0]                | PMU_EN_UPCONVERTER_TRIM_V3_STARTUP      | W        | 1'h0         |        |
| Register 2 | 9 (0x1D) De        | efault: 24'h000000                      |          |              |        |
| 0x1D       | [0]                | PMU_EN_DOWNCONVERTER_TRIM_V3_STARTUP    | W        | 1'h0         |        |
| Register 3 | 0 (0x1E) De        | efault: 24'h000000                      |          |              |        |
| 0x1E       | [0]                | PMU_EN_SAR_TRIM_V3_OUTPUT               | W        | 1'h0         |        |
| Register 3 | 1 (0x1F) De        | fault: 24'h000000                       |          |              |        |
| 0x1F       | [0]                | PMU_EN_UPCONVERTER_TRIM_V3_OUTPUT       | W        | 1'h0         |        |
| Register 3 | <b>2 (0x20)</b> De | fault: 24'h000000                       |          |              |        |
| 0x20       | [0]                | PMU_EN_DOWNCONVERTER_TRIM_V3_OUTPUT     | W        | 1'h0         |        |
| Register 3 | 3 (0x21) De        | fault: 24'h000000                       |          |              |        |
| 0x21       | [0]                | PMU_EN_TICK_SAR_SCN_RESET               | W        | 1'h0         |        |
| Register 3 | 4 (0x22) De        | fault: 24'h000000                       |          |              |        |
| 0x22       | [0]                | PMU_EN_TICK_SAR_SCN_POST_RESET          | W        | 1'h0         |        |
| Register 3 | <b>5 (0x23)</b> De | fault: 24'h000000                       |          |              |        |
| 0x23       | [0]                | PMU_EN_TICK_SAR_SCN_RST_STABILIZE       | W        | 1'h0         |        |
| •          |                    | fault: 24'h000000                       |          |              |        |
| 0x24       | [0]                | PMU_EN_TICK_SAR_SCN_STABILIZE           | W        | 1'h0         |        |
| Register 3 | ` ,                | fault: 24'h000000                       |          |              |        |
| 0x25       |                    | PMU_EN_TICK_SAR_SCN_POST_STABILIZE      | W        | 1'h0         |        |
| _          | ` '                | fault: 24'h000000                       |          |              |        |
| 0x26       | [0]                | PMU_EN_TICK_REFGEN_ON                   | W        | 1'h0         |        |
|            |                    | fault: 24'h000000                       |          |              |        |
| 0x27       | [0]                | PMU_EN_TICK_UPCONVERTER_ON              | W        | 1'h0         |        |
|            |                    | fault: 24'h000000                       |          |              |        |
| 0x28       | [0]                | PMU_EN_TICK_UPCONVERTER_RST_STABILIZE   | W        | 1'h0         |        |
| •          |                    | fault: 24'h000000                       |          |              |        |
| 0x29       | [0]                | PMU_EN_TICK_UPCONVERTER_STABILIZE       | W        | 1'h0         |        |
| •          |                    | efault: 24'h000000                      |          |              |        |
| 0x2A       | [0]                | PMU_EN_TICK_UPCONVERTER_POST_STABILIZE  | W        | 1'h0         |        |
| •          | • •                | efault: 24'h000000                      |          |              |        |
| 0x2B       | [0]                | PMU_EN_TICK_DOWNCONVERTER_ON            | W        | 1'h0         |        |
|            |                    | efault: 24'h000000                      |          | 411.0        |        |
| 0x2C       | [0]                | PMU_EN_TICK_DOWNCONVERTER_RST_STABILIZE | E W      | 1'h0         |        |
|            |                    | Continued on next page                  |          |              |        |

|            |                    | Continued from previous page             |          |              |          |
|------------|--------------------|------------------------------------------|----------|--------------|----------|
|            | Bit Field          |                                          | Property | Size & Reset | Remark   |
| Register 4 | 5 (0x2D) De        | efault: 24'h000000                       | ,        |              |          |
| 0x2D       | [0]                | PMU_EN_TICK_DOWNCONVERTER_STABILIZE      | W        | 1'h0         |          |
|            | 6 (0x2E) De        | efault: 24'h000000                       |          |              |          |
| 0x2E       | [0]                | PMU_EN_TICK_DOWNCONVERTER_POST_STABILIZE | W        | 1'h0         |          |
| Register 4 | 7 (0x2F) De        | efault: 24'h000000                       |          |              |          |
| 0x2F       | [0]                | PMU_EN_TICK_OUTPUT_PRE_3P6_ON            | W        | 1'h0         |          |
| Register 4 | <b>8 (0x30)</b> De | fault: 24'h000000                        |          |              |          |
| 0x30       | [0]                | PMU_EN_TICK_OUTPUT_POST_3P6_ON           | W        | 1'h0         |          |
| Register 4 | 9 (0x31) De        | fault: 24'h000000                        |          |              |          |
| 0x31       | [0]                | PMU_EN_TICK_OUTPUT_POST_1P2_ON           | W        | 1'h0         |          |
| Register 5 | 0 (0x32) De        | fault: 24'h000000                        |          |              |          |
| 0x32       | [0]                | PMU_EN_TICK_OUTPUT_WEAK                  | W        | 1'h0         |          |
| Register 5 | 1 (0x33) De        | fault: 24'h000000                        | •        |              | <u>'</u> |
| 0x33       | [0]                | PMU_EN_TICK_ADC_RESET                    | W        | 1'h0         |          |
| Register 5 | 2 (0x34) De        | fault: 24'h000000                        | '        | 1            | '        |
| 0x34       | [0]                | PMU_EN_TICK_ADC_CLK                      | W        | 1'h0         |          |
| Register 5 | <b>3 (0x35)</b> De | fault: 24'h000000                        | <b>'</b> | 1            |          |
| 0x35       | [0]                | PMU_EN_TICK_CONTROLLER_CLK               | W        | 1'h0         |          |
| Register 5 | 4 (0x36) De        | efault: 24'h000000                       |          | 1            | 1        |
| 0x36       | [0]                | PMU_EN_TICK_REPEAT_VBAT_ADJUST           | W        | 1'h0         |          |
| Register 5 |                    | efault: 24'h000000                       | L        | l .          |          |
| 0x37       | [0]                | PMU_EN_TICK_WAKEUP_WAIT                  | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          |              | <u> </u> |
| 0x38       | [0]                | PMU_EN_TICK_SLEEP_WAIT                   | W        | 1'h0         |          |
| Register 5 |                    | efault: 24'h000000                       |          |              | <u> </u> |
| 0x39       | [0]                | PMU_EN_CONTROLLER_STALL_SLEEP            | W        | 1'h0         |          |
| Register 5 |                    | efault: 24'h000000                       |          |              | <u> </u> |
| 0x3A       | [0]                | PMU_EN_CONTROLLER_STALL_ACTIVE           | W        | 1'h0         |          |
| Register 5 |                    | efault: 24'h000000                       |          |              | <u> </u> |
| 0x3B       | [0]                | PMU_EN_CONTROLLER_DESIRED_STATE_SLEEP    | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | -            |          |
| 0x3C       | [0]                | PMU_EN_CONTROLLER_DESIRED_STATE_ACTIVE   | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | 1 110        |          |
| 0x3D       |                    | PMU_EN_CONTROLLER_STATE_MAIN             | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | _            |          |
| 0x3E       | [0]                | PMU_EN_CONTROLLER_STATE_SAR              | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | 1            |          |
| 0x3F       | [0]                | PMU_EN_CONTROLLER_STATE_UPCONVERTER      | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | 1            |          |
| 0x40       | [0]                | PMU_EN_CONTROLLER_STATE_DOWNCONVERTER    | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | 1            |          |
| 0x41       | [0]                | PMU_EN_CONTROLLER_STATE_ADC              | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       | 11       | 1            |          |
| 0x42       | [0]                | PMU_EN_CONTROLLER_STATE_TICKCOUNT        | W        | 1'h0         |          |
| _          |                    | efault: 24'h000000                       |          |              |          |
| 0x43       | [0]                | PMU_EN_CONTROLLER_STATE_OUTPUT           | W        | 1'h0         |          |
|            |                    | efault: 24'h000000                       |          | 5            |          |
| 0x44       | [0]                | PMU_EN_RESERVED_1                        | W        | 1'h0         |          |
|            | ا [۷]              | Continued on next page                   | 1        | . 110        |          |
|            |                    | Continued on next page                   |          |              |          |

| Continued from previous page |                    |                     |          |              |        |  |
|------------------------------|--------------------|---------------------|----------|--------------|--------|--|
| Reg Addr                     | Bit Field          | Reg Name            | Property | Size & Reset | Remark |  |
| Register 6                   | <b>9 (0x45)</b> De | fault: 24'h000000   |          |              |        |  |
| 0x45                         | [0]                | PMU_EN_RESERVED_2   | W        | 1'h0         |        |  |
| Register 7                   | <b>0 (0x46)</b> De | fault: 24'h000000   |          |              |        |  |
| 0x46                         | [0]                | PMU_EN_RESERVED_3   | W        | 1'h0         |        |  |
| Register 7                   | <b>1 (0x47)</b> De | fault: 24'h000000   |          |              |        |  |
| 0x47                         | [0]                | PMU_EN_RESERVED_4   | W        | 1'h0         |        |  |
|                              |                    | fault: 24'h000000   |          |              |        |  |
| 0x48                         | [0]                | PMU_EN_RESERVED_5   | W        | 1'h0         |        |  |
| Register 8                   | <b>0 (0x50)</b> De | fault: 24'h000000   |          |              |        |  |
| 0x50                         | [23:0]             | IRQ_PAYLOAD         | R        | 24'h000000   |        |  |
| Register 8                   | <b>1 (0x51)</b> De | fault: 24'h00009D   |          |              |        |  |
|                              | [7]                | MBUS_IGNORE_RX_FAIL | W/R      | 1'h1         |        |  |
|                              | [6]                | EN_GLITCH_FILT      | W/R      | 1'h0         |        |  |
| 0x51                         | [5]                | PMU_CHECK_WRITE     | W/R      | 1'h0         |        |  |
| OXO I                        | [4]                | PMU_IRQ_EN          | W/R      | 1'h1         |        |  |
|                              | [3:2]              | LC_CLK_DIV          | W/R      | 2'h3         |        |  |
|                              | [1:0]              | LC_CLK_RING         | W/R      | 2'h1         |        |  |
| Register 8                   |                    | fault: 24'h001000   |          |              |        |  |
| 0x52                         | [15:8]             | INT_RPLY_SHORT_ADDR | W/R      | 8'h10        |        |  |
|                              | [7:0]              | INT_RPLY_REG_ADDR   | W/R      | 8'h00        |        |  |
| Register 8                   | •                  | fault: 24'h000000   |          | 1            |        |  |
|                              | [23]               | VCO_CNT_ENABLE      | W/R      | 1'h0         |        |  |
| 0x53                         | [22]               | VCO_CNT_MODE        | W/R      | 1'h0         |        |  |
|                              | [21:0]             | VCO_CNT_THRESHOLD   | W/R      | 22'h000000   |        |  |

Table 1: PMUv10 MBus Register File Mapping

## 1.2 PMUv10 Register Write/Read Operation

#### 1.2.1 Register 0x00: PMU\_READ\_ADDR

Using a typical MBus Register Write message, writing 8-bit data into this register triggers PMU Register Read operation. The 8-bit data is treated as an address of the register that will be read.

For example, writing 0x01 into this register initiates a READ from register 0x01, which corresponds to PMU\_ADC\_CONFIG. Then, PMUv10 sends an MBus message containing this PMU\_ADC\_CONFIG data. This reply message uses addresses specified in INT\_RPLY\_SHORT\_ADDR and INT\_RPLY\_REG\_ADDR.

Similarly, writing 0x42 into this register 0x00 initiates a READ from register 0x42, which corresponds to PMU\_CONTROLLER\_STATE\_TICKCOUNT.

For this purpose, the valid 8-bit data range is 0x01 ~ 0x48. See Table 1 for the register names.

There is one more valid 8-bit data, which is 0xFF. Writing 0xFF into this register 0x00 resets the interface controller inside PMUv10. This controller (pmuv10\_ctrl) is an interface between the Layer Controller (pmuv10\_layer\_ctrl) and the PMU itself (pmuv10\_top). It does NOT reset the PMU itself (pmuv10\_top). This reset signal is effective for one clock cycle (i.e., one Layer Ctrl clock cycle), and then will be released automatically.

Using a typical MBus Register Read message, reading from this register 0x00 returns pmu\_reg\_en signal in the controller (pmuv10\_ctrl), which is a previously accessed register address.

#### 1.2.2 Register $0x01 \sim 0x48$

Register  $0x01 \sim 0x48$  are mapped to internal PMU registers.

Using a typical MBus Register Write message, writing 24-bit data into one of the registers initiates a WRITE into the corresponding register.

For example, writing 0xFFFFFF into the register 0x38 will write 0xFFFFFF into PMU\_TICK\_SLEEP\_WAIT. Once the write operation is done, PMUv10 will send a reply if PMU\_IRQ\_EN is set to 1, using the addresses specified in INT\_RPLY\_SHORT\_ADDR and INT\_RPLY\_REG\_ADDR. This reply message contains the write data.

Using a typical MBus Register Read message, reading from one of these registers will return zero.

#### 1.2.3 Register $0x50 \sim 0x53$

Register  $0x50 \sim 0x53$  can be treated as typical MBus Register File; user can use the standard MBus Register Write/Read messages to access those registers.

## 1.3 MBus Register Descriptions

#### 1.3.1 Register 0 (0x00)

PMU\_READ\_ADDR Reg 0x00, Bit Field: [0], Default: 1'h0, W

#### 1.3.2 Register 1 (0x01)

PMU\_EN\_ADC\_CONFIG Reg 0x01, Bit Field: [0], Default: 1'h0, W

# 1.3.3 Register 2 (0x02)

PMU\_EN\_ADC\_CONFIG\_OVERRIDE Reg 0x02, Bit Field: [0], Default: 1'h0, W

#### 1.3.4 Register 3 (0x03)

PMU\_EN\_ADC\_STORED\_OUT Reg 0x03, Bit Field: [0], Default: 1'h0, W

#### 1.3.5 Register 4 (0x04)

PMU\_EN\_SAR\_RATIO Reg 0x04, Bit Field: [0], Default: 1'h0, W

## 1.3.6 Register 5 (0x05)

PMU\_EN\_SAR\_RATIO\_OVERRIDE Reg 0x05, Bit Field: [0], Default: 1'h0, W

#### 1.3.7 Register 6 (0x06)

PMU\_EN\_SAR\_RATIO\_OFFSET\_DOWN\_SLEEP Reg 0x06, Bit Field: [0], Default: 1'h0, W

1.3.8 Register 7 (0x07)

PMU\_EN\_SAR\_RATIO\_OFFSET\_DOWN\_ACTIVE Reg 0x07, Bit Field: [0], Default: 1'h0, W

1.3.9 Register 8 (0x08)

PMU\_EN\_SAR\_RATIO\_OFFSET\_UP\_SLEEP Reg 0x08, Bit Field: [0], Default: 1'h0, W

1.3.10 Register 9 (0x09)

PMU\_EN\_SAR\_RATIO\_OFFSET\_UP\_ACTIVE Reg 0x09, Bit Field: [0], Default: 1'h0, W

1.3.11 Register 10 (0x0A)

PMU\_EN\_SAR\_RATIO\_MINIMUM Reg 0x0A, Bit Field: [0], Default: 1'h0, W

1.3.12 Register 11 (0x0B)

PMU\_EN\_VOLTAGE\_CLAMP\_OUT Reg 0x0B, Bit Field: [0], Default: 1'h0, W

1.3.13 Register 12 (0x0C)

PMU\_EN\_REFERENCE\_TRIM\_SLEEP Reg 0x0C, Bit Field: [0], Default: 1'h0, W

1.3.14 Register 13 (0x0D)

PMU\_EN\_REFERENCE\_TRIM\_ACTIVE Reg 0x0D, Bit Field: [0], Default: 1'h0, W

1.3.15 Register 14 (0x0E)

PMU\_EN\_VOLTAGE\_CLAMP\_TRIM Reg 0x0E, Bit Field: [0], Default: 1'h0, W

1.3.16 Register 15 (0x0F)

PMU\_EN\_SAR\_TRIM\_SLEEP Reg 0x0F, Bit Field: [0], Default: 1'h0, W

1.3.17 Register 16 (0x10)

PMU\_EN\_SAR\_TRIM\_ACTIVE Reg 0x10, Bit Field: [0], Default: 1'h0, W

1.3.18 Register 17 (0x11)

PMU\_EN\_UPCONVERTER\_TRIM\_SLEEP Reg 0x11, Bit Field: [0], Default: 1'h0, W

1.3.19 Register 18 (0x12)

PMU\_EN\_UPCONVERTER\_TRIM\_ACTIVE Reg 0x12, Bit Field: [0], Default: 1'h0, W

1.3.20 Register 19 (0x13)

PMU\_EN\_DOWNCONVERTER\_TRIM\_SLEEP Reg 0x13, Bit Field: [0], Default: 1'h0, W

1.3.21 Register 20 (0x14)

PMU\_EN\_DOWNCONVERTER\_TRIM\_ACTIVE Reg 0x14, Bit Field: [0], Default: 1'h0, W

1.3.22 Register 21 (0x15)

PMU\_EN\_SAR\_TRIM\_V3\_SLEEP Reg 0x15, Bit Field: [0], Default: 1'h0, W

1.3.23 Register 22 (0x16)

PMU\_EN\_SAR\_TRIM\_V3\_ACTIVE Reg 0x16, Bit Field: [0], Default: 1'h0, W

1.3.24 Register 23 (0x17)

PMU\_EN\_UPCONVERTER\_TRIM\_V3\_SLEEP Reg 0x17, Bit Field: [0], Default: 1'h0, W

1.3.25 Register 24 (0x18)

PMU\_EN\_UPCONVERTER\_TRIM\_V3\_ACTIVE Reg 0x18, Bit Field: [0], Default: 1'h0, W

1.3.26 Register 25 (0x19)

PMU\_EN\_DOWNCONVERTER\_TRIM\_V3\_SLEEP Reg 0x19, Bit Field: [0], Default: 1'h0, W

1.3.27 Register 26 (0x1A)

PMU\_EN\_DOWNCONVERTER\_TRIM\_V3\_ACTIVE Reg 0x1A, Bit Field: [0], Default: 1'h0, W

1.3.28 Register 27 (0x1B)

PMU\_EN\_SAR\_TRIM\_V3\_STARTUP Reg 0x1B, Bit Field: [0], Default: 1'h0, W

1.3.29 Register 28 (0x1C)

PMU\_EN\_UPCONVERTER\_TRIM\_V3\_STARTUP Reg 0x1C, Bit Field: [0], Default: 1'h0, W

1.3.30 Register 29 (0x1D)

PMU\_EN\_DOWNCONVERTER\_TRIM\_V3\_STARTUP Reg 0x1D, Bit Field: [0], Default: 1'h0, W

1.3.31 Register 30 (0x1E)

PMU\_EN\_SAR\_TRIM\_V3\_OUTPUT Reg 0x1E, Bit Field: [0], Default: 1'h0, W

1.3.32 Register 31 (0x1F)

PMU\_EN\_UPCONVERTER\_TRIM\_V3\_OUTPUT Reg 0x1F, Bit Field: [0], Default: 1'h0, W

1.3.33 Register 32 (0x20)

PMU\_EN\_DOWNCONVERTER\_TRIM\_V3\_OUTPUT Reg 0x20, Bit Field: [0], Default: 1'h0, W

1.3.34 Register 33 (0x21)

PMU\_EN\_TICK\_SAR\_SCN\_RESET Reg 0x21, Bit Field: [0], Default: 1'h0, W

1.3.35 Register 34 (0x22)

PMU\_EN\_TICK\_SAR\_SCN\_POST\_RESET Reg 0x22, Bit Field: [0], Default: 1'h0, W

1.3.36 Register 35 (0x23)

PMU\_EN\_TICK\_SAR\_SCN\_RST\_STABILIZE Reg 0x23, Bit Field: [0], Default: 1'h0, W

1.3.37 Register 36 (0x24)

PMU\_EN\_TICK\_SAR\_SCN\_STABILIZE Reg 0x24, Bit Field: [0], Default: 1'h0, W

1.3.38 Register 37 (0x25)

PMU\_EN\_TICK\_SAR\_SCN\_POST\_STABILIZE Reg 0x25, Bit Field: [0], Default: 1'h0, W

1.3.39 Register 38 (0x26)

PMU\_EN\_TICK\_REFGEN\_ON Reg 0x26, Bit Field: [0], Default: 1'h0, W

1.3.40 Register 39 (0x27)

PMU\_EN\_TICK\_UPCONVERTER\_ON Reg 0x27, Bit Field: [0], Default: 1'h0, W

1.3.41 Register 40 (0x28)

PMU\_EN\_TICK\_UPCONVERTER\_RST\_STABILIZE Reg 0x28, Bit Field: [0], Default: 1'h0, W

1.3.42 Register 41 (0x29)

PMU\_EN\_TICK\_UPCONVERTER\_STABILIZE Reg 0x29, Bit Field: [0], Default: 1'h0, W

1.3.43 Register 42 (0x2A)

PMU\_EN\_TICK\_UPCONVERTER\_POST\_STABILIZE Reg 0x2A, Bit Field: [0], Default: 1'h0, W

1.3.44 Register 43 (0x2B)

PMU\_EN\_TICK\_DOWNCONVERTER\_ON Reg 0x2B, Bit Field: [0], Default: 1'h0, W

1.3.45 Register 44 (0x2C)

PMU\_EN\_TICK\_DOWNCONVERTER\_RST\_STABILIZE Reg 0x2C, Bit Field: [0], Default: 1'h0, W

1.3.46 Register 45 (0x2D)

PMU\_EN\_TICK\_DOWNCONVERTER\_STABILIZE Reg 0x2D, Bit Field: [0], Default: 1'h0, W

1.3.47 Register 46 (0x2E)

PMU\_EN\_TICK\_DOWNCONVERTER\_POST\_STABILIZE Reg 0x2E, Bit Field: [0], Default: 1'h0, W

1.3.48 Register 47 (0x2F)

PMU\_EN\_TICK\_OUTPUT\_PRE\_3P6\_ON Reg 0x2F, Bit Field: [0], Default: 1'h0, W

1.3.49 Register 48 (0x30)

PMU\_EN\_TICK\_OUTPUT\_POST\_3P6\_ON Reg 0x30, Bit Field: [0], Default: 1'h0, W

1.3.50 Register 49 (0x31)

PMU\_EN\_TICK\_OUTPUT\_POST\_1P2\_ON Reg 0x31, Bit Field: [0], Default: 1'h0, W

1.3.51 Register 50 (0x32)

PMU\_EN\_TICK\_OUTPUT\_WEAK Reg 0x32, Bit Field: [0], Default: 1'h0, W

1.3.52 Register 51 (0x33)

PMU\_EN\_TICK\_ADC\_RESET Reg 0x33, Bit Field: [0], Default: 1'h0, W

1.3.53 Register 52 (0x34)

PMU\_EN\_TICK\_ADC\_CLK Reg 0x34, Bit Field: [0], Default: 1'h0, W

1.3.54 Register 53 (0x35)

PMU\_EN\_TICK\_CONTROLLER\_CLK Reg 0x35, Bit Field: [0], Default: 1'h0, W

1.3.55 Register 54 (0x36)

PMU\_EN\_TICK\_REPEAT\_VBAT\_ADJUST Reg 0x36, Bit Field: [0], Default: 1'h0, W

1.3.56 Register 55 (0x37)

PMU\_EN\_TICK\_WAKEUP\_WAIT Reg 0x37, Bit Field: [0], Default: 1'h0, W

1.3.57 Register 56 (0x38)

PMU\_EN\_TICK\_SLEEP\_WAIT Reg 0x38, Bit Field: [0], Default: 1'h0, W

1.3.58 Register 57 (0x39)

PMU\_EN\_CONTROLLER\_STALL\_SLEEP Reg 0x39, Bit Field: [0], Default: 1'h0, W

1.3.59 Register 58 (0x3A)

PMU\_EN\_CONTROLLER\_STALL\_ACTIVE Reg 0x3A, Bit Field: [0], Default: 1'h0, W

1.3.60 Register 59 (0x3B)

PMU\_EN\_CONTROLLER\_DESIRED\_STATE\_SLEEP Reg 0x3B, Bit Field: [0], Default: 1'h0, W

1.3.61 Register 60 (0x3C)

PMU\_EN\_CONTROLLER\_DESIRED\_STATE\_ACTIVE Reg 0x3C, Bit Field: [0], Default: 1'h0, W

1.3.62 Register 61 (0x3D)

PMU\_EN\_CONTROLLER\_STATE\_MAIN Reg 0x3D, Bit Field: [0], Default: 1'h0, W

1.3.63 Register 62 (0x3E)

PMU\_EN\_CONTROLLER\_STATE\_SAR Reg 0x3E, Bit Field: [0], Default: 1'h0, W

1.3.64 Register 63 (0x3F)

PMU\_EN\_CONTROLLER\_STATE\_UPCONVERTER Reg 0x3F, Bit Field: [0], Default: 1'h0, W

1.3.65 Register 64 (0x40)

PMU\_EN\_CONTROLLER\_STATE\_DOWNCONVERTER Reg 0x40, Bit Field: [0], Default: 1'h0, W

1.3.66 Register 65 (0x41)

PMU\_EN\_CONTROLLER\_STATE\_ADC Reg 0x41, Bit Field: [0], Default: 1'h0, W

1.3.67 Register 66 (0x42)

PMU\_EN\_CONTROLLER\_STATE\_TICKCOUNT Reg 0x42, Bit Field: [0], Default: 1'h0, W

1.3.68 Register 67 (0x43)

PMU\_EN\_CONTROLLER\_STATE\_OUTPUT Reg 0x43, Bit Field: [0], Default: 1'h0, W

1.3.69 Register 68 (0x44)

PMU\_EN\_RESERVED\_1 Reg 0x44, Bit Field: [0], Default: 1'h0, W

1.3.70 Register 69 (0x45)

PMU\_EN\_RESERVED\_2 Reg 0x45, Bit Field: [0], Default: 1'h0, W

1.3.71 Register 70 (0x46)

PMU\_EN\_RESERVED\_3 Reg 0x46, Bit Field: [0], Default: 1'h0, W

1.3.72 Register 71 (0x47)

PMU\_EN\_RESERVED\_4 Reg 0x47, Bit Field: [0], Default: 1'h0, W

1.3.73 Register 72 (0x48)

PMU\_EN\_RESERVED\_5 Reg 0x48, Bit Field: [0], Default: 1'h0, W

## 1.3.74 Register 80 (0x50)

IRQ\_PAYLOAD Reg 0x50, Bit Field: [23:0], Default: 24'h000000, R

1.3.75 Register 81 (0x51)

MBUS\_IGNORE\_RX\_FAIL Reg 0x51, Bit Field: [7], Default: 1'h1, W/R

**EN\_GLITCH\_FILT** Reg 0x51, Bit Field: [6], Default: 1'h0, W/R

PMU\_CHECK\_WRITE Reg 0x51, Bit Field: [5], Default: 1'h0, W/R

PMU\_IRQ\_EN Reg 0x51, Bit Field: [4], Default: 1'h1, W/R

LC\_CLK\_DIV Reg 0x51, Bit Field: [3:2], Default: 2'h3, W/R

LC\_CLK\_RING Reg 0x51, Bit Field: [1:0], Default: 2'h1, W/R

1.3.76 Register 82 (0x52)

INT\_RPLY\_SHORT\_ADDR Reg 0x52, Bit Field: [15:8], Default: 8'h10, W/R

INT\_RPLY\_REG\_ADDR Reg 0x52, Bit Field: [7:0], Default: 8'h00, W/R

1.3.77 Register 83 (0x53)

VCO\_CNT\_ENABLE Reg 0x53, Bit Field: [23], Default: 1'h0, W/R

VCO\_CNT\_MODE Reg 0x53, Bit Field: [22], Default: 1'h0, W/R

VCO\_CNT\_THRESHOLD Reg 0x53, Bit Field: [21:0], Default: 22'h000000, W/R