2016-11-15 10:36:18 +00:00
|
|
|
// Copyright 2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// 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.
|
|
|
|
|
2018-02-01 09:45:41 +00:00
|
|
|
#ifndef PHY_INIT_DATA_H
|
|
|
|
#define PHY_INIT_DATA_H /* don't use #pragma once here, we compile this file sometimes */
|
2016-11-15 10:36:18 +00:00
|
|
|
#include "esp_phy_init.h"
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
|
2020-01-27 03:43:08 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-11-15 10:36:18 +00:00
|
|
|
// constrain a value between 'low' and 'high', inclusive
|
|
|
|
#define LIMIT(val, low, high) ((val < low) ? low : (val > high) ? high : val)
|
|
|
|
|
|
|
|
#define PHY_INIT_MAGIC "PHYINIT"
|
|
|
|
|
2018-07-25 09:28:56 +00:00
|
|
|
// define the lowest tx power as LOWEST_PHY_TX_POWER
|
|
|
|
#define PHY_TX_POWER_LOWEST LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 52)
|
|
|
|
#define PHY_TX_POWER_OFFSET 44
|
|
|
|
#define PHY_TX_POWER_NUM 5
|
|
|
|
|
2019-10-16 03:22:50 +00:00
|
|
|
#if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN
|
|
|
|
#define PHY_CRC_ALGORITHM 1
|
|
|
|
#define PHY_COUNTRY_CODE_LEN 2
|
|
|
|
#define PHY_INIT_DATA_TYPE_OFFSET 126
|
|
|
|
#define PHY_SUPPORT_MULTIPLE_BIN_OFFSET 125
|
|
|
|
#endif
|
|
|
|
|
2016-11-15 10:36:18 +00:00
|
|
|
static const char phy_init_magic_pre[] = PHY_INIT_MAGIC;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Structure containing default recommended PHY initialization parameters.
|
|
|
|
*/
|
2017-10-09 06:37:42 +00:00
|
|
|
static const esp_phy_init_data_t phy_init_data= { {
|
2017-10-17 03:22:46 +00:00
|
|
|
3,
|
2019-06-17 03:50:37 +00:00
|
|
|
0,
|
|
|
|
0x04,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x05,
|
2019-06-17 03:50:37 +00:00
|
|
|
0x04,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x05,
|
|
|
|
0x05,
|
|
|
|
0x04,
|
|
|
|
0x06,
|
2019-06-17 03:50:37 +00:00
|
|
|
0x06,
|
|
|
|
0x06,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x05,
|
2019-06-17 03:50:37 +00:00
|
|
|
0x06,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x05,
|
2017-10-17 03:22:46 +00:00
|
|
|
0x09,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x06,
|
|
|
|
0x05,
|
2017-10-17 03:22:46 +00:00
|
|
|
0x03,
|
2017-10-09 06:37:42 +00:00
|
|
|
0x06,
|
|
|
|
0x05,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
|
|
|
0x00,
|
2019-06-17 03:50:37 +00:00
|
|
|
0xf4,
|
|
|
|
0xf8,
|
|
|
|
0xf8,
|
2017-10-09 06:37:42 +00:00
|
|
|
0xf0,
|
|
|
|
0xf0,
|
|
|
|
0xf0,
|
|
|
|
0xe0,
|
|
|
|
0xe0,
|
|
|
|
0xe0,
|
|
|
|
0x18,
|
|
|
|
0x18,
|
|
|
|
0x18,
|
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 78),
|
2017-10-17 03:22:46 +00:00
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 72),
|
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 66),
|
2017-10-09 06:37:42 +00:00
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 60),
|
2017-10-17 03:22:46 +00:00
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 56),
|
2017-10-09 06:37:42 +00:00
|
|
|
LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 52),
|
|
|
|
0,
|
|
|
|
1,
|
|
|
|
1,
|
|
|
|
2,
|
2017-10-17 03:22:46 +00:00
|
|
|
2,
|
2017-10-09 06:37:42 +00:00
|
|
|
3,
|
|
|
|
4,
|
|
|
|
5,
|
|
|
|
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,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
2017-10-17 03:22:46 +00:00
|
|
|
0,
|
|
|
|
0,
|
2017-10-09 06:37:42 +00:00
|
|
|
} };
|
2016-11-15 10:36:18 +00:00
|
|
|
|
|
|
|
static const char phy_init_magic_post[] = PHY_INIT_MAGIC;
|
|
|
|
|
2019-10-16 03:22:50 +00:00
|
|
|
#if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN
|
|
|
|
/**
|
|
|
|
* @brief PHY init data control infomation structure
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uint8_t control_info_checksum[4]; /*!< 4-byte control infomation checksum */
|
|
|
|
uint8_t multiple_bin_checksum[4]; /*!< 4-byte multiple bin checksum */
|
|
|
|
uint8_t check_algorithm; /*!< check algorithm */
|
|
|
|
uint8_t version; /*!< PHY init data bin version */
|
|
|
|
uint8_t number; /*!< PHY init data bin number */
|
|
|
|
uint8_t length[2]; /*!< Length of each PHY init data bin */
|
|
|
|
uint8_t reserved[19]; /*!< 19-byte reserved */
|
|
|
|
} __attribute__ ((packed)) phy_control_info_data_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Country corresponds to PHY init data type structure
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
char cc[PHY_COUNTRY_CODE_LEN];
|
|
|
|
uint8_t type;
|
|
|
|
} phy_country_to_bin_type_t;
|
|
|
|
#endif
|
|
|
|
|
2020-01-27 03:43:08 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-02-01 09:45:41 +00:00
|
|
|
#endif /* PHY_INIT_DATA_H */
|
|
|
|
|