-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathchapter_1-1.qmd
417 lines (278 loc) · 27.2 KB
/
chapter_1-1.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
# 1.1 First Arduino program with Seeed Studio XIAO: Blink {.unnumbered}
Arduino is a globally popular open-source electronic prototyping platform, including various models of Arduino development boards and the Arduino IDE software platform. Because of its open, convenient, and easy-to-start characteristics, it has become the first choice for many software and hardware beginners.
With it, you can quickly complete project development and implement your ideas. To date, Arduino has introduced various models of controllers and numerous peripheral modules, such as sensors, actuators, expansion boards, etc. These modules can implement various exciting and practical projects when used with Arduino.
The Seeed Studio XIAO series products we are learning about today are development boards derived from Arduino. They belong to the Seeeduino series and are the smallest members of this series.
## 1.1.1 Arduino IDE Text Editor
We need to program the hardware through the Arduino IDE text editor. If you have not installed the Arduino IDE, go to the download page to install it: 🔗 [Software](https://www.arduino.cc/en/software). The Arduino IDE (Integrated Development Environment) is a programming software designed explicitly for Arduino. Through it, we can write and upload different programs for Arduino hardware. When we open the Arduino IDE software, it will create a new file named Sketch, which we can rename.
#### **For Windows Users**
The interface of the Arduino IDE is spotless, and can be divided into four parts: menu bar, toolbar, editing area, and debug window.
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_1.jpeg)
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/yuque_diagram-1.png" alt="yuque_diagram-1.png" width="30" height="30" />
Menu bar: Includes files, edit, sketch, tools, and help, such as new, save, example programs, select serial port, etc.
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/yuque_diagram-2.png" alt="yuque_diagram-2.png" width="30" height="30" />
Horizontal toolbar: Contains several commonly used function buttons: verify, upload, debug, board selection, serial plotter, and serial monitor selection.
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/yuque_diagram-3.png" alt="yuque_diagram-3.png" width="30" height="30" />
Vertical toolbar: Contains shortcuts to the project folder, board manager, library manager, debug, and search.
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/yuque_diagram-4.png" alt="yuque_diagram-4.png" width="30" height="30" />
Code editing area: This is where you write program code, just as we usually type text in a Word window. Write the program code in this area.
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/yuque_diagram-5.png" alt="yuque_diagram-5.png" width="30" height="30" />
Serial monitor, output window: On the right side of the horizontal toolbar, you can open or close the serial monitor window.
#### **For MAC Users**
Except for the location of the menu bar (at the top), which is slightly different from Windows users, all other tools and experiences are the same.
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_2.jpeg)
## 1.1.2 Adding Seeed Studio XIAO to Arduino IDE
> #### ⚠️ **Attention**
><br />
> Due to space limitations, all parts of this course's program code and hardware connection are based on Seeed Studio [XIAO SAMD21](https://www.seeedstudio.com/Seeeduino-XIAO-Arduino-Microcontroller-SAMD21-Cortex-M0+-p-4426.html). Most of the code in the book can be applied to all products in the Seeed Studio XIAO series. If there are exceptions, they will be additionally marked or explained for applicable hardware. If not marked, they apply to multiple products.
We must add the Seeed Studio XIAO series products to the Arduino IDE to start our learning journey.
- For Windows users, first, open your Arduino IDE, click "File→Preferences" in the top menu bar, as shown in the figure, and copy the following URL into "Additional Boards Manager URLs."
- For Mac users, first, open your Arduino IDE, click "Arduino IDE→Preferences" in the top menu bar, as shown in the figure, and copy the following URL into "Additional Boards Manager URLs."
- For Seeed Studio XIAO SAMD21, XIAO nRF52840, and XIAO nRF52840 Sense, copy the link address below: <https://files.seeedstudio.com/arduino/package_seeeduino_boards_index.json>
- For Seeed Studio XIAO RP2040, copy the link address below: <https://github.com/earlephilhower/arduino-pico/releases/download/global/package_rp2040_index.json>
- For Seeed Studio XIAO ESP32C3, XIAO ESP32S3, copy the link address below: <https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_dev_index.json>
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684140735129-effa8acd-c059-4c64-8c84-ab96e0fbf929.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_3.jpeg)
If you frequently use multiple different models of XIAO at the same time, you can click on the![](images/chapter_1/icon.jpg){width="10mm" height="6mm"}icon on the right side of the address bar and add all three addresses above to the board manager, as shown in the figure below.
<!-- ![L1-arduino-ide-mac-setup-2.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684140807895-8ef9ffa6-0789-4d41-ad32-cc442f972263.png#averageHue=%23c6c9c9&clientId=u86b65af4-f8b6-4&from=ui&id=nPsaW&originHeight=1054&originWidth=1590&originalType=binary&ratio=2&rotation=0&showTitle=false&size=158716&status=done&style=none&taskId=ua51ba116-bd3c-4646-8bd5-4cb01b49502&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_4.png)
Next, click "Tools→Board→Board Manager," enter the keyword `Seeeduino XIAO` in the search bar, find `Seeed SAMD Boards` in the appeared entries, and click `INSTALL`.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684142355010-1f33512f-94a8-4c29-86cd-e21a263f3a15.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_5.jpeg)
When the installation starts, you will see an output pop-up window. After the installation is complete, an "INSTALLED" option will appear.
> #### ⚠️ **Attention**
>
> - Enter "RP2040" in the search bar to find the installation package for Seeed XIAO RP2040.
> - Enter "XIAO nrf52840" to find two installation packages: Seeed nRF52 Boards (for low-power projects) and Seeed nRF52 mbed-enabled Boards (for higher-power TinyML projects).
> - Enter "ESP32" to find the installation package for ESP32 by Espressif Systems.
### Connecting Seeed Studio XIAO to Arduino IDE
Connect XIAO to the computer with a data cable, as shown in the figure below:
<!-- ![XIAO连接电脑\@4x.png](https://cdn.nlark.com/yuque/0/2021/png/2746511/1615797195994-1d69441c-5fee-42ba-9700-58b330040dd1.png#averageHue=%23efefee&height=962&id=acnTk&originHeight=1073&originWidth=2896&originalType=binary&ratio=1&rotation=0&showTitle=false&size=134360&status=done&style=none&title=&width=2597) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_6.png)
Next, click on "Tools→Board", find "Seeeduino XIAO," and select it, as shown in the figure below.
<!-- ![L1-WeCom20230515-172140\@2x.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684142575447-8cf375ed-cdc8-46b8-ada6-10b7167f508a.png#averageHue=%2389b575&clientId=u86b65af4-f8b6-4&from=ui&id=u58618537&originHeight=1186&originWidth=2460&originalType=binary&ratio=2&rotation=0&showTitle=false&size=759602&status=done&style=none&taskId=ub04c07af-24b0-4f77-919a-e41f78ac26e&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_7.png)
> ⚠️ Attention
>
> If your development board is XIAO nRF52840, please select Seeed XIAO nrf52840. <br />
>If your development board is XIAO nRF52840 Sense, please select Seeed XIAO nrf52840 Sense. <br />
>If your development board is XIAO RP2040, please select Seeed XIAO RP2040. <br />
>If your development board is XIAO ESP32C3, please select XIAO_ESP32C3. <br />
>If your development board is XIAO ESP32S3, please select XIAO_ESP32S3. <br />
Check if the port connection is correct; if not, select it manually.
- The serial port on Windows systems is displayed as "COM+number," as shown in the figure below.
- The serial port name on Mac or Linux systems is generally /dev/tty.usbmodem+number or /dev/cu.usbmodem+number, as shown in the figure below.
Now, we can start programming XIAO through the software.
> ⚠️ **XIAO ESP32C3 may not be adequately recognized in Arduino IDE 2, and you need to specify the development board and port manually.**
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684219110243-6ef7e05f-4618-495a-8a2d-167422d04677.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_8.jpeg)
>When ESP32C3 is plugged into a PC with Arduino IDE 2, it may not be able to match the correct development board automatically. As shown in the figure below, the display is not the XIAO ESP32 development board; you need to specify manually. Select " Other Board & Port..." from the Port drop-down menu. Enter "xiao" in the search bar of the development board, select the XIAO_ESP32C3 development board from the filtered list below, and confirm after selecting the port on the right.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684219312231-9d33cecd-1be3-4904-aeee-49aa6151e94a.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_9.jpeg)
>Now you can see that the development board and port are in the correct state.
<!-- ![L1-WeCom20230516-144210\@2x.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684219357868-bd5018f7-f729-4992-85fe-ec6d257399f7.png#averageHue=%23e8b64e&clientId=u112af17f-1ac5-4&from=ui&id=u2fc47546&originHeight=1428&originWidth=1848&originalType=binary&ratio=2&rotation=0&showTitle=false&size=262798&status=done&style=none&taskId=u4e8b42aa-f225-48f2-ac80-da53c1e3ad9&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_10.png)
> ### ⚠️ Reset Seeed Studio XIAO
>
> Sometimes when the program upload fails, the Seeed Studio XIAO port may disappear, and we need to perform a reset operation. The reset method will be different for different models of XIAO.
> #### Reset of Seeed Studio XIAO SAMD21
>
> - Connect XIAO SAMD21 to your computer.
> - Open "Blink" in the Arduino IDE sample program and click upload.
> - While uploading, short circuit the RST pin in the figure once with tweezers or a short wire.
> - The reset is completed when the orange LED flashes and lights up.
As shown in the figure below. ![XIAO-reset.gif](https://files.seeedstudio.com/wiki/Seeeduino-XIAO/img/XIAO-reset.gif).
>#### Reset of Seeed Studio XIAO PR2040
>
> - Connect Seeed Studio XIAO RP2040 to your computer.
> - Press the reset button marked with "R" once, the position is shown in the figure below.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684219597756-6dbd99e7-9be5-46ed-a3b4-a64208ee0d27.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_11.jpeg)
If this does not work, hold down the Boot button marked with "B", connect the board to your computer while holding down the BOOT button, and then release it to enter the bootloader mode.
> #### Reset of Seeed Studio XIAO nRF52840 and Sense version
> - Connect Seeed Studio XIAO nRF52840 or Sense version to your computer.
> - Press the reset button marked with "RST" once, the position is shown in the figure below.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684219636704-506e4ca0-9ec1-4b3f-a609-8fd84a7f33d5.jpeg) -->
<img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_12.jpeg" width="500" height="400" />
If this does not work, you can quickly click it twice to enter the bootloader mode.
> #### Reset of Seeed Studio XIAO ESP32C3
>
> - Connect Seeed Studio XIAO ESP32C3 to your computer.
> - Press the reset button marked with "R" once, the position is shown in the figure below.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684224461683-7ba8c18d-f005-4d77-b525-8845e0a38279.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_13.jpeg)
If this does not work, hold down the Boot button marked with "B", connect the board to your computer while holding down the BOOT button, and then release it to enter the bootloader mode.
> #### Reset of Seeed Studio XIAO ESP32S3
>
> - Connect Seeed Studio XIAO ESP32S3 to your computer.
> - Press the reset button marked with "R" once, the position is shown in the figure below.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1698388811596-f95d296a-a79d-4d08-8176-3abdbff63ccd.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_14.jpeg)
If this does not work, hold down the Boot button marked with "B", connect the board to your computer while holding down the BOOT button, and then release it to enter the bootloader mode.
### Structure of Arduino Programs
Now that we have the development board, how can we write programs into it to control its functions? That's when the Arduino IDE text editor comes in handy. We've already introduced the interface functions of Arduino IDE in the introduction, it's an important tool for writing and uploading programs. Arduino programs consist of two basic functions:
`setup()` <br />
This function is called when the program begins. Use it to initialize variables, pin modes, start using libraries, etc. `setup()` runs only once each time the Arduino board is powered on or reset.
`loop()` <br />
After the program in `setup()` is executed, the program in `loop()` begins to execute. The program in `loop()` runs repeatedly.
<!-- ![L1-企业微信20230516-160950\@2x.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684224618107-775f075d-575a-49c8-8b92-44ea1545cfa7.png#averageHue=%23bd9641&clientId=u2787efb9-7ba6-4&from=ui&id=u1704f87c&originHeight=1288&originWidth=1786&originalType=binary&ratio=2&rotation=0&showTitle=false&size=202951&status=done&style=none&taskId=u1d2f3e22-7542-42ca-84c2-4183b7d6003&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_15.png)
> ##### Knowledge window:
> - The contents after "/\* \*/" and "//" are comments to help you understand and manage code, the comments will not affect the normal operation of the program;
> - When writing programs, we need to use "{}" to wrap a set of codes;
> - After each line of code, use ";" as an end symbol to tell the Arduino editor that this line of code instruction is over.
### Digital Signals and I/O Settings
Simply put, digital signals are signals represented in binary form of 0 and 1. In Arduino, digital signals are represented by high and low levels, high level means digital signal 1, and low level means digital signal 0. Seeed Studio XIAO has 11 digital pins, we can set these pins to perform the function of inputting or outputting digital signals.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684224782661-b9e9d160-2a27-4838-a66a-395d814662fb.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_16.jpeg)
In Arduino, you can use functions to set the status and function of pins. Here are the basic steps to set pins through functions:
1. First, determine the pin number of the pin you want to control.
2. In the Arduino code, use the `pinMode()` function to set the function of the pin, such as input or output. For example, to set the pin to output mode, you can use the following code:
``` cpp
int ledPin = 13; // The pin to be controlled
void setup() {
pinMode(ledPin, OUTPUT); // Set the pin to output mode
}
```
3. Once you have set the pin to output mode, you can use the `digitalWrite()` function to set the status of the pin, such as setting it to high or low level. For example, to set the pin to high level, you can use the following code:
``` cpp
digitalWrite(ledPin, HIGH); // Set the pin to high level
```
4. If you set the pin to input mode, you can use the `digitalRead()` function to read the status of the pin, such as detecting whether it is high or low level. For example, to read the status of the pin and save it to a variable, you can use the following code:
``` cpp
int buttonPin = 2; // The pin to read the status from
int buttonState = 0; // The variable to save the status
void setup() {
pinMode(buttonPin, INPUT); // Set the pin to input mode
}
void loop() {
buttonState = digitalRead(buttonPin); // Read the status of the pin
}
```
By using functions like `pinMode()`, `digitalWrite()`, and `digitalRead()`, you can easily set and control the status and function of pins in Arduino.
## 1.1.3 Task 1: Run Blink to Make XIAO's LED Flash
Just as "Hello World" is the first section in all programming languages, "Blink" is akin to "Hello World" in Arduino programming. It is the key to our journey in learning Arduino. Arduino provides many example codes to help us get started quickly, and Blink is one of them. We can select "File → Examples → 01.Basics → Blink" in the Arduino window to open the example program Blink.
<!-- ![L1-企业微信20230516-163205\@2x.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684226229927-10eec161-495c-4d40-8fdf-c5cfed2bbeff.png#averageHue=%2383907e&clientId=u2787efb9-7ba6-4&from=ui&id=ucdfe75f1&originHeight=1736&originWidth=1880&originalType=binary&ratio=2&rotation=0&showTitle=false&size=1002046&status=done&style=none&taskId=uaff646d1-dfa6-4606-9228-873d313f5da&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_17.png)
After opening the example program, you can see the following code, which implements the effect of LED flashing. You can see that the code has orange and green color prompts, which proves that your input is correct. Pay attention to the difference between uppercase and lowercase.
<!-- ![L1-blink.png](https://cdn.nlark.com/yuque/0/2023/png/2392200/1684226225853-9759173f-84ab-4394-874c-b9c7c6b4c994.png#averageHue=%23f6f6f6&clientId=u2787efb9-7ba6-4&from=ui&id=u799467eb&originHeight=1888&originWidth=1842&originalType=binary&ratio=2&rotation=0&showTitle=false&size=434936&status=done&style=none&taskId=u97c65326-a1ba-44b7-8c39-f998431318a&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_18.png)
``` cpp
/*
Blink
Turns an LED on for one second, then off for one second, repeatedly.
Most Arduinos have an on-board LED you can control. On the UNO, MEGA and ZERO
it is attached to digital pin 13, on MKR1000 on pin 6. LED_BUILTIN is set to
the correct LED pin independent of which board is used.
If you want to know what pin the on-board LED is connected to on your Arduino
model, check the Technical Specs of your board at:
https://www.arduino.cc/en/Main/Products
modified 8 May 2014
by Scott Fitzgerald
modified 2 Sep 2016
by Arturo Guadalupi
modified 8 Sep 2016
by Colby Newman
This example code is in the public domain.
https://www.arduino.cc/en/Tutorial/BuiltInExamples/Blink
*/
// the setup function runs once when you press reset or power the board
void setup() {
// initialize digital pin LED_BUILTIN as an output.
pinMode(LED_BUILTIN, OUTPUT);
}
// the loop function runs over and over again forever
void loop() {
digitalWrite(LED_BUILTIN, HIGH); // turn the LED on (HIGH is the voltage level)
delay(1000); // wait for a second
digitalWrite(LED_BUILTIN, LOW); // turn the LED off by making the voltage LOW
delay(1000); // wait for a second
}
```
### Code Analysis
##### `pinMode(LED_BUILTIN, OUTPUT);`
The first thing the code does is to initialize `LED_BUILTIN` as an output pin in the `setup()` function. Most Arduino series boards default the onboard LED to digital pin 13. The constant `LED_BUILTIN` connects the onboard LED to pin 13.
<br />
##### `digitalWrite(LED_BUILTIN, HIGH);`
In the `loop()` function, we set the `LED_BUILTIN` pin to the "on" state, outputting 5V or 3.3V voltage to this pin, which can be represented by `HIGH`. However, note that all I/O pins on XIAO are 3.3V. Do not input a voltage exceeding 3.3V, or it may damage the CPU.
##### `digitalWrite(LED_BUILTIN, LOW);`
What comes on must turn off. This statement sets the `LED_BUILTIN` pin to the "off" state, outputting 0V voltage to this pin, which can be represented by `LOW`.
##### `delay(1000);`
This is a delay statement. It means that the LED can maintain the "on" or "off" state for 1 second, because the parameter in the function is in milliseconds, so 1000 milliseconds is 1 second. After controlling the "on" and "off" statements of the LED, a delay must be added, and the waiting time should be the same to ensure that the LED flashes evenly.
### Upload the Program
Next, we will learn how to upload the program. Use the data cable in the kit to connect XIAO to the computer, as shown in the figure.
<!-- ![image.png](https://cdn.nlark.com/yuque/0/2021/png/2746511/1616585195669-ba0d4324-bcce-40a5-93fc-706d3d0c959e.png#averageHue=%23e8e7e4&height=350&id=XWmAM&originHeight=350&originWidth=992&originalType=binary&ratio=1&rotation=0&showTitle=false&size=85068&status=done&style=none&title=&width=992) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_19.png)
Choose the serial port of the development board from the "Tools" bar. For Windows users, it is generally COM3 or a larger number. Select it as shown in the figure below.
If several ports are displayed for selection, unplug the data cable, reopen the "Tools" bar, and the port that disappears is the XIAO port. Reconnect the circuit board and then select this serial port. After selecting the board and the serial port, you can see the controller model and corresponding serial port that have been set up in the lower right corner of the IDE interface.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684307022559-5118c887-4787-4265-9e29-2e22fd1421b9.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_20.jpeg)
In Mac or Linux systems, the serial port name is generally `/dev/tty.usbmodem+number` or `/dev/cu.usbmodem+number`, as shown in the figure below.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684307463342-df84ffd3-5b68-4fad-8bb8-93aed75dd343.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_21.jpeg)
Next, we can upload the program. Before uploading, we can click the <img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/verify-button.png" alt="verify-button.png" width="30" height="30" />(verify button) to verify whether the program is correct. If "Compilation Completed" is displayed, the program is correct.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684307793146-ee233003-4240-45b2-8248-a421fcdcfce9.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_22.jpeg)
Click the <img src="https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/upload-button.png" alt="upload-button.png" width="30" height="30" /> (upload button), the debug window will display "Compiling Project→Upload". When "Upload Completed" is displayed, you can see the effect of the program running on XIAO, as shown in the upload successful prompt window displayed on a Mac computer.
<!-- ![](https://cdn.nlark.com/yuque/0/2023/jpeg/2392200/1684307706997-bd9fd76b-01e3-45c3-8af9-372269278c0e.jpeg) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_23.jpeg)
> #### ⚠️ **Note**
> When you start writing code, you will often forget the rules of uppercase and lowercase, punctuation, and make mistakes. Therefore, try to write code by yourself instead of copying and pasting. After the example program is successfully uploaded, try to create a new Sketch and start manually inputting the code.
## 1.1.4 Task 2: Complete the Blink example by connecting an external LED to Seeed XIAO ESP32C3 without LED
If the XIAO you have on hand is Seeed XIAO ESP32C3, since it does not have an onboard LED available for users, in order to run the Blink program, you need to first connect an LED to the `D10` pin of the board, as shown below:
<!-- ![](https://cdn.nlark.com/yuque/0/2022/png/2586586/1666778092446-9a6e722a-8823-48fe-a890-9016f300cb66.png#averageHue=%23d8d4cb&clientId=u5d6c62e5-f3ec-4&from=paste&id=riopo&originHeight=1068&originWidth=1920&originalType=url&ratio=1&rotation=0&showTitle=false&status=done&style=none&taskId=uacd00b90-dfae-494b-96d7-a127e884d1f&title=) -->
![](https://files.seeedstudio.com/wiki/XIAO_Big_Power-Board-ebook-photo/chapter_1-1/chapter_1-1_24.png)
> ⚠️ Note <br />
> You must connect a resistor (about 150Ω) in series with the LED to limit the current flowing through the LED to prevent the strong current from burning the LED.
Then copy the following program to the Arduino IDE:
``` cpp
// Define the LED pin according to the pin diagram
int led = D10;
void setup() {
// Initialize the digital pin 'led' as output
pinMode(led, OUTPUT);
}
void loop() {
digitalWrite(led, HIGH); // Turn the LED on
delay(1000); // Wait for a second
digitalWrite(led, LOW); // Turn the LED off
delay(1000); // Wait for a second
}
```
> Get this program from Github <br />
> <https://github.com/mouseart/XIAO-Mastering-Arduino-and-TinyML/blob/main/code/L1_Blinks_XIAO_ESP32C3/L1_Blinks_XIAO_ESP32C3.ino>
### Code Analysis <br />
`int led = D10;`
Seeed XIAO ESP32C3 does not have an onboard LED, so we did not preset an LED corresponding pin in the Arduino core. Just now, we connected the LED to the `D10` pin, so we need to declare it in the program.
`pinMode(led, OUTPUT);`
We defined `led` as `D10`, and this step is to initialize led(D10) as an output pin.
## 1.1.5 Extended Exercise
Rewrite the Blink program: In the example program, the LED is on and off for 1 second each time, so it seems to blink evenly. Try adjusting the waiting time to give the LED different blinking effects.
Hint:
``` cpp
void setup() {
pinMode(LED_BUILTIN, OUTPUT);
}
void loop() {
digitalWrite(LED_BUILTIN, HIGH);
delay(1000);
digitalWrite(LED_BUILTIN, LOW);
delay(500);
}
```
> Get this program from Github <br />
> <https://github.com/mouseart/XIAO-Mastering-Arduino-and-TinyML/blob/main/code/L1_ll_Blinks_1_en/L1_ll_Blinks_1_en.ino>
For XIAO ESP32C3, we also need to modify the pin definition part of the program:
``` cpp
int led = D10;
void setup() {
pinMode(led, OUTPUT);
}
void loop() {
digitalWrite(led, HIGH);
delay(1000);
digitalWrite(led, LOW);
delay(500);
}
```
> Get this program from Github <br />
> <https://github.com/mouseart/XIAO-Mastering-Arduino-and-TinyML/blob/main/code/L1_ll_blinks_2_en/L1_ll_blinks_2_en.ino>