mirror of
https://github.com/Koenkk/Z-Stack-firmware.git
synced 2025-01-19 04:11:19 +01:00
Merge branch 'master' into develop
This commit is contained in:
commit
9f296cdeee
@ -1,5 +1,11 @@
|
|||||||
# 20190523
|
# CC2530, CC2530_CC2591, CC2530_CC2592, CC2531
|
||||||
|
|
||||||
|
## 20190523
|
||||||
- Add CC2530 and CC2530_CC2591 firmware
|
- Add CC2530 and CC2530_CC2591 firmware
|
||||||
|
|
||||||
# 20190425
|
## 20190425
|
||||||
- Initial version.
|
- Initial version.
|
||||||
|
|
||||||
|
# CC2538_CC2592_MODKAMRU_V3
|
||||||
|
|
||||||
|
Available [here](https://github.com/jethome-ru/zigbee-firmware/tree/master/ti/coordinator/cc2538_cc2592#changelog).
|
@ -24,24 +24,4 @@
|
|||||||
|
|
||||||
# CC2538_CC2592_MODKAMRU_V3
|
# CC2538_CC2592_MODKAMRU_V3
|
||||||
|
|
||||||
## Setup development environment
|
Available [here](https://github.com/jethome-ru/zigbee-firmware/tree/master/ti/coordinator/cc2538_cc2592#modkam-v3-differences-form-the-original-ti-znp-z-stack-302).
|
||||||
1. Download and install [Z-STACK-3.0.2](http://www.ti.com/tool/Z-STACK).
|
|
||||||
2. Download and install [IAR Embedded Workbench for ARM](https://www.iar.com/iar-embedded-workbench/#!?architecture=Arm).
|
|
||||||
|
|
||||||
*NOTE: For IAR Embedded Workbench for ARM you need either the full (paid) version or the 30-days evaluation version.*
|
|
||||||
|
|
||||||
## Compiling
|
|
||||||
1. Copy `firmware_CC2538_CC2592_MODKAMRU_V3.patch` to `Z-Stack 3.0.2`
|
|
||||||
2. Open Git Bash, go to `Z-Stack 3.0.2` and apply the patch using:
|
|
||||||
`git apply --reject --whitespace=fix firmware_CC2538_CC2592_MODKAMRU_V3.patch`
|
|
||||||
3. Open `Z-Stack 3.0.2\Projects\zstack\ZNP\CC2538\ZNP.eww` with IAR Embedded workbench for ARM.
|
|
||||||
4. Select `CC2538ZNP-Debug` target.
|
|
||||||
5. Right-click on your target and press options. Go to C/C++ compiler -> preprocessor. Depending on what you want to compile, correct the following symbols in *Defined symbols*:
|
|
||||||
- to use USB interface: `HAL_UART_USB`, `xHAL_UART=TRUE`, `xZNP_ALT`;
|
|
||||||
- to use UART interface without flow control: `xHAL_UART_USB`, `HAL_UART=TRUE`, `ZNP_ALT`;
|
|
||||||
- to use UART interface with flow control enabled: `xHAL_UART_USB`, `HAL_UART=TRUE`, `xZNP_ALT`.
|
|
||||||
6. Go to Output Converter, check `Generate additional output` checkbox, select `Intel Extended hex` output format and uncheck `Override default` checkbox.
|
|
||||||
7. Press OK.
|
|
||||||
8. Right-click on your target and click *Rebuild all*.
|
|
||||||
9. Once finished, you can find the `ZNP.hex` file in `Z-Stack 3.0.2\Projects\zstack\ZNP\CC2538\CC2538ZNP-Debug\Exe\`.
|
|
||||||
|
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
Firmwares are hosted [here](https://github.com/jethome-ru/zigbee-firmware/tree/master/ti/coordinator/cc2538_cc2592).
|
Binary file not shown.
@ -1,683 +0,0 @@
|
|||||||
diff --git a/Components/bsp/srf06eb_cc2538/drivers/source/bsp.h b/Components/bsp/srf06eb_cc2538/drivers/source/bsp.h
|
|
||||||
index 38ac3d9..367699d 100644
|
|
||||||
--- a/Components/bsp/srf06eb_cc2538/drivers/source/bsp.h
|
|
||||||
+++ b/Components/bsp/srf06eb_cc2538/drivers/source/bsp.h
|
|
||||||
@@ -81,16 +81,22 @@ extern "C"
|
|
||||||
#define BSP_3V3_EN GPIO_PIN_4 //!< PB4
|
|
||||||
|
|
||||||
// Board LED defines
|
|
||||||
-#define BSP_LED_BASE GPIO_C_BASE
|
|
||||||
-#define BSP_LED_1 GPIO_PIN_0 //!< PC0
|
|
||||||
-#define BSP_LED_2 GPIO_PIN_1 //!< PC1
|
|
||||||
-#define BSP_LED_3 GPIO_PIN_2 //!< PC2
|
|
||||||
-#define BSP_LED_4 GPIO_PIN_3 //!< PC3
|
|
||||||
-#define BSP_LED_ALL (BSP_LED_1 | \
|
|
||||||
- BSP_LED_2 | \
|
|
||||||
- BSP_LED_3 | \
|
|
||||||
- BSP_LED_4) //!< Bitmask of all LEDs
|
|
||||||
-
|
|
||||||
+#ifdef MODKAMRU_V3 // Redefine board LEDs
|
|
||||||
+ #define BSP_LED_BASE GPIO_B_BASE
|
|
||||||
+ #define BSP_LED_1 GPIO_PIN_1
|
|
||||||
+ #define BSP_LED_2 GPIO_PIN_2
|
|
||||||
+ #define BSP_LED_3 GPIO_PIN_3
|
|
||||||
+ #define BSP_LED_4 GPIO_PIN_4
|
|
||||||
+ #define BSP_LED_ALL (BSP_LED_1 | BSP_LED_2 | BSP_LED_3 | BSP_LED_4)
|
|
||||||
+#else //Not a MODKAMRU board
|
|
||||||
+ #define BSP_LED_BASE GPIO_C_BASE
|
|
||||||
+ #define BSP_LED_1 GPIO_PIN_0 //!< PC0
|
|
||||||
+ #define BSP_LED_2 GPIO_PIN_1 //!< PC1
|
|
||||||
+ #define BSP_LED_3 GPIO_PIN_2 //!< PC2
|
|
||||||
+ #define BSP_LED_4 GPIO_PIN_3 //!< PC3
|
|
||||||
+ #define BSP_LED_ALL (BSP_LED_1 | BSP_LED_2 | BSP_LED_3 | BSP_LED_4) //!< Bitmask of all LEDs
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
// Board key defines
|
|
||||||
#define BSP_KEY_DIR_BASE GPIO_C_BASE //!< Base for left/right/up/down
|
|
||||||
#define BSP_KEY_SEL_BASE GPIO_A_BASE //!< Base for Select
|
|
||||||
diff --git a/Components/hal/include/hal_led.h b/Components/hal/include/hal_led.h
|
|
||||||
index bb327f1..f8a88b2 100644
|
|
||||||
--- a/Components/hal/include/hal_led.h
|
|
||||||
+++ b/Components/hal/include/hal_led.h
|
|
||||||
@@ -86,6 +86,19 @@ extern "C"
|
|
||||||
/*********************************************************************
|
|
||||||
* GLOBAL VARIABLES
|
|
||||||
*/
|
|
||||||
+
|
|
||||||
+#ifdef MODKAMRU_V3 //LED control helpers
|
|
||||||
+ /* Dynamically enable/disable LEDs */
|
|
||||||
+ extern bool gbModkamUseLeds;
|
|
||||||
+ extern void modkamUseLeds(bool);
|
|
||||||
+
|
|
||||||
+ /* LED control macros */
|
|
||||||
+#define MODKAM_LED_ON(leds) {if(gbModkamUseLeds)HalLedSet(leds,HAL_LED_MODE_ON);}
|
|
||||||
+#define MODKAM_LED_OFF(leds) {if(gbModkamUseLeds)HalLedSet(leds,HAL_LED_MODE_OFF);}
|
|
||||||
+#define MODKAM_LED_BLINK(leds,count,duty,duration) {if(gbModkamUseLeds)HalLedBlink(leds,count,duty,duration);}
|
|
||||||
+#define MODKAM_LED_BLINK_LONG(leds) MODKAM_LED_BLINK(leds,1,90,1000)
|
|
||||||
+#define MODKAM_LED_BLINK_SHORT(leds) MODKAM_LED_BLINK(leds,1,50,100)
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Initialize LED Service.
|
|
||||||
diff --git a/Components/hal/target/CC2538ZNP/hal_board_cfg.h b/Components/hal/target/CC2538ZNP/hal_board_cfg.h
|
|
||||||
index 0bc45b5..9f28629 100644
|
|
||||||
--- a/Components/hal/target/CC2538ZNP/hal_board_cfg.h
|
|
||||||
+++ b/Components/hal/target/CC2538ZNP/hal_board_cfg.h
|
|
||||||
@@ -231,7 +231,7 @@ extern unsigned char znpCfg0;
|
|
||||||
#define HAL_FLASH_WORD_SIZE 4
|
|
||||||
|
|
||||||
// Z-Stack uses flash pages for NV
|
|
||||||
-#define HAL_NV_PAGE_CNT 6
|
|
||||||
+#define HAL_NV_PAGE_CNT 12
|
|
||||||
#define HAL_NV_PAGE_BEG (HAL_NV_PAGE_END-HAL_NV_PAGE_CNT+1)
|
|
||||||
#define HAL_NV_START_ADDR ((FLASH_BASE) + (HAL_NV_PAGE_BEG * HAL_FLASH_PAGE_SIZE))
|
|
||||||
|
|
||||||
@@ -280,7 +280,7 @@ extern unsigned char znpCfg0;
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* ----------- RF-frontend Connection Initialization ---------- */
|
|
||||||
-#if defined HAL_PA_LNA || defined HAL_PA_LNA_CC2590
|
|
||||||
+#if defined HAL_PA_LNA || defined HAL_PA_LNA_CC2590 || defined HAL_PA_LNA_CC2592
|
|
||||||
extern void MAC_RfFrontendSetup(void);
|
|
||||||
#define HAL_BOARD_RF_FRONTEND_SETUP() MAC_RfFrontendSetup()
|
|
||||||
#else
|
|
||||||
@@ -300,13 +300,14 @@ extern void MAC_RfFrontendSetup(void);
|
|
||||||
/* ----------- Board Initialization ---------- */
|
|
||||||
#define HAL_BOARD_INIT() \
|
|
||||||
{ \
|
|
||||||
+ HAL_BOARD_LED_INIT(); \
|
|
||||||
HAL_BOARD_COMMON_INIT() \
|
|
||||||
HAL_BOARD_PA_LNA_INIT(); \
|
|
||||||
HAL_BOARD_RF_FRONTEND_SETUP(); \
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
-#ifdef HAL_PA_LNA
|
|
||||||
+#if defined HAL_PA_LNA || defined HAL_PA_LNA_CC2592
|
|
||||||
#define HAL_BOARD_PA_LNA_INIT() st(GPIOPinTypeGPIOOutput(HGM_BASE, HGM_PIN); )
|
|
||||||
#else
|
|
||||||
#define HAL_BOARD_PA_LNA_INIT()
|
|
||||||
@@ -340,15 +341,34 @@ extern void MAC_RfFrontendSetup(void);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ----------- LED's ---------- */
|
|
||||||
-#define HAL_TURN_OFF_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, 0)
|
|
||||||
-#define HAL_TURN_OFF_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, 0)
|
|
||||||
-#define HAL_TURN_OFF_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, 0)
|
|
||||||
-#define HAL_TURN_OFF_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, 0)
|
|
||||||
+#ifdef MODKAMRU_V3 //Set LED pins to output mode
|
|
||||||
+ #define HAL_BOARD_LED_INIT() GPIOPinTypeGPIOOutput(BSP_LED_BASE,BSP_LED_ALL)
|
|
||||||
+#else
|
|
||||||
+ #define HAL_BOARD_LED_INIT()
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+#ifdef MODKAMRU_V3 //Redefine LED contorl macros
|
|
||||||
+ #define HAL_TURN_OFF_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, BSP_LED_1)
|
|
||||||
+ #define HAL_TURN_OFF_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, BSP_LED_2)
|
|
||||||
+ #define HAL_TURN_OFF_LED3() GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, BSP_LED_3)
|
|
||||||
+ #define HAL_TURN_OFF_LED4() GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, BSP_LED_4)
|
|
||||||
+
|
|
||||||
+ #define HAL_TURN_ON_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, 0)
|
|
||||||
+ #define HAL_TURN_ON_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, 0)
|
|
||||||
+ #define HAL_TURN_ON_LED3() GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, 0)
|
|
||||||
+ #define HAL_TURN_ON_LED4() GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, 0)
|
|
||||||
+#else /* Not a MODKAMRU board */
|
|
||||||
+ #define HAL_TURN_OFF_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, 0)
|
|
||||||
+ #define HAL_TURN_OFF_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, 0)
|
|
||||||
+ #define HAL_TURN_OFF_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, 0)
|
|
||||||
+ #define HAL_TURN_OFF_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, 0)
|
|
||||||
+
|
|
||||||
+ #define HAL_TURN_ON_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, BSP_LED_1)
|
|
||||||
+ #define HAL_TURN_ON_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, BSP_LED_2)
|
|
||||||
+ #define HAL_TURN_ON_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, BSP_LED_3)
|
|
||||||
+ #define HAL_TURN_ON_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, BSP_LED_4)
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
-#define HAL_TURN_ON_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, BSP_LED_1)
|
|
||||||
-#define HAL_TURN_ON_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, BSP_LED_2)
|
|
||||||
-#define HAL_TURN_ON_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, BSP_LED_3)
|
|
||||||
-#define HAL_TURN_ON_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, BSP_LED_4)
|
|
||||||
|
|
||||||
#define HAL_CLR_GPIO_00() GPIOPinWrite(BSP_LED_BASE, GPIO_PIN_2, 0) // LED3
|
|
||||||
#define HAL_CLR_GPIO_02() GPIOPinWrite(BSP_LED_BASE, GPIO_PIN_3, 0) // LED4
|
|
||||||
@@ -357,16 +377,30 @@ extern void MAC_RfFrontendSetup(void);
|
|
||||||
#define HAL_SET_GPIO_02() GPIOPinWrite(BSP_LED_BASE, GPIO_PIN_3, GPIO_PIN_3) // LED4
|
|
||||||
|
|
||||||
/* ----------- Toggle the LEDs ---------- */
|
|
||||||
-#define HAL_TOGGLE_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_1)))
|
|
||||||
-#define HAL_TOGGLE_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_2)))
|
|
||||||
-#define HAL_TOGGLE_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_3)))
|
|
||||||
-#define HAL_TOGGLE_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_4)))
|
|
||||||
+#ifdef MODKAMRU_V3 //Redefine LED contorl macros
|
|
||||||
+ #define HAL_TOGGLE_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_1)))
|
|
||||||
+ #define HAL_TOGGLE_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_2)))
|
|
||||||
+ #define HAL_TOGGLE_LED3() GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_3)))
|
|
||||||
+ #define HAL_TOGGLE_LED4() GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_4)))
|
|
||||||
+#else //Not a MODKAMRU board
|
|
||||||
+ #define HAL_TOGGLE_LED1() GPIOPinWrite(BSP_LED_BASE, BSP_LED_1, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_1)))
|
|
||||||
+ #define HAL_TOGGLE_LED2() GPIOPinWrite(BSP_LED_BASE, BSP_LED_2, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_2)))
|
|
||||||
+ #define HAL_TOGGLE_LED3() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_3, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_3)))
|
|
||||||
+ #define HAL_TOGGLE_LED4() //GPIOPinWrite(BSP_LED_BASE, BSP_LED_4, ~(GPIOPinRead(BSP_LED_BASE, BSP_LED_4)))
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
/* ----------- Read the LEDs ---------- */
|
|
||||||
-#define HAL_STATE_LED1() GPIOPinRead(BSP_LED_BASE, BSP_LED_1)
|
|
||||||
-#define HAL_STATE_LED2() GPIOPinRead(BSP_LED_BASE, BSP_LED_2)
|
|
||||||
-#define HAL_STATE_LED3() GPIOPinRead(BSP_LED_BASE, BSP_LED_3)
|
|
||||||
-#define HAL_STATE_LED4() GPIOPinRead(BSP_LED_BASE, BSP_LED_4)
|
|
||||||
+#ifdef MODKAMRU_V3 //Redefine LED state reading macros
|
|
||||||
+ #define HAL_STATE_LED1() (!GPIOPinRead(BSP_LED_BASE, BSP_LED_1))
|
|
||||||
+ #define HAL_STATE_LED2() (!GPIOPinRead(BSP_LED_BASE, BSP_LED_2))
|
|
||||||
+ #define HAL_STATE_LED3() (!GPIOPinRead(BSP_LED_BASE, BSP_LED_3))
|
|
||||||
+ #define HAL_STATE_LED4() (!GPIOPinRead(BSP_LED_BASE, BSP_LED_4))
|
|
||||||
+#else //Not a MODKAMRU board
|
|
||||||
+ #define HAL_STATE_LED1() GPIOPinRead(BSP_LED_BASE, BSP_LED_1)
|
|
||||||
+ #define HAL_STATE_LED2() GPIOPinRead(BSP_LED_BASE, BSP_LED_2)
|
|
||||||
+ #define HAL_STATE_LED3() GPIOPinRead(BSP_LED_BASE, BSP_LED_3)
|
|
||||||
+ #define HAL_STATE_LED4() GPIOPinRead(BSP_LED_BASE, BSP_LED_4)
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
#define HAL_PUSH_BUTTON1()(PUSH_BTN_POLARITY (GPIOPinRead(BSP_KEY_SEL_BASE, BSP_KEY_SELECT)))
|
|
||||||
|
|
||||||
diff --git a/Components/hal/target/CC2538ZNP/hal_led.c b/Components/hal/target/CC2538ZNP/hal_led.c
|
|
||||||
index 1a6e636..cf560e9 100644
|
|
||||||
--- a/Components/hal/target/CC2538ZNP/hal_led.c
|
|
||||||
+++ b/Components/hal/target/CC2538ZNP/hal_led.c
|
|
||||||
@@ -103,6 +103,18 @@ void HalLedOnOff (uint8 leds, uint8 mode);
|
|
||||||
* FUNCTIONS - API
|
|
||||||
***************************************************************************************************/
|
|
||||||
|
|
||||||
+#ifdef MODKAMRU_V3 // LED control helpers
|
|
||||||
+ // Dynamically enable/disable LEDs
|
|
||||||
+bool gbModkamUseLeds = true;
|
|
||||||
+void modkamUseLeds(bool enable){
|
|
||||||
+ gbModkamUseLeds=enable;
|
|
||||||
+ if(!enable)
|
|
||||||
+ HalLedSet(HAL_LED_ALL,HAL_LED_MODE_OFF);
|
|
||||||
+ else
|
|
||||||
+ HalLedSet(HAL_LED_1,HAL_LED_MODE_ON);// Light on power LED
|
|
||||||
+}
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/***************************************************************************************************
|
|
||||||
* @fn HalLedInit
|
|
||||||
*
|
|
||||||
diff --git a/Components/hal/target/CC2538ZNP/hal_uart_isr.c b/Components/hal/target/CC2538ZNP/hal_uart_isr.c
|
|
||||||
index a6ce62b..0e34aec 100644
|
|
||||||
--- a/Components/hal/target/CC2538ZNP/hal_uart_isr.c
|
|
||||||
+++ b/Components/hal/target/CC2538ZNP/hal_uart_isr.c
|
|
||||||
@@ -160,10 +160,17 @@ uint8 HalUARTOpenIsr(uint8 port, halUARTCfg_t *config)
|
|
||||||
|
|
||||||
if(config->flowControl)
|
|
||||||
{
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ IOCPinConfigPeriphOutput(GPIO_D_BASE, GPIO_PIN_1, IOC_MUX_OUT_SEL_UART1_RTS);
|
|
||||||
+ GPIOPinTypeUARTOutput(GPIO_D_BASE, GPIO_PIN_1);
|
|
||||||
+ IOCPinConfigPeriphInput(GPIO_B_BASE, GPIO_PIN_0, IOC_UARTCTS_UART1);
|
|
||||||
+ GPIOPinTypeUARTInput(GPIO_B_BASE, GPIO_PIN_0);
|
|
||||||
+#else
|
|
||||||
IOCPinConfigPeriphOutput(GPIO_D_BASE, GPIO_PIN_3, IOC_MUX_OUT_SEL_UART1_RTS);
|
|
||||||
GPIOPinTypeUARTOutput(GPIO_D_BASE, GPIO_PIN_3);
|
|
||||||
IOCPinConfigPeriphInput(GPIO_B_BASE, GPIO_PIN_0, IOC_UARTCTS_UART1);
|
|
||||||
GPIOPinTypeUARTInput(GPIO_B_BASE, GPIO_PIN_0);
|
|
||||||
+#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
IntEnable(HAL_UART_INT_CTRL);
|
|
||||||
@@ -364,11 +371,14 @@ uint16 HalUARTWriteIsr(uint8 port, uint8 *pBuffer, uint16 length)
|
|
||||||
cnt = idx - cnt;
|
|
||||||
}
|
|
||||||
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+#else
|
|
||||||
/* Accept "all-or-none" on write request. */
|
|
||||||
if (cnt < length)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
txMT = false;
|
|
||||||
idx = uartRecord.tx.bufferTail;
|
|
||||||
diff --git a/Components/mt/MT_SYS.c b/Components/mt/MT_SYS.c
|
|
||||||
index aa57766..9b3cb3d 100644
|
|
||||||
--- a/Components/mt/MT_SYS.c
|
|
||||||
+++ b/Components/mt/MT_SYS.c
|
|
||||||
@@ -73,7 +73,7 @@
|
|
||||||
#endif
|
|
||||||
#if (defined INCLUDE_REVISION_INFORMATION) && ((defined MAKE_CRC_SHDW) || (defined FAKE_CRC_SHDW)) //built for bootloader
|
|
||||||
#include "hal_flash.h"
|
|
||||||
- #include "sb_shared.h"
|
|
||||||
+ //#include "sb_shared.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/******************************************************************************
|
|
||||||
@@ -515,7 +515,7 @@ static void MT_SysVersion(void)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
osal_memcpy(verStr, (uint8 *)MTVersionString, sizeof(MTVersionString));
|
|
||||||
-
|
|
||||||
+/*
|
|
||||||
#if (defined MAKE_CRC_SHDW) || (defined FAKE_CRC_SHDW) //built for bootloader
|
|
||||||
HalFlashRead(SBL_SIG_ADDR / HAL_FLASH_PAGE_SIZE,
|
|
||||||
SBL_SIG_ADDR % HAL_FLASH_PAGE_SIZE,
|
|
||||||
@@ -537,6 +537,8 @@ static void MT_SysVersion(void)
|
|
||||||
// SBL is NOT supported
|
|
||||||
sblRev = 0xFFFFFFFF;
|
|
||||||
#endif
|
|
||||||
+*/
|
|
||||||
+ sblRev = 0xFFFFFFFF;
|
|
||||||
|
|
||||||
// Plug the SBL revision indication
|
|
||||||
UINT32_TO_BUF_LITTLE_ENDIAN(pBuf,sblRev);
|
|
||||||
diff --git a/Components/mt/MT_UTIL.c b/Components/mt/MT_UTIL.c
|
|
||||||
index b4a24d8..68d7ceb 100644
|
|
||||||
--- a/Components/mt/MT_UTIL.c
|
|
||||||
+++ b/Components/mt/MT_UTIL.c
|
|
||||||
@@ -921,6 +921,12 @@ static void MT_UtilLedControl(uint8 *pBuf)
|
|
||||||
/* LED and Mode */
|
|
||||||
iLed = *pBuf++;
|
|
||||||
iMode = *pBuf;
|
|
||||||
+
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ if(iMode==0)
|
|
||||||
+ modkamUseLeds(false);
|
|
||||||
+ else modkamUseLeds(true);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
if ( iLed == 1 )
|
|
||||||
Led = HAL_LED_1;
|
|
||||||
diff --git a/Components/mt/MT_VERSION.c b/Components/mt/MT_VERSION.c
|
|
||||||
index f374554..f2e3de9 100644
|
|
||||||
--- a/Components/mt/MT_VERSION.c
|
|
||||||
+++ b/Components/mt/MT_VERSION.c
|
|
||||||
@@ -69,7 +69,7 @@
|
|
||||||
*****************************************************************************/
|
|
||||||
const uint8 MTVersionString[] = {
|
|
||||||
2, /* Transport protocol revision */
|
|
||||||
- 0, /* Product ID */
|
|
||||||
+ 2, /* Product ID */
|
|
||||||
2, /* Software major release number */
|
|
||||||
7, /* Software minor release number */
|
|
||||||
2, /* Software maintenance release number */
|
|
||||||
diff --git a/Components/mt/revision_info.h b/Components/mt/revision_info.h
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..636ccc8
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/Components/mt/revision_info.h
|
|
||||||
@@ -0,0 +1 @@
|
|
||||||
+#define CODE_REVISION_NUMBER 20200211
|
|
||||||
\ No newline at end of file
|
|
||||||
diff --git a/Components/osal/mcu/cc2538/osal_nv.c b/Components/osal/mcu/cc2538/osal_nv.c
|
|
||||||
index 9275e64..7e2fee5 100644
|
|
||||||
--- a/Components/osal/mcu/cc2538/osal_nv.c
|
|
||||||
+++ b/Components/osal/mcu/cc2538/osal_nv.c
|
|
||||||
@@ -62,7 +62,7 @@
|
|
||||||
* $PROJ_DIR$\..\..\..\Tools\"Processor Specific Name"\"Specific Name".xcl
|
|
||||||
*/
|
|
||||||
#ifndef OSAL_NV_PHY_PER_PG
|
|
||||||
- #define OSAL_NV_PHY_PER_PG 1
|
|
||||||
+ #define OSAL_NV_PHY_PER_PG 2
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define OSAL_NV_PAGES_USED (HAL_NV_PAGE_CNT / OSAL_NV_PHY_PER_PG)
|
|
||||||
diff --git a/Components/stack/af/AF.c b/Components/stack/af/AF.c
|
|
||||||
index 5e54237..c88b195 100644
|
|
||||||
--- a/Components/stack/af/AF.c
|
|
||||||
+++ b/Components/stack/af/AF.c
|
|
||||||
@@ -405,10 +405,18 @@ void afIncomingData( aps_FrameFormat_t *aff, zAddrType_t *SrcAddress, uint16 Src
|
|
||||||
#if !defined ( APS_NO_GROUPS )
|
|
||||||
// Find the first endpoint for this group
|
|
||||||
grpEp = aps_FindGroupForEndpoint( aff->GroupID, APS_GROUPS_FIND_FIRST );
|
|
||||||
- if ( grpEp == APS_GROUPS_EP_NOT_FOUND )
|
|
||||||
- return; // No endpoint found
|
|
||||||
+ if ( grpEp == APS_GROUPS_EP_NOT_FOUND ) {
|
|
||||||
+ // No endpoint found, default to endpoint 1.
|
|
||||||
+ // In the original source code there is a return here.
|
|
||||||
+ // This prevent the messags from being forwarded.
|
|
||||||
+ // For our use-case we want to capture all messages.
|
|
||||||
+ // Even if the coordinator is not in the group.
|
|
||||||
+ epDesc = afFindEndPointDesc( 1 );
|
|
||||||
+ }
|
|
||||||
+ else {
|
|
||||||
+ epDesc = afFindEndPointDesc( grpEp );
|
|
||||||
+ }
|
|
||||||
|
|
||||||
- epDesc = afFindEndPointDesc( grpEp );
|
|
||||||
if ( epDesc == NULL )
|
|
||||||
return; // Endpoint descriptor not found
|
|
||||||
|
|
||||||
@@ -425,6 +433,12 @@ void afIncomingData( aps_FrameFormat_t *aff, zAddrType_t *SrcAddress, uint16 Src
|
|
||||||
epDesc = pList->epDesc;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ else if ( aff->DstEndPoint == 10 || aff->DstEndPoint == 11 ) {
|
|
||||||
+ if ( (epDesc = afFindEndPointDesc( 1 )) )
|
|
||||||
+ {
|
|
||||||
+ pList = afFindEndPointDescList( epDesc->endPoint );
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
else if ( (epDesc = afFindEndPointDesc( aff->DstEndPoint )) )
|
|
||||||
{
|
|
||||||
pList = afFindEndPointDescList( epDesc->endPoint );
|
|
||||||
diff --git a/Components/stack/bdb/bdb_FindingAndBinding.c b/Components/stack/bdb/bdb_FindingAndBinding.c
|
|
||||||
index 1b4f72c..7695d9f 100644
|
|
||||||
--- a/Components/stack/bdb/bdb_FindingAndBinding.c
|
|
||||||
+++ b/Components/stack/bdb/bdb_FindingAndBinding.c
|
|
||||||
@@ -624,6 +624,9 @@ void bdb_ProcessSimpleDesc( zdoIncomingMsg_t *msgPtr )
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//Save the simple desc to don't ask for it again
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ bdb_zclSimpleDescClusterListClean( &bdb_FindingBindingTargetSimpleDesc );
|
|
||||||
+#endif
|
|
||||||
pCurr->SimpleDescriptor = &bdb_FindingBindingTargetSimpleDesc;
|
|
||||||
}
|
|
||||||
(void)extAddr; //dummy
|
|
||||||
diff --git a/Components/stack/nwk/nwk_globals.c b/Components/stack/nwk/nwk_globals.c
|
|
||||||
index eb436ae..8b43ae5 100644
|
|
||||||
--- a/Components/stack/nwk/nwk_globals.c
|
|
||||||
+++ b/Components/stack/nwk/nwk_globals.c
|
|
||||||
@@ -71,10 +71,17 @@
|
|
||||||
* CONSTANTS
|
|
||||||
*/
|
|
||||||
// Maximums for the data buffer queue
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+#define NWK_MAX_DATABUFS_WAITING 80 // Waiting to be sent to MAC
|
|
||||||
+#define NWK_MAX_DATABUFS_SCHEDULED 50 // Timed messages to be sent
|
|
||||||
+#define NWK_MAX_DATABUFS_CONFIRMED 50 // Held after MAC confirms
|
|
||||||
+#define NWK_MAX_DATABUFS_TOTAL 255 // Total number of buffers
|
|
||||||
+#else
|
|
||||||
#define NWK_MAX_DATABUFS_WAITING 8 // Waiting to be sent to MAC
|
|
||||||
#define NWK_MAX_DATABUFS_SCHEDULED 5 // Timed messages to be sent
|
|
||||||
#define NWK_MAX_DATABUFS_CONFIRMED 5 // Held after MAC confirms
|
|
||||||
#define NWK_MAX_DATABUFS_TOTAL 12 // Total number of buffers
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
// 1-255 (0 -> 256) X RTG_TIMER_INTERVAL
|
|
||||||
// A known shortcoming is that when a message is enqueued as "hold" for a
|
|
||||||
diff --git a/Components/stack/sys/ZGlobals.c b/Components/stack/sys/ZGlobals.c
|
|
||||||
index d170283..e251f15 100644
|
|
||||||
--- a/Components/stack/sys/ZGlobals.c
|
|
||||||
+++ b/Components/stack/sys/ZGlobals.c
|
|
||||||
@@ -212,7 +212,10 @@ uint8 zgEndDeviceConfiguration = END_DEV_CONFIGURATION;
|
|
||||||
//
|
|
||||||
// NOTICE: Before enabling Child Aging make sure to review all the related
|
|
||||||
// definitions in this file, especially zgNwkParentInformation.
|
|
||||||
-uint8 zgChildAgingEnable = TRUE;
|
|
||||||
+/**
|
|
||||||
+ * Disable child aging, otherwise Xiaomi devices are being kicked off the network.
|
|
||||||
+ */
|
|
||||||
+uint8 zgChildAgingEnable = FALSE;
|
|
||||||
|
|
||||||
//========== TouchLink NWK configuration ===============
|
|
||||||
// Values used by Router when starts a network as initiator
|
|
||||||
diff --git a/Components/stack/zdo/ZDObject.c b/Components/stack/zdo/ZDObject.c
|
|
||||||
index dcb6efa..29c8adc 100644
|
|
||||||
--- a/Components/stack/zdo/ZDObject.c
|
|
||||||
+++ b/Components/stack/zdo/ZDObject.c
|
|
||||||
@@ -76,6 +76,10 @@
|
|
||||||
/* HAL */
|
|
||||||
#include "hal_lcd.h"
|
|
||||||
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+#include "hal_led.h"
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/*********************************************************************
|
|
||||||
* MACROS
|
|
||||||
*/
|
|
||||||
@@ -1957,6 +1961,12 @@ void ZDO_ProcessMgmtPermitJoinReq( zdoIncomingMsg_t *inMsg )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
duration = inMsg->asdu[ZDP_MGMT_PERMIT_JOIN_REQ_DURATION];
|
|
||||||
+
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ if(duration==0)
|
|
||||||
+ MODKAM_LED_OFF(HAL_LED_3)
|
|
||||||
+ else MODKAM_LED_BLINK(HAL_LED_3,duration/2,50,2000)
|
|
||||||
+#endif
|
|
||||||
// Per R21 Spec this field is not longer relevant 2.4.3.3.7.2 (Mgmt_Permit_Joining_req Effect on Receipt)
|
|
||||||
//tcsig = inMsg->asdu[ZDP_MGMT_PERMIT_JOIN_REQ_TC_SIG];
|
|
||||||
|
|
||||||
diff --git a/Components/zmac/ZMAC.h b/Components/zmac/ZMAC.h
|
|
||||||
index d658113..f4e7142 100644
|
|
||||||
--- a/Components/zmac/ZMAC.h
|
|
||||||
+++ b/Components/zmac/ZMAC.h
|
|
||||||
@@ -458,7 +458,10 @@ typedef enum
|
|
||||||
TX_PWR_PLUS_16,
|
|
||||||
TX_PWR_PLUS_17,
|
|
||||||
TX_PWR_PLUS_18,
|
|
||||||
- TX_PWR_PLUS_19
|
|
||||||
+ TX_PWR_PLUS_19,
|
|
||||||
+ TX_PWR_PLUS_20,
|
|
||||||
+ TX_PWR_PLUS_21,
|
|
||||||
+ TX_PWR_PLUS_22
|
|
||||||
} ZMacTransmitPower_t; // The transmit power in units of -1 dBm.
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
diff --git a/Projects/zstack/Tools/CC2538DB/CC2538.icf b/Projects/zstack/Tools/CC2538DB/CC2538.icf
|
|
||||||
index d4c95cc..cb8abf6 100644
|
|
||||||
--- a/Projects/zstack/Tools/CC2538DB/CC2538.icf
|
|
||||||
+++ b/Projects/zstack/Tools/CC2538DB/CC2538.icf
|
|
||||||
@@ -15,7 +15,7 @@ define memory mem with size = 4G;
|
|
||||||
//
|
|
||||||
// Define a region for the on-chip program code space.
|
|
||||||
//
|
|
||||||
-define region FLASH = mem:[from 0x00200000 to 0x0027C7FF];
|
|
||||||
+define region FLASH = mem:[from 0x00200000 to 0x002797FF];
|
|
||||||
|
|
||||||
//
|
|
||||||
// Define a region for the OTA CRC structure.
|
|
||||||
@@ -39,7 +39,7 @@ define region FLASH = mem:[from 0x00200000 to 0x0027C7FF];
|
|
||||||
// The size of this region MUST MATCH the size defined by "HAL_NV_PAGE_CNT"
|
|
||||||
// in the file: hal_board_cfg.h
|
|
||||||
//
|
|
||||||
-define region NV_MEM = mem:[from 0x0027C800 to 0x0027F7FF];
|
|
||||||
+define region NV_MEM = mem:[from 0x00279800 to 0x0027F7FF];
|
|
||||||
|
|
||||||
//
|
|
||||||
// Define regions for on-chip factory Commissioning Parameters.
|
|
||||||
@@ -87,7 +87,7 @@ define region FLASH_LCK = mem:[from 0x0027FFE0 to 0x0027FFFF];
|
|
||||||
//
|
|
||||||
// Define a region for the on-chip SRAM.
|
|
||||||
//
|
|
||||||
-define region SRAM = mem:[from 0x20004000 to 0x20007FFF];
|
|
||||||
+define region SRAM = mem:[from 0x20000000 to 0x20007FFF];
|
|
||||||
|
|
||||||
//
|
|
||||||
// Define a block for the heap. The size should be set to something other
|
|
||||||
diff --git a/Projects/zstack/Tools/CC2538DB/f8wConfig.cfg b/Projects/zstack/Tools/CC2538DB/f8wConfig.cfg
|
|
||||||
index 9d2c1bf..328cbbb 100644
|
|
||||||
--- a/Projects/zstack/Tools/CC2538DB/f8wConfig.cfg
|
|
||||||
+++ b/Projects/zstack/Tools/CC2538DB/f8wConfig.cfg
|
|
||||||
@@ -119,7 +119,7 @@
|
|
||||||
-DMAX_POLL_FAILURE_RETRIES=2
|
|
||||||
|
|
||||||
/* The number of items in the broadcast table */
|
|
||||||
--DMAX_BCAST=9
|
|
||||||
+//-DMAX_BCAST=9
|
|
||||||
|
|
||||||
/* The maximum number of groups in the groups table */
|
|
||||||
-DAPS_MAX_GROUPS=16
|
|
||||||
diff --git a/Projects/zstack/ZMain/TI2538ZNP/OnBoard.h b/Projects/zstack/ZMain/TI2538ZNP/OnBoard.h
|
|
||||||
index 02bce67..3271563 100644
|
|
||||||
--- a/Projects/zstack/ZMain/TI2538ZNP/OnBoard.h
|
|
||||||
+++ b/Projects/zstack/ZMain/TI2538ZNP/OnBoard.h
|
|
||||||
@@ -120,10 +120,17 @@ extern uint8 aExtendedAddress[8];
|
|
||||||
/* SOC defines the ideal sizes in the
|
|
||||||
* individual _hal_uart_dma/isr.c modules.
|
|
||||||
*/
|
|
||||||
-#define HAL_UART_FLOW_THRESHOLD 5
|
|
||||||
-#define HAL_UART_RX_BUF_SIZE 170
|
|
||||||
-#define HAL_UART_TX_BUF_SIZE 120
|
|
||||||
-#define HAL_UART_IDLE_TIMEOUT 5
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ #define HAL_UART_FLOW_THRESHOLD 10
|
|
||||||
+ #define HAL_UART_RX_BUF_SIZE 340
|
|
||||||
+ #define HAL_UART_TX_BUF_SIZE 240
|
|
||||||
+ #define HAL_UART_IDLE_TIMEOUT 10
|
|
||||||
+#else
|
|
||||||
+ #define HAL_UART_FLOW_THRESHOLD 5
|
|
||||||
+ #define HAL_UART_RX_BUF_SIZE 170
|
|
||||||
+ #define HAL_UART_TX_BUF_SIZE 120
|
|
||||||
+ #define HAL_UART_IDLE_TIMEOUT 5
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
/* Restart system from absolute beginning
|
|
||||||
* Disables interrupts, forces WatchDog reset
|
|
||||||
diff --git a/Projects/zstack/ZMain/TI2538ZNP/ZMain.c b/Projects/zstack/ZMain/TI2538ZNP/ZMain.c
|
|
||||||
index 5febd92..0d3a44f 100644
|
|
||||||
--- a/Projects/zstack/ZMain/TI2538ZNP/ZMain.c
|
|
||||||
+++ b/Projects/zstack/ZMain/TI2538ZNP/ZMain.c
|
|
||||||
@@ -48,6 +48,10 @@
|
|
||||||
#include "OnBoard.h"
|
|
||||||
#include "ZMAC.h"
|
|
||||||
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ #include "hal_led.h"
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
#ifndef NONWK
|
|
||||||
#include "AF.h"
|
|
||||||
#endif
|
|
||||||
@@ -160,6 +164,13 @@ int main( void )
|
|
||||||
/* If WDT is used, this is a good place to enable it. */
|
|
||||||
WatchDogEnable( WDTIMX );
|
|
||||||
#endif
|
|
||||||
+
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ // Test all LEDs
|
|
||||||
+ MODKAM_LED_BLINK_LONG(HAL_LED_ALL);
|
|
||||||
+ // Power LED on
|
|
||||||
+ MODKAM_LED_ON(HAL_LED_1);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
osal_start_system(); /* No Return from here */
|
|
||||||
|
|
||||||
diff --git a/Projects/zstack/ZNP/Source/znp.cfg b/Projects/zstack/ZNP/Source/znp.cfg
|
|
||||||
index 2b8d56d..b7fc48a 100644
|
|
||||||
--- a/Projects/zstack/ZNP/Source/znp.cfg
|
|
||||||
+++ b/Projects/zstack/ZNP/Source/znp.cfg
|
|
||||||
@@ -107,3 +107,38 @@
|
|
||||||
-DMT_APP_FUNC
|
|
||||||
-DMT_APP_CNF_FUNC
|
|
||||||
|
|
||||||
+//Additional flags
|
|
||||||
+-DMODKAMRU_V3
|
|
||||||
+
|
|
||||||
+-DINCLUDE_REVISION_INFORMATION
|
|
||||||
+-DMT_SYS_KEY_MANAGEMENT=1
|
|
||||||
+-DTP2_LEGACY_ZC
|
|
||||||
+-DMULTICAST_ENABLED=FALSE
|
|
||||||
+
|
|
||||||
+//-DHAL_PA_LNA
|
|
||||||
+-DHAL_PA_LNA_CC2592
|
|
||||||
+-DHAL_LED=TRUE
|
|
||||||
+-DBLINK_LEDS
|
|
||||||
+-DHAL_LCD=FALSE
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+/* Large netrowk optimizations (MTO, Source Routing) */
|
|
||||||
+-DINT_HEAP_LEN=12288
|
|
||||||
+-DNWK_MAX_DEVICE_LIST=80
|
|
||||||
+-DCONCENTRATOR_ENABLE=TRUE
|
|
||||||
+-DCONCENTRATOR_DISCOVERY_TIME=120
|
|
||||||
+-DMAX_RTG_SRC_ENTRIES=400
|
|
||||||
+-DMAX_NEIGHBOR_ENTRIES=100
|
|
||||||
+-DSRC_RTG_EXPIRY_TIME=10
|
|
||||||
+-DCONCENTRATOR_ROUTE_CACHE=TRUE
|
|
||||||
+-DMTO_RREQ_LIMIT_TIME=5000
|
|
||||||
+
|
|
||||||
+-DLINK_DOWN_TRIGGER=6
|
|
||||||
+-DNWK_ROUTE_AGE_LIMIT=12
|
|
||||||
+-DBCAST_DELIVERY_TIME=100
|
|
||||||
+-DMAX_BCAST=12
|
|
||||||
+//-DDEF_NWK_RADIUS=15
|
|
||||||
+//-DDEFAULT_ROUTE_REQUEST_RADIUS=8
|
|
||||||
+-DROUTE_DISCOVERY_TIME=13
|
|
||||||
+//-DZDNWKMGR_MIN_TRANSMISSIONS=0
|
|
||||||
+-DNWK_LINK_STATUS_PERIOD=60
|
|
||||||
diff --git a/Projects/zstack/ZNP/Source/znp_app.c b/Projects/zstack/ZNP/Source/znp_app.c
|
|
||||||
index 31b115e..f7ada93 100644
|
|
||||||
--- a/Projects/zstack/ZNP/Source/znp_app.c
|
|
||||||
+++ b/Projects/zstack/ZNP/Source/znp_app.c
|
|
||||||
@@ -67,6 +67,10 @@
|
|
||||||
#include "zcl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ #include "hal_led.h"
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
/* ------------------------------------------------------------------------------------------------
|
|
||||||
* Local Functions
|
|
||||||
* ------------------------------------------------------------------------------------------------
|
|
||||||
@@ -156,6 +160,10 @@ void znpInit(uint8 taskId)
|
|
||||||
*/
|
|
||||||
uint16 znpEventLoop(uint8 taskId, uint16 events)
|
|
||||||
{
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ MODKAM_LED_BLINK_SHORT(HAL_LED_4);
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
osal_event_hdr_t *pMsg;
|
|
||||||
#if !defined CC2531ZNP
|
|
||||||
uint8 *pBuf;
|
|
||||||
@@ -406,7 +414,7 @@ static void npInit(void)
|
|
||||||
MT_UartRegisterTaskID(znpTaskId);
|
|
||||||
|
|
||||||
#ifdef HAL_PA_LNA_CC2592
|
|
||||||
- ZMacSetTransmitPower(TX_PWR_PLUS_19);
|
|
||||||
+ ZMacSetTransmitPower(TX_PWR_PLUS_22);
|
|
||||||
#else
|
|
||||||
ZMacSetTransmitPower(TX_PWR_PLUS_4);
|
|
||||||
#endif
|
|
||||||
@@ -508,6 +516,18 @@ static void npBasicRsp(void)
|
|
||||||
*/
|
|
||||||
static void npUartCback(uint8 port, uint8 event)
|
|
||||||
{
|
|
||||||
+#ifdef MODKAMRU_V3
|
|
||||||
+ // There can be multiple event bits in event argument
|
|
||||||
+ if(
|
|
||||||
+ (event & HAL_UART_RX_FULL) ||
|
|
||||||
+ (event & HAL_UART_RX_ABOUT_FULL) ||
|
|
||||||
+ (event & HAL_UART_RX_TIMEOUT)
|
|
||||||
+ ){
|
|
||||||
+ MT_UartProcessZToolData(port, znpTaskId);
|
|
||||||
+ }else if(event & HAL_UART_TX_EMPTY){
|
|
||||||
+ osal_set_event(znpTaskId, ZNP_UART_TX_READY_EVENT);
|
|
||||||
+ }
|
|
||||||
+#else
|
|
||||||
switch (event) {
|
|
||||||
case HAL_UART_RX_FULL:
|
|
||||||
case HAL_UART_RX_ABOUT_FULL:
|
|
||||||
@@ -522,6 +542,7 @@ static void npUartCback(uint8 port, uint8 event)
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
+#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/**************************************************************************************************
|
|
||||||
diff --git a/note.txt b/note.txt
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..91122c7
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/note.txt
|
|
||||||
@@ -0,0 +1,15 @@
|
|
||||||
+Preprocessor:
|
|
||||||
+ USB:
|
|
||||||
+ - HAL_UART_USB
|
|
||||||
+ - xHAL_UART=TRUE
|
|
||||||
+ - xZNP_ALT
|
|
||||||
+ UART FC:
|
|
||||||
+ - xHAL_UART_USB
|
|
||||||
+ - HAL_UART=TRUE
|
|
||||||
+ - xZNP_ALT
|
|
||||||
+ UART no FC:
|
|
||||||
+ - xHAL_UART_USB
|
|
||||||
+ - HAL_UART=TRUE
|
|
||||||
+ - ZNP_ALT
|
|
||||||
+
|
|
||||||
+
|
|
@ -1,13 +1,13 @@
|
|||||||
# Buttons
|
# Buttons
|
||||||
|
|
||||||
The S1 button only changes the state of the green LED.
|
* S1 button: only changes the state of the green LED.
|
||||||
The S2 button repairs CC2531 (see below)
|
* S2 button: repairs CC2531 (see below)
|
||||||
|
|
||||||
# Lights
|
# Lights
|
||||||
|
|
||||||
Short fast blinks (one per second) – the router is connecting to a network.
|
* Short fast blinks (one per second) – the router is connecting to a network.
|
||||||
Short long blinks (one per 4 seconds) – normal operations.
|
* Short long blinks (one per 4 seconds) – normal operations.
|
||||||
Three short blinks – the router cannot send a report to a coordinator.
|
* Three short blinks – the router cannot send a report to a coordinator.
|
||||||
|
|
||||||
# Pairing
|
# Pairing
|
||||||
|
|
||||||
@ -15,5 +15,5 @@ Flash firmware and permit joining to a network on your coordinator.
|
|||||||
|
|
||||||
# Re-pairing
|
# Re-pairing
|
||||||
|
|
||||||
CC2530, CC2531: Power on, wait 2 seconds, power off, repeat this cycle three times.
|
* CC2530, CC2531: Power on, wait 2 seconds, power off, repeat this cycle three times.
|
||||||
CC2531: Power on, press and hold down the S2 button for 5 seconds.
|
* CC2531: Power on, press and hold down the S2 button for 5 seconds.
|
||||||
|
Loading…
Reference in New Issue
Block a user