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.
Diff: main.cpp
- Revision:
- 0:94e73eda8cda
diff -r 000000000000 -r 94e73eda8cda main.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp Sat Dec 11 16:24:27 2021 +0000
@@ -0,0 +1,248 @@
+
+/*
+ * Program implements MQTT client on a NUCLEO-L476RG board
+ * using arm mbed-mqtt library and ESP-WROOM-02 WiFi modem.
+ *
+ * University of Belgrade - School of Electrical Engineering
+ * Department of Electronics
+ * Bulevar Kralja Aleksandra 73, 11120 Belgrade, Serbia
+ *
+ * November 2021.
+ *
+ */
+
+#include "mbed.h"
+#include "mb_pins.h"
+#include "platform/mbed_thread.h"
+#include "MQTTClientMbedOs.h"
+
+
+// LED2 blinking rate:
+#define BLINKING_RATE_MS 250
+// Scaler to 3v3L
+#define VOLTAGE_SCALER 3.3f
+// Client yield timeout in miliseconds:
+#define YIELD_TIMEOUT_MS 1000
+// Maximum number of networks to scan for:
+#define MAX_NETWORKS 15
+// Small delay for network information printing:
+#define PRINTF_DELAY_MS 10
+
+
+// Left potentiometer:
+AnalogIn pot1(MB_POT1);
+// Left button on the motherboard:
+InterruptIn sw1(MB_SW1);
+// Right LED on the motherboard:
+DigitalOut led2(MB_LED2);
+// Pointer to a WiFi network object:
+WiFiInterface *wifi;
+// Creating TCP socket:
+TCPSocket socket;
+// Creating MQTT client using the TCP socket;
+MQTTClient client(&socket);
+// Message handler:
+MQTT::Message message;
+
+char* topic = "pubpim";
+char* topic_sub = "subpim";
+// Counter of arrived messages:
+int arrivedcount = 0;
+// Flag indicating that button is not pressed:
+int button_pressed=0;
+// HiveMQ broker connectivity information:
+const char* hostname = "broker.hivemq.com";
+int port = 1883;
+// Returning a string for a provided network encryption:
+const char *sec2str(nsapi_security_t sec)
+{
+ switch (sec)
+ {
+ case NSAPI_SECURITY_NONE:
+ return "None";
+ case NSAPI_SECURITY_WEP:
+ return "WEP";
+ case NSAPI_SECURITY_WPA:
+ return "WPA";
+ case NSAPI_SECURITY_WPA2:
+ return "WPA2";
+ case NSAPI_SECURITY_WPA_WPA2:
+ return "WPA/WPA2";
+ case NSAPI_SECURITY_UNKNOWN:
+ default:
+ return "Unknown";
+ }
+}
+
+int scan_networks(WiFiInterface *wifi)
+{
+ printf("Scan:\n");
+
+ // Scan only for the number of networks, first parameter is NULL:
+ int count = wifi->scan(NULL, 0);
+ // If there are no networks, count == 0, if there is an error, counter < 0:
+ if (count <= 0)
+ {
+ printf("scan() failed with return value: %d\n", count);
+ return 0;
+ }
+
+ // Limit number of network arbitrary to some reasonable number:
+ count = count < MAX_NETWORKS ? count : MAX_NETWORKS;
+
+ // Create a local pointer to an object, which is an array of WiFi APs:
+ WiFiAccessPoint *ap = new WiFiAccessPoint[count];
+ // Now scan again for 'count' networks and populate the array of APs:
+ count = wifi->scan(ap, count);
+
+ // This time, the number of entries to 'ap' is returned:
+ if (count <= 0)
+ {
+ printf("scan() failed with return value: %d\n", count);
+ return 0;
+ }
+
+ // Print out the parameters of each AP:
+ for (int i = 0; i < count; i++)
+ {
+ printf("Network: %s secured: %s BSSID: %hhX:%hhX:%hhX:%hhx:%hhx:%hhx RSSI: %hhd Ch: %hhd\n", ap[i].get_ssid(),
+ sec2str(ap[i].get_security()), ap[i].get_bssid()[0], ap[i].get_bssid()[1], ap[i].get_bssid()[2],
+ ap[i].get_bssid()[3], ap[i].get_bssid()[4], ap[i].get_bssid()[5], ap[i].get_rssi(), ap[i].get_channel());
+ thread_sleep_for(PRINTF_DELAY_MS);
+ }
+ printf("%d networks available.\n", count);
+
+ // Since 'ap' is dynamically allocated pointer to the array of objects, it
+ // needs to be deleted:
+ delete[] ap;
+ return count;
+}
+
+void messageArrived(MQTT::MessageData& md)
+{
+ MQTT::Message &message = md.message;
+ //printf("Message arrived: qos %d, retained %d, dup %d, packetid %d\r\n", message.qos, message.retained, message.dup, message.id);
+ printf("Message from the browser: %.*s\r\n", message.payloadlen, (char*)message.payload);
+ ++arrivedcount;
+}
+
+void buttonFunction() {
+
+ button_pressed=1;
+
+}
+
+int main()
+{
+ // Set the interrupt event:
+ sw1.fall(&buttonFunction);
+
+ // Create a default network interface:
+ wifi = WiFiInterface::get_default_instance();
+ if (!wifi) {
+ printf("ERROR: No WiFiInterface found.\n");
+ return -1;
+ }
+
+ // Scan for available networks and aquire information about Access Points:
+ int count = scan_networks(wifi);
+ if (count == 0) {
+ printf("No WIFI APs found - can't continue further.\n");
+ return -1;
+ }
+
+ // Connect to the network with the parameters specified in 'mbed_app.json':
+ printf("\nConnecting to %s...\n", MBED_CONF_APP_WIFI_SSID);
+ int ret = wifi->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2);
+ if (ret != 0) {
+ printf("\nConnection error: %d\n", ret);
+ return -1;
+ }
+
+ // Print out the information aquired:
+ printf("Success\n\n");
+ printf("MAC: %s\n", wifi->get_mac_address());
+ printf("IP: %s\n", wifi->get_ip_address());
+ printf("Netmask: %s\n", wifi->get_netmask());
+ printf("Gateway: %s\n", wifi->get_gateway());
+ printf("RSSI: %d\n\n", wifi->get_rssi());
+
+ // Open TCP socket using WiFi network interface:
+ socket.open(wifi);
+ // Connect to the HiveMQ broker:
+ socket.connect(hostname, port);
+ // Fill connect data with default values:
+ MQTTPacket_connectData data = MQTTPacket_connectData_initializer;
+ // Change only ID and protocol version:
+ data.MQTTVersion = 3;
+ data.clientID.cstring = "pim-23";
+
+ // Connect the
+ int rc = 0;
+ if ((rc = client.connect(data)) != 0)
+ printf("rc from MQTT connect is %d\r\n", rc);
+
+ if ((rc = client.subscribe(topic_sub, MQTT::QOS2, messageArrived)) != 0)
+ printf("rc from MQTT subscribe is %d\r\n", rc);
+
+ while (true) {
+ // Show that the loop is running by switching motherboard LED2:
+ led2 = !led2;
+ thread_sleep_for(BLINKING_RATE_MS);
+ if (button_pressed==1) {
+ button_pressed=0;
+ // QoS 0
+ char buf[100];
+ sprintf(buf, "V(POT1) = %1.2f\r\n", pot1*VOLTAGE_SCALER);
+ message.qos = MQTT::QOS0;
+ message.retained = false;
+ message.dup = false;
+ message.payload = (void*)buf;
+ message.payloadlen = strlen(buf)+1;
+ client.publish(topic, message);
+
+ }
+
+ /******************************************
+
+ if (strcmp(message.payload, "start") == 0)
+{
+ pot1();
+}
+else if (strcmp(message.payload, "stop") == 0)
+{
+ stoppot1();//
+}
+else if (strcmp(message.payload, "oled") == 0)
+{
+ oled();//
+}
+
+else
+{
+ ;
+}
+
+ ********************************************/
+
+
+
+ // Need to call yield API to maintain connection:
+ client.yield(YIELD_TIMEOUT_MS);
+ } // while
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+