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.
Revision 0:4e0f31b64b24, committed 2022-01-19
- Comitter:
- minamikawa
- Date:
- Wed Jan 19 08:31:23 2022 +0000
- Commit message:
- first_commit
Changed in this revision
diff -r 000000000000 -r 4e0f31b64b24 .gitignore --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/.gitignore Wed Jan 19 08:31:23 2022 +0000 @@ -0,0 +1,4 @@ +.build +.mbed +projectfiles +*.py*
diff -r 000000000000 -r 4e0f31b64b24 CONTRIBUTING.md --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/CONTRIBUTING.md Wed Jan 19 08:31:23 2022 +0000 @@ -0,0 +1,5 @@ +# Contributing to Mbed OS + +Mbed OS is an open-source, device software platform for the Internet of Things. Contributions are an important part of the platform, and our goal is to make it as simple as possible to become a contributor. + +To encourage productive collaboration, as well as robust, consistent and maintainable code, we have a set of guidelines for [contributing to Mbed OS](https://os.mbed.com/docs/mbed-os/latest/contributing/index.html).
diff -r 000000000000 -r 4e0f31b64b24 README.md --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/README.md Wed Jan 19 08:31:23 2022 +0000 @@ -0,0 +1,64 @@ + +# Blinky Mbed OS example + +The example project is part of the [Arm Mbed OS Official Examples](https://os.mbed.com/code/) and is the [getting started example for Mbed OS](https://os.mbed.com/docs/mbed-os/v5.14/quick-start/index.html). It contains an application that repeatedly blinks an LED on supported [Mbed boards](https://os.mbed.com/platforms/). + +You can build the project with all supported [Mbed OS build tools](https://os.mbed.com/docs/mbed-os/latest/tools/index.html). However, this example project specifically refers to the command-line interface tool [Arm Mbed CLI](https://github.com/ARMmbed/mbed-cli#installing-mbed-cli). +(Note: To see a rendered example you can import into the Arm Online Compiler, please see our [import quick start](https://os.mbed.com/docs/mbed-os/latest/quick-start/online-with-the-online-compiler.html#importing-the-code).) + +1. [Install Mbed CLI](https://os.mbed.com/docs/mbed-os/latest/quick-start/offline-with-mbed-cli.html). + +1. Clone this repository on your system, and change the current directory to where the project was cloned: + + ```bash + $ git clone git@github.com:armmbed/mbed-os-example-blinky && cd mbed-os-example-blinky + ``` + + Alternatively, you can download the example project with Arm Mbed CLI using the `import` subcommand: + + ```bash + $ mbed import mbed-os-example-blinky && cd mbed-os-example-blinky + ``` + + +## Application functionality + +The `main()` function is the single thread in the application. It toggles the state of a digital output connected to an LED on the board. + +## Building and running + +1. Connect a USB cable between the USB port on the board and the host computer. +2. <a name="build_cmd"></a> Run the following command to build the example project and program the microcontroller flash memory: + ```bash + $ mbed compile -m <TARGET> -t <TOOLCHAIN> --flash + ``` +The binary is located at `./BUILD/<TARGET>/<TOOLCHAIN>/mbed-os-example-blinky.bin`. + +Alternatively, you can manually copy the binary to the board, which you mount on the host computer over USB. + +Depending on the target, you can build the example project with the `GCC_ARM`, `ARM` or `IAR` toolchain. After installing Arm Mbed CLI, run the command below to determine which toolchain supports your target: + +```bash +$ mbed compile -S +``` + +## Expected output +The LED on your target turns on and off every 500 milliseconds. + + +## Troubleshooting +If you have problems, you can review the [documentation](https://os.mbed.com/docs/latest/tutorials/debugging.html) for suggestions on what could be wrong and how to fix it. + +## Related Links + +* [Mbed OS Stats API](https://os.mbed.com/docs/latest/apis/mbed-statistics.html). +* [Mbed OS Configuration](https://os.mbed.com/docs/latest/reference/configuration.html). +* [Mbed OS Serial Communication](https://os.mbed.com/docs/latest/tutorials/serial-communication.html). +* [Mbed OS bare metal](https://os.mbed.com/docs/mbed-os/latest/reference/mbed-os-bare-metal.html). +* [Mbed boards](https://os.mbed.com/platforms/). + +### License and contributions + +The software is provided under Apache-2.0 license. Contributions to this project are accepted under the same license. Please see contributing.md for more info. + +This project contains code from other projects. The original license text is included in those source files. They must comply with our license guide.
diff -r 000000000000 -r 4e0f31b64b24 main.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp Wed Jan 19 08:31:23 2022 +0000
@@ -0,0 +1,96 @@
+
+
+#include "mbed.h" //MbedOS 5.15
+#include "EthernetInterface.h"
+
+#define BUFFSIZE 50
+
+#define PORT 80
+
+DigitalOut led1(LED1);
+
+EthernetInterface net;
+TCPSocket server;
+TCPSocket* client;
+SocketAddress clientAddress;
+
+char *in_buffer;
+char *out_buffer;
+
+static const char* mbedIP = "192.168.0.32"; //IP
+static const char* mbedMask = "255.255.255.0"; // Mask
+static const char* mbedGateway = "192.168.0.0"; //Gateway
+
+
+int main (void){
+ printf("TCP Echo starting...\n");
+ int net_stat;
+//#ifndef ROUTER
+ net.disconnect();
+ net_stat = net.set_network(mbedIP,mbedMask,mbedGateway); //set ip, mask, gateway to net
+ printf("set IP status: %i\n",net_stat);
+//#endif
+ net_stat = net.connect(); //connect to network
+ printf("connect status: %i\n",net_stat);
+
+ SocketAddress ip; //make socket for local ip address
+ net.get_ip_address(&ip); //get a info from net
+ const char *p_ip = ip.get_ip_address();
+ printf("IP address: %s and Port: %d\n", p_ip ? p_ip : "None" , PORT );
+ SocketAddress mask;
+ net.get_netmask(&mask);
+ const char *p_mask = mask.get_ip_address();
+ printf("Netmask: %s\n", p_mask ? p_mask : "None");
+ SocketAddress gateway;
+ net.get_gateway(&gateway);
+ const char *p_gateway = gateway.get_ip_address();
+ printf("Gateway: %s\n", p_gateway ? p_gateway : "None");
+
+ if(ip){
+ server.open(&net); //open a network socket using info of net
+ server.bind(PORT); //bind the socket to a port which receive data
+ server.listen(1); //prepare for incoming connections
+ while (1) {
+
+ printf("Server bound and listening\n");
+ client = server.accept(); //wait until connection has done
+ client->set_blocking(false);
+ client->getpeername(&clientAddress);
+ const char *p_clientAddress = clientAddress.get_ip_address();
+ printf("Client connected from IP address: %s\n", p_clientAddress ? p_clientAddress : "None");
+
+ bool b = true;
+ while (b) {
+ in_buffer = new char[BUFFSIZE];
+ int n = client->recv(in_buffer, BUFFSIZE);
+
+ printf("%d\n", n);
+
+ if (n == 0) {
+ printf("Client disconnected\n");
+ b = false;
+ }else if(n == NSAPI_ERROR_WOULD_BLOCK){
+ //printf("data is not here\n");
+ }else{
+ in_buffer[n] = '\0';
+ printf("Received message from Client :'%s'\n", in_buffer);
+ out_buffer = new char[BUFFSIZE];
+ n = sprintf(out_buffer,"Echo - %s", in_buffer);
+
+ printf("Sending echo to client\n");
+ //client->send(out_buffer, n);
+ led1 =! led1;
+ delete []out_buffer;
+ }
+ led1 =! led1;
+ delete []in_buffer;
+ wait_us(10000);
+ }
+ client->close();
+ }
+ }else{
+ printf("No IP\n");
+ net.disconnect();
+ printf("Program end\n");
+ }
+}
\ No newline at end of file
diff -r 000000000000 -r 4e0f31b64b24 mbed-os.lib --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-os.lib Wed Jan 19 08:31:23 2022 +0000 @@ -0,0 +1,1 @@ +https://github.com/ARMmbed/mbed-os/#b1796dedeb8accde1cbaecf136fab96895e23d81
diff -r 000000000000 -r 4e0f31b64b24 resources/official_armmbed_example_badge.png Binary file resources/official_armmbed_example_badge.png has changed