Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of HelloWorld_IDS01A4 by
Diff: main.cpp
- Revision:
- 1:cf2e2f85bf8d
- Parent:
- 0:2ddc0583bcec
- Child:
- 2:a0677b17a570
diff -r 2ddc0583bcec -r cf2e2f85bf8d main.cpp
--- a/main.cpp Thu May 25 16:38:55 2017 +0000
+++ b/main.cpp Mon Jun 19 08:23:08 2017 +0000
@@ -4,7 +4,7 @@
* @author Rosarium PILA, STMicroelectronics
* @version V1.0.0
* @date May 17th, 2017
- * @brief mbed HelloWorld P2P example for the STMicroelectronics X-NUCLEO-IDB01A4/5
+ * @brief mbed Hello World test application for the STMicroelectronics X-NUCLEO-IDB01A4/5
* Spirit1 Expansion Board
******************************************************************************
* @attention
@@ -39,69 +39,61 @@
#include "mbed.h"
#include "SimpleSpirit1.h"
-#define TEST_STR_LEN (32) //512
+#define TEST_STR_LEN (32)
static uint8_t send_buf[TEST_STR_LEN] ={'S','P','I','R','I','T','1',' ','H','E','L','L','O',' ','W','O','R','L','D',' ','P','2','P',' ','D','E','M','O'};
static uint8_t read_buf[TEST_STR_LEN] ={'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'};
-
-#define PCKT_MARGIN (2) //32
+
+static SimpleSpirit1 &myspirit = SimpleSpirit1::CreateInstance(D11, D12, D3, D9, D10, D2); //RPi: (SPI_CLK) = (D13:PA5:resistorR7 --> D3:PB3:resistorR4)
-//#define SIGNAL_BIT (0x1) //RPi //Removed OS dependency for mbed classic
-//static osThreadId main_thread_id; //RPi //Removed OS dependency for mbed classic
+volatile bool rx_done_flag = 0;
+volatile bool tx_done_flag = 0;
-
-static SimpleSpirit1 &myspirit = SimpleSpirit1::CreateInstance(D11, D12, D3, D9, D10, D2); //RPi
-bool SIGNAL_BIT = 0; //RPi
static int curr_len = 0;
unsigned char myValue = 0;
-InterruptIn event(USER_BUTTON); //RPi //Added interrupt event to give userinterface to send pkt.
+InterruptIn event(USER_BUTTON); //RPi : //Added interrupt event to give userinterface to send pkt.
+/**
+ * @brief callback_func
+ * @param callback event
+ * @retval None.
+ */
static void callback_func(int event)
{
- if(event == SimpleSpirit1::RX_DONE) {
-// osSignalSet(main_thread_id, SIGNAL_BIT); //RPi //Removed OS dependency for mbed classic
- SIGNAL_BIT = 1;
- } else if (event != SimpleSpirit1::TX_DONE) {
- printf("Got unexpected event %d\r\n", event);
- } else {
- printf("TX done!\n\r\n");
- }
+ if(event == SimpleSpirit1::RX_DONE)
+ {
+ rx_done_flag = 1;
+ }
+ else if (event == SimpleSpirit1::TX_DONE)
+ {
+ tx_done_flag = 1;
+ }
}
+
+/**
+ * @brief send_data
+ * @param None
+ * @retval None
+ */
void send_data(void)
-{
- int cnt = 0;
- cnt++;
- if(cnt >= MAX_PACKET_LEN) cnt = 0;
+{
+ printf("\r\n***Sending a packet***\r\n");
- printf("\r\n***Sending a packet***\r\nSent string ='%s' (len=%d)\n\r", send_buf, strlen((const char*)send_buf) + 1);
-
- uint32_t before_cca = us_ticker_read();
while(myspirit.is_receiving()); // wait for ongoing RX ends
- uint32_t after_cca = us_ticker_read();
-
+
curr_len = strlen((const char*)send_buf) + 1;
myspirit.send(send_buf, curr_len);
- uint32_t after_send = us_ticker_read();
-
- printf("CCA time: %uus\n", (unsigned int)(after_cca - before_cca));
- printf("Send time: %uus\n\r", (unsigned int)(after_send - after_cca));
}
-
+/**
+ * @brief main routine
+ * @param None
+ * @retval int
+ */
int main()
-{
- // osStatus ret; //RPi //Removed OS dependency for mbed classic
-
- unsigned int pckts_fails = 0;
- unsigned int first_failed_packet = 0;
- unsigned int last_failed_packet = 0;
- int validate_cnt = -1;
-
- // main_thread_id = Thread::gettid(); //RPi //Removed OS dependency for mbed classic
-
-
- DigitalOut TestLED = D5; //RPi //LED of IDS01A4/5
- TestLED = 0; //RPi //LED off
+{
+ DigitalOut TestLED = D5; //RPi //LED of IDS01A4/5
+ TestLED = 0; //RPi //LED off
myspirit.attach_irq_callback(callback_func);
@@ -110,48 +102,35 @@
printf("\n**************HelloWorld mbed demo for Spirit1 (X-NUCLEO-IDS01A4/5)**************\r\n");
printf("\nPress User Button on one of the two boards to send a packaet to the other and the LED D1 on the receiver X-NUCLEO-IDS01A4/5 should toggle \n\r\n");
+ event.rise(&send_data); //RPi: User button interrupt trigger to send data
+
while(1)
{
-
- event.rise(&send_data); //RPi // Added User button interrupt trigger to send data
+ __WFE(); // low power in idle condition., waiting for an event
- if(SIGNAL_BIT) //RPi //Data pkt received
+ if(rx_done_flag)
{
- SIGNAL_BIT = 0;
-
- for(unsigned int flush_count = 0; flush_count < TEST_STR_LEN; flush_count++) read_buf[flush_count] = 0 ;//RPi//clear the read buffer
+ rx_done_flag = 0;
+
+ for(unsigned int flush_count = 0; flush_count < TEST_STR_LEN; flush_count++) read_buf[flush_count] = 0 ;//RPi:clear the read buffer
int ret = myspirit.read(read_buf, sizeof(read_buf));
- myValue = 1 - myValue; //RPi //Toggle LED at the receiver
- TestLED = myValue; //RPi //Toggle LED at the receiver
+ myValue = 1 - myValue;
+ TestLED = myValue; //RPi: Toggle LED at the receiver
if(ret == 0) {
printf("\nNothing to read\n\r");
continue;
}
- int len = strlen((const char*)read_buf) + 1;
- if(validate_cnt < 0) {
- validate_cnt = ret;
- } else {
- validate_cnt++;
- if(validate_cnt > MAX_PACKET_LEN) validate_cnt = 1;
- }
-
- if(ret != len) {
- pckts_fails++;
- if((ret > (int)(first_failed_packet + PCKT_MARGIN) || (ret < (int)(first_failed_packet - PCKT_MARGIN)))) {
- first_failed_packet = ret;
- }
- last_failed_packet = ret;
- }
-
printf("\r\n***Received a packet***\r\n\rReceived string = '%s' (len=%d) \n\r", read_buf, ret);
- printf("RSSI: %f, LQI: %u\r\n", myspirit.get_last_rssi_dbm(), (unsigned int)myspirit.get_last_sqi());
- printf("Packets failed:\t%d\t(ff=%d, lf=%d)\r\n", pckts_fails, first_failed_packet, last_failed_packet);
-
- while(myspirit.is_receiving()); // wait for ongoing RX ends
- }
+ }
+
+ else if (tx_done_flag)
+ {
+ tx_done_flag = 0;
+ printf("\r\n***Packet sent***\r\nSent string ='%s' (len=%d)\n\r", send_buf, strlen((const char*)send_buf) + 1);
+ }
}
myspirit.off();
