imx: imx8ulp: upower: make code cleaner
authorPeng Fan <peng.fan@nxp.com>
Tue, 31 Jan 2023 08:42:23 +0000 (16:42 +0800)
committerStefano Babic <sbabic@denx.de>
Wed, 29 Mar 2023 18:15:42 +0000 (20:15 +0200)
To clean the upower codes by aligning codes format, check err_code
and add detail bits list for the memory magic number

Reviewed-by: Ye Li <ye.li@nxp.com>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
arch/arm/mach-imx/imx8ulp/upower/upower_hal.c

index 370685e9e19b7836029058604b67fc5a57fb8623..fcb02ed3af6b4a487f93968bc0db65dc77c810c2 100644 (file)
@@ -129,6 +129,7 @@ int upower_init(void)
        u32 fw_major, fw_minor, fw_vfixes;
        u32 soc_id;
        int status;
+       enum upwr_resp err_code;
 
        u32 swton;
        u64 memon;
@@ -165,22 +166,86 @@ int upower_init(void)
        if (ret)
                printf("Turn on switches fail %d\n", ret);
        else
-               printf("Turn on switches ok\n");
+               printf("Turning on switches...\n");
+
        upower_wait_resp();
-       ret = upwr_poll_req_status(UPWR_SG_PWRMGMT, NULL, NULL, &ret_val, 1000);
+       ret = upwr_poll_req_status(UPWR_SG_PWRMGMT, NULL, &err_code, &ret_val, 1000);
        if (ret != UPWR_REQ_OK)
-               printf("Failure %d\n", ret);
+               printf("Turn on switches faliure %d, err_code %d, ret_val 0x%x\n", ret, err_code, ret_val);
+       else
+               printf("Turn on switches ok\n");
 
-       memon = 0x3FFFFFFFFFFFFCUL;
-       ret = upwr_pwm_power_on(NULL, (const u32 *)&memon, NULL);
+       /*
+        * Ascending Order -> bit [0:54)
+        * CA35 Core 0 L1 cache
+        * CA35 Core 1 L1 cache
+        * L2 Cache 0
+        * L2 Cache 1
+        * L2 Cache victim/tag
+        * CAAM Secure RAM
+        * DMA1 RAM
+        * FlexSPI2 FIFO, Buffer
+        * SRAM0
+        * AD ROM
+        * USB0 TX/RX RAM
+        * uSDHC0 FIFO RAM
+        * uSDHC1 FIFO RAM
+        * uSDHC2 FIFO and USB1 TX/RX RAM
+        * GIC RAM
+        * ENET TX FIXO
+        * Reserved(Brainshift)
+        * DCNano Tile2Linear and RGB Correction
+        * DCNano Cursor and FIFO
+        * EPDC LUT
+        * EPDC FIFO
+        * DMA2 RAM
+        * GPU2D RAM Group 1
+        * GPU2D RAM Group 2
+        * GPU3D RAM Group 1
+        * GPU3D RAM Group 2
+        * HIFI4 Caches, IRAM, DRAM
+        * ISI Buffers
+        * MIPI-CSI FIFO
+        * MIPI-DSI FIFO
+        * PXP Caches, Buffers
+        * SRAM1
+        * Casper RAM
+        * DMA0 RAM
+        * FlexCAN RAM
+        * FlexSPI0 FIFO, Buffer
+        * FlexSPI1 FIFO, Buffer
+        * CM33 Cache
+        * PowerQuad RAM
+        * ETF RAM
+        * Sentinel PKC, Data RAM1, Inst RAM0/1
+        * Sentinel ROM
+        * uPower IRAM/DRAM
+        * uPower ROM
+        * CM33 ROM
+        * SSRAM Partition 0
+        * SSRAM Partition 1
+        * SSRAM Partition 2,3,4
+        * SSRAM Partition 5
+        * SSRAM Partition 6
+        * SSRAM Partition 7_a(128KB)
+        * SSRAM Partition 7_b(64KB)
+        * SSRAM Partition 7_c(64KB)
+        * Sentinel Data RAM0, Inst RAM2
+        */
+       /* MIPI-CSI FIFO BIT28 not set */
+       memon = 0x3FFFFFEFFFFFFCUL;
+       ret = upwr_pwm_power_on(NULL, (const uint32_t *)&memon, NULL);
        if (ret)
                printf("Turn on memories fail %d\n", ret);
        else
-               printf("Turn on memories ok\n");
+               printf("Turning on memories...\n");
+
        upower_wait_resp();
-       ret = upwr_poll_req_status(UPWR_SG_PWRMGMT, NULL, NULL, &ret_val, 1000);
+       ret = upwr_poll_req_status(UPWR_SG_PWRMGMT, NULL, &err_code, &ret_val, 1000);
        if (ret != UPWR_REQ_OK)
-               printf("Failure %d\n", ret);
+               printf("Turn on memories faliure %d, err_code %d, ret_val 0x%x\n", ret, err_code, ret_val);
+       else
+               printf("Turn on memories ok\n");
 
        mdelay(1);
 
@@ -188,13 +253,14 @@ int upower_init(void)
        if (ret)
                printf("Clear DDR retention fail %d\n", ret);
        else
-               printf("Clear DDR retention ok\n");
+               printf("Clearing DDR retention...\n");
 
        upower_wait_resp();
-
-       ret = upwr_poll_req_status(UPWR_SG_EXCEPT, NULL, NULL, &ret_val, 1000);
+       ret = upwr_poll_req_status(UPWR_SG_EXCEPT, NULL, &err_code, &ret_val, 1000);
        if (ret != UPWR_REQ_OK)
-               printf("Failure %d\n", ret);
+               printf("Clear DDR retention fail %d, err_code %d, ret_val 0x%x\n", ret, err_code, ret_val);
+       else
+               printf("Clear DDR retention ok\n");
 
        return 0;
 }