mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-24 19:12:38 +00:00 
			
		
		
		
	wifi/bt: fix part of modem module not reset when power up
This commit is contained in:
		| @@ -106,11 +106,17 @@ void IRAM_ATTR esp_restart_noos(void) | |||||||
|     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); |     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); | ||||||
|  |  | ||||||
|     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) |     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) | ||||||
|     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, |     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIBB_RST    | \ | ||||||
|         DPORT_BB_RST | DPORT_FE_RST | DPORT_MAC_RST | |                                                    DPORT_FE_RST        | \ | ||||||
|         DPORT_BT_RST | DPORT_BTMAC_RST | DPORT_SDIO_RST | |                                                    DPORT_WIFIMAC_RST   | \ | ||||||
|         DPORT_SDIO_HOST_RST | DPORT_EMAC_RST | DPORT_MACPWR_RST | |                                                    DPORT_BTBB_RST      | \ | ||||||
|         DPORT_RW_BTMAC_RST | DPORT_RW_BTLP_RST); |                                                    DPORT_BTMAC_RST     | \ | ||||||
|  |                                                    DPORT_SDIO_RST      | \ | ||||||
|  |                                                    DPORT_SDIO_HOST_RST | \ | ||||||
|  |                                                    DPORT_EMAC_RST      | \ | ||||||
|  |                                                    DPORT_MACPWR_RST    | \ | ||||||
|  |                                                    DPORT_RW_BTMAC_RST  | \ | ||||||
|  |                                                    DPORT_RW_BTLP_RST); | ||||||
|     DPORT_REG_WRITE(DPORT_CORE_RST_EN_REG, 0); |     DPORT_REG_WRITE(DPORT_CORE_RST_EN_REG, 0); | ||||||
|  |  | ||||||
|     // Reset timer/spi/uart |     // Reset timer/spi/uart | ||||||
|   | |||||||
| @@ -87,11 +87,16 @@ void IRAM_ATTR esp_restart_noos(void) | |||||||
|     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); |     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); | ||||||
|  |  | ||||||
|     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) |     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) | ||||||
|     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, |     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIBB_RST   | \ | ||||||
|                             DPORT_BB_RST | DPORT_FE_RST | DPORT_MAC_RST | |                                                    DPORT_FE_RST       | \ | ||||||
|                             DPORT_BT_RST | DPORT_BTMAC_RST | DPORT_SDIO_RST | |                                                    DPORT_WIFIMAC_RST  | \ | ||||||
|                             DPORT_SDIO_HOST_RST | DPORT_EMAC_RST | DPORT_MACPWR_RST | |                                                    DPORT_BTBB_RST     | \ | ||||||
|                             DPORT_RW_BTMAC_RST | DPORT_RW_BTLP_RST); |                                                    DPORT_BTMAC_RST    | \ | ||||||
|  |                                                    DPORT_SDIO_RST     | \ | ||||||
|  |                                                    DPORT_EMAC_RST     | \ | ||||||
|  |                                                    DPORT_MACPWR_RST   | \ | ||||||
|  |                                                    DPORT_RW_BTMAC_RST | \ | ||||||
|  |                                                    DPORT_RW_BTLP_RST); | ||||||
|     DPORT_REG_WRITE(DPORT_CORE_RST_EN_REG, 0); |     DPORT_REG_WRITE(DPORT_CORE_RST_EN_REG, 0); | ||||||
|  |  | ||||||
|     // Reset timer/spi/uart |     // Reset timer/spi/uart | ||||||
|   | |||||||
| @@ -89,11 +89,19 @@ void IRAM_ATTR esp_restart_noos(void) | |||||||
|     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); |     WRITE_PERI_REG(GPIO_FUNC5_IN_SEL_CFG_REG, 0x30); | ||||||
|  |  | ||||||
|     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) |     // Reset wifi/bluetooth/ethernet/sdio (bb/mac) | ||||||
|     SET_PERI_REG_MASK(SYSTEM_CORE_RST_EN_REG, |     SET_PERI_REG_MASK(SYSTEM_CORE_RST_EN_REG, SYSTEM_WIFIBB_RST       | \ | ||||||
|                       SYSTEM_BB_RST | SYSTEM_FE_RST | SYSTEM_MAC_RST | |                                               SYSTEM_FE_RST           | \ | ||||||
|                       SYSTEM_BT_RST | SYSTEM_BTMAC_RST | SYSTEM_SDIO_RST | |                                               SYSTEM_WIFIMAC_RST      | \ | ||||||
|                       SYSTEM_SDIO_HOST_RST | SYSTEM_EMAC_RST | SYSTEM_MACPWR_RST | |                                               SYSTEM_BTBB_RST         | \ | ||||||
|                       SYSTEM_RW_BTMAC_RST | SYSTEM_RW_BTLP_RST | SYSTEM_BLE_REG_RST | SYSTEM_PWR_REG_RST | SYSTEM_BB_REG_RST); |                                               SYSTEM_BTMAC_RST        | \ | ||||||
|  |                                               SYSTEM_SDIO_RST         | \ | ||||||
|  |                                               SYSTEM_EMAC_RST         | \ | ||||||
|  |                                               SYSTEM_MACPWR_RST       | \ | ||||||
|  |                                               SYSTEM_RW_BTMAC_RST     | \ | ||||||
|  |                                               SYSTEM_RW_BTLP_RST      | \ | ||||||
|  |                                               SYSTEM_RW_BTMAC_REG_RST | \ | ||||||
|  |                                               SYSTEM_RW_BTLP_REG_RST  | \ | ||||||
|  |                                               SYSTEM_BTBB_REG_RST); | ||||||
|     REG_WRITE(SYSTEM_CORE_RST_EN_REG, 0); |     REG_WRITE(SYSTEM_CORE_RST_EN_REG, 0); | ||||||
|  |  | ||||||
|     // Reset timer/spi/uart |     // Reset timer/spi/uart | ||||||
|   | |||||||
| @@ -520,8 +520,8 @@ static void IRAM_ATTR timer_arm_us_wrapper(void *ptimer, uint32_t us, bool repea | |||||||
|  |  | ||||||
| static void wifi_reset_mac_wrapper(void) | static void wifi_reset_mac_wrapper(void) | ||||||
| { | { | ||||||
|     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_MAC_RST); |     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIMAC_RST); | ||||||
|     DPORT_CLEAR_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_MAC_RST); |     DPORT_CLEAR_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIMAC_RST); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void wifi_clock_enable_wrapper(void) | static void wifi_clock_enable_wrapper(void) | ||||||
|   | |||||||
| @@ -432,8 +432,8 @@ static void IRAM_ATTR timer_arm_us_wrapper(void *ptimer, uint32_t us, bool repea | |||||||
|  |  | ||||||
| static void wifi_reset_mac_wrapper(void) | static void wifi_reset_mac_wrapper(void) | ||||||
| { | { | ||||||
|     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_MAC_RST); |     DPORT_SET_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIMAC_RST); | ||||||
|     DPORT_CLEAR_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_MAC_RST); |     DPORT_CLEAR_PERI_REG_MASK(DPORT_CORE_RST_EN_REG, DPORT_WIFIMAC_RST); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void wifi_clock_enable_wrapper(void) | static void wifi_clock_enable_wrapper(void) | ||||||
|   | |||||||
| @@ -447,15 +447,15 @@ static void IRAM_ATTR timer_arm_us_wrapper(void *ptimer, uint32_t us, bool repea | |||||||
|  |  | ||||||
| static void wifi_reset_mac_wrapper(void) | static void wifi_reset_mac_wrapper(void) | ||||||
| { | { | ||||||
|     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_MAC_RST); |     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIMAC_RST); | ||||||
|     CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_MAC_RST); |     CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIMAC_RST); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void IRAM_ATTR wifi_rtc_enable_iso_wrapper(void) | static void IRAM_ATTR wifi_rtc_enable_iso_wrapper(void) | ||||||
| { | { | ||||||
| #if CONFIG_MAC_BB_PD | #if CONFIG_MAC_BB_PD | ||||||
|     esp_mac_bb_power_down(); |     esp_mac_bb_power_down(); | ||||||
|     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_MAC_RST); |     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIMAC_RST); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -463,8 +463,8 @@ static void IRAM_ATTR wifi_rtc_disable_iso_wrapper(void) | |||||||
| { | { | ||||||
| #if CONFIG_MAC_BB_PD | #if CONFIG_MAC_BB_PD | ||||||
|     esp_mac_bb_power_up(); |     esp_mac_bb_power_up(); | ||||||
|     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_MAC_RST); |     SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIMAC_RST); | ||||||
|     CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_MAC_RST); |     CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIMAC_RST); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| #include <sys/lock.h> | #include <sys/lock.h> | ||||||
|  |  | ||||||
| #include "soc/rtc.h" | #include "soc/rtc.h" | ||||||
|  | #include "soc/syscon_reg.h" | ||||||
| #include "esp_err.h" | #include "esp_err.h" | ||||||
| #include "esp_phy_init.h" | #include "esp_phy_init.h" | ||||||
| #include "esp_system.h" | #include "esp_system.h" | ||||||
| @@ -43,11 +44,9 @@ | |||||||
| #elif CONFIG_IDF_TARGET_ESP32C3 | #elif CONFIG_IDF_TARGET_ESP32C3 | ||||||
| #include "esp32c3/rom/rtc.h" | #include "esp32c3/rom/rtc.h" | ||||||
| #include "soc/rtc_cntl_reg.h" | #include "soc/rtc_cntl_reg.h" | ||||||
| #include "soc/syscon_reg.h" |  | ||||||
| #elif CONFIG_IDF_TARGET_ESP32S3 | #elif CONFIG_IDF_TARGET_ESP32S3 | ||||||
| #include "esp32s3/rom/rtc.h" | #include "esp32s3/rom/rtc.h" | ||||||
| #include "soc/rtc_cntl_reg.h" | #include "soc/rtc_cntl_reg.h" | ||||||
| #include "soc/syscon_reg.h" |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if CONFIG_IDF_TARGET_ESP32 | #if CONFIG_IDF_TARGET_ESP32 | ||||||
| @@ -293,9 +292,9 @@ void IRAM_ATTR esp_wifi_bt_power_domain_on(void) | |||||||
|     _lock_acquire(&s_wifi_bt_pd_controller.lock); |     _lock_acquire(&s_wifi_bt_pd_controller.lock); | ||||||
|     if (s_wifi_bt_pd_controller.count++ == 0) { |     if (s_wifi_bt_pd_controller.count++ == 0) { | ||||||
|         CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD); |         CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD); | ||||||
| #if CONFIG_IDF_TARGET_ESP32C3 | #if !CONFIG_IDF_TARGET_ESP32 | ||||||
|         SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIBB_RST | SYSTEM_FE_RST); |         SET_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, MODEM_RESET_FIELD_WHEN_PU); | ||||||
|         CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, SYSTEM_WIFIBB_RST | SYSTEM_FE_RST); |         CLEAR_PERI_REG_MASK(SYSCON_WIFI_RST_EN_REG, MODEM_RESET_FIELD_WHEN_PU); | ||||||
| #endif | #endif | ||||||
|         CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_ISO_REG, RTC_CNTL_WIFI_FORCE_ISO); |         CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_ISO_REG, RTC_CNTL_WIFI_FORCE_ISO); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1076,17 +1076,25 @@ | |||||||
| #define DPORT_CORE_RST_EN_REG          (DR_REG_DPORT_BASE + 0x0D0) | #define DPORT_CORE_RST_EN_REG          (DR_REG_DPORT_BASE + 0x0D0) | ||||||
| /* DPORT_CORE_RST : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | /* DPORT_CORE_RST : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | ||||||
| /*description: */ | /*description: */ | ||||||
| #define DPORT_RW_BTLP_RST (BIT(10)) | #define DPORT_WIFIBB_RST       BIT(0) | ||||||
| #define DPORT_RW_BTMAC_RST (BIT(9)) | #define DPORT_FE_RST           BIT(1) | ||||||
| #define DPORT_MACPWR_RST (BIT(8)) | #define DPORT_WIFIMAC_RST      BIT(2) | ||||||
| #define DPORT_EMAC_RST (BIT(7)) | #define DPORT_BTBB_RST         BIT(3) | ||||||
| #define DPORT_SDIO_HOST_RST (BIT(6)) | #define DPORT_BTMAC_RST        BIT(4) | ||||||
| #define DPORT_SDIO_RST (BIT(5)) | #define DPORT_SDIO_RST         BIT(5) | ||||||
| #define DPORT_BTMAC_RST (BIT(4)) | #define DPORT_SDIO_HOST_RST    BIT(6) | ||||||
| #define DPORT_BT_RST (BIT(3)) | #define DPORT_EMAC_RST         BIT(7) | ||||||
| #define DPORT_MAC_RST (BIT(2)) | #define DPORT_MACPWR_RST       BIT(8) | ||||||
| #define DPORT_FE_RST (BIT(1)) | #define DPORT_RW_BTMAC_RST     BIT(9) | ||||||
| #define DPORT_BB_RST (BIT(0)) | #define DPORT_RW_BTLP_RST      BIT(10) | ||||||
|  |  | ||||||
|  | #define MODEM_RESET_FIELD_WHEN_PU   (DPORT_WIFIBB_RST       | \ | ||||||
|  |                                      DPORT_FE_RST           | \ | ||||||
|  |                                      DPORT_WIFIMAC_RST      | \ | ||||||
|  |                                      DPORT_BTBB_RST         | \ | ||||||
|  |                                      DPORT_BTMAC_RST        | \ | ||||||
|  |                                      DPORT_RW_BTMAC_RST     | \ | ||||||
|  |                                      DPORT_RW_BTLP_RST) | ||||||
|  |  | ||||||
| #define DPORT_BT_LPCK_DIV_INT_REG          (DR_REG_DPORT_BASE + 0x0D4) | #define DPORT_BT_LPCK_DIV_INT_REG          (DR_REG_DPORT_BASE + 0x0D4) | ||||||
| /* DPORT_BTEXTWAKEUP_REQ : R/W ;bitpos:[12] ;default: 1'b0 ; */ | /* DPORT_BTEXTWAKEUP_REQ : R/W ;bitpos:[12] ;default: 1'b0 ; */ | ||||||
|   | |||||||
| @@ -193,6 +193,7 @@ extern "C" { | |||||||
|  |  | ||||||
| #define SYSTEM_CORE_RST_EN_REG        SYSTEM_WIFI_RST_EN_REG | #define SYSTEM_CORE_RST_EN_REG        SYSTEM_WIFI_RST_EN_REG | ||||||
| #define SYSTEM_WIFI_RST_EN_REG        SYSCON_WIFI_RST_EN_REG | #define SYSTEM_WIFI_RST_EN_REG        SYSCON_WIFI_RST_EN_REG | ||||||
|  |  | ||||||
| /* SYSTEM_WIFI_RST_EN : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | /* SYSTEM_WIFI_RST_EN : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | ||||||
| /*description: */ | /*description: */ | ||||||
| #define SYSTEM_WIFIBB_RST           BIT(0) | #define SYSTEM_WIFIBB_RST           BIT(0) | ||||||
| @@ -209,6 +210,17 @@ extern "C" { | |||||||
| #define SYSTEM_RW_BTLP_REG_RST      BIT(12)   /* Bluetooth Low Power Registers */ | #define SYSTEM_RW_BTLP_REG_RST      BIT(12)   /* Bluetooth Low Power Registers */ | ||||||
| #define SYSTEM_BTBB_REG_RST         BIT(13)   /* Bluetooth Baseband Registers */ | #define SYSTEM_BTBB_REG_RST         BIT(13)   /* Bluetooth Baseband Registers */ | ||||||
|  |  | ||||||
|  | #define MODEM_RESET_FIELD_WHEN_PU   (SYSTEM_WIFIBB_RST       | \ | ||||||
|  |                                      SYSTEM_FE_RST           | \ | ||||||
|  |                                      SYSTEM_WIFIMAC_RST      | \ | ||||||
|  |                                      SYSTEM_BTBB_RST         | \ | ||||||
|  |                                      SYSTEM_BTMAC_RST        | \ | ||||||
|  |                                      SYSTEM_RW_BTMAC_RST     | \ | ||||||
|  |                                      SYSTEM_RW_BTLP_RST      | \ | ||||||
|  |                                      SYSTEM_RW_BTMAC_REG_RST | \ | ||||||
|  |                                      SYSTEM_RW_BTLP_REG_RST  | \ | ||||||
|  |                                      SYSTEM_BTBB_REG_RST) | ||||||
|  |  | ||||||
| #define SYSCON_HOST_INF_SEL_REG          (DR_REG_SYSCON_BASE + 0x01C) | #define SYSCON_HOST_INF_SEL_REG          (DR_REG_SYSCON_BASE + 0x01C) | ||||||
| /* SYSCON_PERI_IO_SWAP : R/W ;bitpos:[7:0] ;default: 8'h0 ; */ | /* SYSCON_PERI_IO_SWAP : R/W ;bitpos:[7:0] ;default: 8'h0 ; */ | ||||||
| /*description: */ | /*description: */ | ||||||
|   | |||||||
| @@ -1,16 +1,8 @@ | |||||||
| // Copyright 2017-2018 Espressif Systems (Shanghai) PTE LTD | /* | ||||||
| // |  * SPDX-FileCopyrightText: 2017-2022 Espressif Systems (Shanghai) CO LTD | ||||||
| // Licensed under the Apache License, Version 2.0 (the "License"); |  * | ||||||
| // you may not use this file except in compliance with the License. |  * SPDX-License-Identifier: Apache-2.0 | ||||||
| // You may obtain a copy of the License at |  */ | ||||||
| // |  | ||||||
| //     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| // |  | ||||||
| // Unless required by applicable law or agreed to in writing, software |  | ||||||
| // distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| // See the License for the specific language governing permissions and |  | ||||||
| // limitations under the License. |  | ||||||
| #ifndef _SOC_SYSCON_REG_H_ | #ifndef _SOC_SYSCON_REG_H_ | ||||||
| #define _SOC_SYSCON_REG_H_ | #define _SOC_SYSCON_REG_H_ | ||||||
|  |  | ||||||
| @@ -469,23 +461,32 @@ extern "C" { | |||||||
|  |  | ||||||
| #define DPORT_CORE_RST_EN_REG         DPORT_WIFI_RST_EN_REG | #define DPORT_CORE_RST_EN_REG         DPORT_WIFI_RST_EN_REG | ||||||
| #define DPORT_WIFI_RST_EN_REG         SYSCON_WIFI_RST_EN_REG | #define DPORT_WIFI_RST_EN_REG         SYSCON_WIFI_RST_EN_REG | ||||||
|  |  | ||||||
| /* DPORT_WIFI_RST : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | /* DPORT_WIFI_RST : R/W ;bitpos:[31:0] ;default: 32'h0 ; */ | ||||||
| /*description: */ | /*description: */ | ||||||
| #define DPORT_WIFI_RST  0xFFFFFFFF | #define DPORT_WIFI_RST  0xFFFFFFFF | ||||||
| #define DPORT_WIFI_RST_M  ((DPORT_WIFI_RST_V)<<(DPORT_WIFI_RST_S)) | #define DPORT_WIFI_RST_M  ((DPORT_WIFI_RST_V)<<(DPORT_WIFI_RST_S)) | ||||||
| #define DPORT_WIFI_RST_V  0xFFFFFFFF | #define DPORT_WIFI_RST_V  0xFFFFFFFF | ||||||
| #define DPORT_WIFI_RST_S  0 | #define DPORT_WIFI_RST_S  0 | ||||||
| #define DPORT_RW_BTLP_RST (BIT(10)) |  | ||||||
| #define DPORT_RW_BTMAC_RST (BIT(9)) | #define DPORT_WIFIBB_RST   BIT(0) | ||||||
| #define DPORT_MACPWR_RST (BIT(8)) | #define DPORT_FE_RST       BIT(1) | ||||||
| #define DPORT_EMAC_RST (BIT(7)) | #define DPORT_WIFIMAC_RST  BIT(2) | ||||||
| #define DPORT_SDIO_HOST_RST (BIT(6)) | #define DPORT_BTBB_RST     BIT(3) | ||||||
| #define DPORT_SDIO_RST (BIT(5)) | #define DPORT_BTMAC_RST    BIT(4) | ||||||
| #define DPORT_BTMAC_RST (BIT(4)) | #define DPORT_SDIO_RST     BIT(5) | ||||||
| #define DPORT_BT_RST (BIT(3)) | #define DPORT_EMAC_RST     BIT(7) | ||||||
| #define DPORT_MAC_RST (BIT(2)) | #define DPORT_MACPWR_RST   BIT(8) | ||||||
| #define DPORT_FE_RST (BIT(1)) | #define DPORT_RW_BTMAC_RST BIT(9) | ||||||
| #define DPORT_BB_RST (BIT(0)) | #define DPORT_RW_BTLP_RST  BIT(10) | ||||||
|  |  | ||||||
|  | #define MODEM_RESET_FIELD_WHEN_PU   (DPORT_WIFIBB_RST       | \ | ||||||
|  |                                      DPORT_FE_RST           | \ | ||||||
|  |                                      DPORT_WIFIMAC_RST      | \ | ||||||
|  |                                      DPORT_BTBB_RST         | \ | ||||||
|  |                                      DPORT_BTMAC_RST        | \ | ||||||
|  |                                      DPORT_RW_BTMAC_RST     | \ | ||||||
|  |                                      DPORT_RW_BTLP_RST) | ||||||
|  |  | ||||||
| #define SYSCON_FRONT_END_MEM_PD_REG          (DR_REG_SYSCON_BASE + 0x098) | #define SYSCON_FRONT_END_MEM_PD_REG          (DR_REG_SYSCON_BASE + 0x098) | ||||||
| /* SYSCON_DC_MEM_FORCE_PD : R/W ;bitpos:[5] ;default: 1'b0 ; */ | /* SYSCON_DC_MEM_FORCE_PD : R/W ;bitpos:[5] ;default: 1'b0 ; */ | ||||||
|   | |||||||
| @@ -214,19 +214,31 @@ extern "C" { | |||||||
| #define SYSTEM_WIFI_RST_M ((SYSTEM_WIFI_RST_V) << (SYSTEM_WIFI_RST_S)) | #define SYSTEM_WIFI_RST_M ((SYSTEM_WIFI_RST_V) << (SYSTEM_WIFI_RST_S)) | ||||||
| #define SYSTEM_WIFI_RST_V 0xFFFFFFFF | #define SYSTEM_WIFI_RST_V 0xFFFFFFFF | ||||||
| #define SYSTEM_WIFI_RST_S 0 | #define SYSTEM_WIFI_RST_S 0 | ||||||
| #define SYSTEM_BB_REG_RST (BIT(13)) |  | ||||||
| #define SYSTEM_PWR_REG_RST (BIT(12)) | #define SYSTEM_WIFIBB_RST           BIT(0) | ||||||
| #define SYSTEM_BLE_REG_RST (BIT(11)) | #define SYSTEM_FE_RST               BIT(1) | ||||||
| #define SYSTEM_RW_BTLP_RST (BIT(10)) | #define SYSTEM_WIFIMAC_RST          BIT(2) | ||||||
| #define SYSTEM_RW_BTMAC_RST (BIT(9)) | #define SYSTEM_BTBB_RST             BIT(3)    /* Bluetooth Baseband */ | ||||||
| #define SYSTEM_MACPWR_RST (BIT(8)) | #define SYSTEM_BTMAC_RST            BIT(4)    /* deprecated */ | ||||||
| #define SYSTEM_EMAC_RST (BIT(7)) | #define SYSTEM_SDIO_RST             BIT(5) | ||||||
| #define SYSTEM_SDIO_RST (BIT(5)) | #define SYSTEM_EMAC_RST             BIT(7) | ||||||
| #define SYSTEM_BTMAC_RST (BIT(4)) | #define SYSTEM_MACPWR_RST           BIT(8) | ||||||
| #define SYSTEM_BT_RST (BIT(3)) | #define SYSTEM_RW_BTMAC_RST         BIT(9)    /* Bluetooth MAC */ | ||||||
| #define SYSTEM_MAC_RST (BIT(2)) | #define SYSTEM_RW_BTLP_RST          BIT(10)   /* Bluetooth Low Power Module */ | ||||||
| #define SYSTEM_FE_RST (BIT(1)) | #define SYSTEM_RW_BTMAC_REG_RST     BIT(11)   /* Bluetooth MAC Regsiters */ | ||||||
| #define SYSTEM_BB_RST (BIT(0)) | #define SYSTEM_RW_BTLP_REG_RST      BIT(12)   /* Bluetooth Low Power Registers */ | ||||||
|  | #define SYSTEM_BTBB_REG_RST         BIT(13)   /* Bluetooth Baseband Registers */ | ||||||
|  |  | ||||||
|  | #define MODEM_RESET_FIELD_WHEN_PU   (SYSTEM_WIFIBB_RST       | \ | ||||||
|  |                                      SYSTEM_FE_RST           | \ | ||||||
|  |                                      SYSTEM_WIFIMAC_RST      | \ | ||||||
|  |                                      SYSTEM_BTBB_RST         | \ | ||||||
|  |                                      SYSTEM_BTMAC_RST        | \ | ||||||
|  |                                      SYSTEM_RW_BTMAC_RST     | \ | ||||||
|  |                                      SYSTEM_RW_BTLP_RST      | \ | ||||||
|  |                                      SYSTEM_RW_BTMAC_REG_RST | \ | ||||||
|  |                                      SYSTEM_RW_BTLP_REG_RST  | \ | ||||||
|  |                                      SYSTEM_BTBB_REG_RST) | ||||||
|  |  | ||||||
| #define SYSCON_HOST_INF_SEL_REG (DR_REG_SYSCON_BASE + 0x01C) | #define SYSCON_HOST_INF_SEL_REG (DR_REG_SYSCON_BASE + 0x01C) | ||||||
| /* SYSCON_PERI_IO_SWAP : R/W ;bitpos:[7:0] ;default: 8'h0 ; */ | /* SYSCON_PERI_IO_SWAP : R/W ;bitpos:[7:0] ;default: 8'h0 ; */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 jingli
					jingli