mirror of
https://github.com/espressif/esp-idf.git
synced 2025-10-23 18:53:28 +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