Microsoft MVP성태의 닷넷 이야기
사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [링크 복사], [링크+제목 복사],
조회: 21475
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 3개 있습니다.)

NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신

역시, 직업 또는 꾸준한 취미 활동으로 삼지 않는 한 어떤 것에 대한 지식을 유지하는 것이 ^^; 힘들군요.

오랜만에 IoT 관련 코드를 해보고 싶어, 묵혀 두었던 장비를 꺼냈는데 뭐가 어떻게 되는지 하나도 모르겠습니다. 다행히 유사한 모듈에 대해 개발 환경을 기록한 것이 있는데,

New NodeMCU v3 아두이노 호환 보드의 기본 개발 환경 구성
; https://www.sysnet.pe.kr/2/0/11595

제가 지금 가지고 있는 v1 보드랑 뭔가 맞지 않습니다. 장치 관리자의 인식이 "USB-SERIAL CH340"이 아닌, "Silicon Labs CP210x USB to UART Bridge"라는 이름으로 잡히는데요, 보드를 자세하게 살펴보니,

node_mcu_1.png

node_mcu_2.png

각각의 면에 다음과 같은 문자들을 확인할 수 있습니다.

NODEMCU
AMICA
WWW.NODEMCU.COM
OPEN-SOURCE IOT PLATFORM
1. Install CP2102 driver
2. Use 9600 baud rate
3. Connect Wi-Fi and enjoy
Vin +5V Recommended +10V MAX

MODEL VENDOR
ESP8266MOD
ISM 2.4GHz
PA +25dBm
802.11b/g/n

A0     W    D0
RSV    i    D1
RSV    F    D2
SD3    i    D3
SD2    C    D4
SD1    h    3V3
CMD    i    GND
SD0    p    D5
CLK         D6
GND         D7
3V3         D8
EN          RX
RST         TX
GND         GND
Vin         3V3
  RST   FLASH
SILABS
CP2102
DCL00X
1806+

이러한 정보를 기반으로 검색해 보면 칩의 구성과 프린팅된 텍스트와 정확히 일치하는 다음의 제품이 나옵니다.

아두이노 NodeMCU V1.0 와이파이 보드 /Lua WiFi ESP8266 - 12E CP2102 칩셋
; https://eduino.kr/product/detail.html?product_no=239

CP210x USB to UART Bridge VCP Drivers
; https://www.silabs.com/developers/usb-to-uart-bridge-vcp-drivers

nodemcu_silabs_cp2102_1.png


SPI 관련 핀: 
    SDIO_DATA1(MOSI), SDIO_DATA0(MISO), SDIO_CLK(SCLK), SDIO_CMD(CS), SDIO_DATA2(GPIO9), SDIO_DATA3(GPIO10)
    GPIO14 (HSCLK), GPIO15(HMISO), GPIO16(HMOSI), GPIO17(HCS)

MISO (Master In Slave Out)
MOSI (Master Out Slave In)
SCLK (Serial Clock)
CS (Chip Select)

NodeMCU SPI with Arduino IDE
; https://www.electronicwings.com/nodemcu/nodemcu-spi-with-arduino-ide

UART 관련 핀:
    GPIO13(CTS0), GPIO15(RTS0), GPIO3(RXD0), GPIO1(TXD0)

I2C (data pin, click pin):
    GPIO4(SDA), GPIO5(SCL)

PWM 핀: GPIO4, GPIO14, GPIO12, GPIO15

SDIO(SD Card Interface):
    GPIO10(SDD3), GPIO9(SDD2), GPIO8(SDD1), GPIO11(SDCMD), GPIO7(SDD0), GPIO6(SDCLK)

Insight Into ESP8266 NodeMCU Features & Using It With Arduino IDE
; https://lastminuteengineers.com/esp8266-nodemcu-arduino-tutorial/#esp8266-nodemcu-pinout

친절하게도 위의 사이트에서 아두이노 IDE에 어떻게 보드 설정을 하는지 자세하게 소개하고 있습니다. 간략하게 정리하면, "File" / "Preferences" 메뉴에서 "Additional Board Manager URLs"에 "http://arduino.esp8266.com/stable/package_esp8266com_index.json" 값을 입력해 설정하고, "Tools" / "Board: ..." / "Boards Manager..."에서 "esp8266 by ESP8266 Community"라고 검색되는 항목을 설치합니다.

마지막으로, 다시 "Tools" / "Port: ..."에서 장치 관리자의 "Silicon Labs CP210x USB to UART Bridge" 항목에 표시된 COM 포트 번호를 설정합니다.

그럼 "Tools" / "Get Board Info" 메뉴를 선택했을 때 다음과 같은 식의 결과가 출력되는 것을 확인할 수 있습니다.

Board Info
BN: Unknown board
VID: 10C4
PID: EA60
SN: Upload any sketch to obtain it

(참고로, 위의 과정은 "New NodeMCU v3 아두이노 호환 보드의 기본 개발 환경 구성" 글에서도 동일하게 설명했습니다.)

간단하게 (부품이 그사이 고장 나지 않았는지 확인하기 위해 ^^) 동작 테스트를 다음의 BLINK 예제로 시작할 수 있습니다.

void setup() {
  pinMode(16, OUTPUT);
}

void loop() {
  digitalWrite(16, HIGH); 
  delay(5000);            
  digitalWrite(16, LOW);  
  delay(5000);            
}

NodeMCU 보드의 경우 16번 핀의 출력은 보드의 RST 핀 옆에 있는 LED가 깜빡입니다. 재미있는 것은, 해당 보드에는 프로그램을 업로드하는 등의 상태를 알리는 LED가 별도로 제공되는데, 그 LED는 2번 출력으로 제어가 됩니다. 따라서 다음과 같이 번호를 바꾸면,

void setup() {
  pinMode(2, OUTPUT);
}

void loop() {
  digitalWrite(2, HIGH);
  delay(5000);          
  digitalWrite(2, LOW); 
  delay(5000);          
}

// 핀 구성 https://www.sysnet.pe.kr/2/0/11767#pin_layout

이제는 보드의 D0(GPIO 16) 핀 옆에 있는 LED가 깜빡입니다.




Blink 예제만 하고 이 글을 끝내기에는 좀 아쉽죠. ^^ 일단 TCP 기반의 WiFiClient 통신은 지난 글에서 다뤄봤으니,

New NodeMCU v3(ESP8266)의 http 통신
; https://www.sysnet.pe.kr/2/0/11762

New NodeMCU v3(ESP8266)의 https 통신
; https://www.sysnet.pe.kr/2/0/11763

이번에는 UDP 통신을 해보겠습니다. 이에 대해서는 이미 다음의 글에서 자세하게 소개하고 있으므로,

ESP8266 UDP SEND & RECEIVE EXAMPLE (STEP-BY-STEP TUTORIAL)
; https://siytek.com/esp8266-udp-send-receive/

여기선 그냥 베끼기만 하면 됩니다. ^^

#include <ESP8266WiFi.h>
#include <WiFiUdp.h>

#define WIFI_SSID "...ssid..."
#define WIFI_PASS "...wifipassword..."
#define UDP_PORT 1194
#define PACKET_SIZE 8
int _buildLedPin = 16;

WiFiUDP UDP;
const char udpServer[] = "...udp_dns_server...";
char packet[PACKET_SIZE + 1];

void setup() {
  // Setup serial port
  Serial.begin(115200);
  Serial.println();
  
  // Begin WiFi
  WiFi.begin(WIFI_SSID, WIFI_PASS);
  
  // Loop continuously while WiFi is not connected
  while (WiFi.status() != WL_CONNECTED)
  {
    delay(1000);
    Serial.print(".");
  }
  
  // Connected to WiFi
  Serial.println();
  Serial.print("Connected! IP address: ");
  Serial.println(WiFi.localIP());

  pinMode(_buildLedPin, OUTPUT);
}

void loop() {

  memset(packet, 0, PACKET_SIZE);

  UDP.beginPacket(udpServer, UDP_PORT);
  UDP.write(packet, PACKET_SIZE);
  UDP.endPacket();

  delay(1000);
  int packetSize = UDP.parsePacket();

  if (packetSize)
  {
    int len = UDP.read(packet, PACKET_SIZE);
    if (len > 0)
    {
      packet[len] = 0;
    }
  }

  Blink(2000);
}

void Blink(int ledOnTime)
{
  digitalWrite(_buildLedPin, LOW);
  delay(ledOnTime);
  digitalWrite(_buildLedPin, HIGH);
  delay(ledOnTime);
}

위의 예제는 UDP 서버에 (빈 내용으로) 8바이트를 보내고, 그 응답으로 8바이트를 (해석하지는 않지만) 받고 있습니다.




참고로, 기록을 위해 프로그램 업로드 시 출력되는 내용은 다음과 같습니다.

Executable segment sizes:
IROM   : 228640          - code in flash         (default or ICACHE_FLASH_ATTR) 
IRAM   : 26756   / 32768 - code in IRAM          (ICACHE_RAM_ATTR, ISRs...) 
DATA   : 1248  )         - initialized variables (global, static) in RAM/HEAP 
RODATA : 688   ) / 81920 - constants             (global, static) in RAM/HEAP 
BSS    : 24880 )         - zeroed variables      (global, static) in RAM/HEAP 

Sketch uses 257332 bytes (24%) of program storage space. Maximum is 1044464 bytes.
Global variables use 26816 bytes (32%) of dynamic memory, leaving 55104 bytes for local variables. Maximum is 81920 bytes.

esptool.py v2.8
Serial port COM4
Connecting....
Chip is ESP8266EX
Features: WiFi
Crystal is 26MHz
MAC: 50:5d:2a:12:6d:23
Uploading stub...
Running stub...
Stub running...
Configuring flash size...
Auto-detected Flash size: 4MB
Compressed 261488 bytes to 193147...
Wrote 261488 bytes (193147 compressed) at 0x00000000 in 17.1 seconds (effective 122.2 kbit/s)...
Hash of data verified.

Leaving...
Hard resetting via RTS pin...




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/20/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2023-01-03 09시51분
정성태

... [151]  152  153  154  155  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1308정성태7/3/201227306.NET Framework: 330. IEnumerator는 언제나 읽기 전용일까?파일 다운로드1
1307정성태6/30/201229658개발 환경 구성: 154. Sysnet, Azure를 만나다. [5]
1306정성태6/29/201230126제니퍼 .NET: 22. 눈으로 확인하는 connectionManagement의 maxconnection 설정값 [4]
1305정성태6/28/201228437오류 유형: 157. IIS 6 - WCF svc 호출 시 404 Not Found 발생
1304정성태6/27/201229233개발 환경 구성: 153. sysnet 첨부 파일을 Azure Storage에 마이그레이션 [3]파일 다운로드1
1303정성태6/26/201228803개발 환경 구성: 152. sysnet DB를 SQL Azure 데이터베이스로 마이그레이션
1302정성태6/25/201230745개발 환경 구성: 151. Azure 웹 사이트에 사용자 도메인 네임 연결하는 방법
1301정성태6/20/201227079오류 유형: 156. KB2667402 윈도우 업데이트 실패 및 마이크로소프트 Answers 웹 사이트 대응
1300정성태6/20/201233605.NET Framework: 329. C# - Rabin-Miller 소수 생성방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 [1]파일 다운로드2
1299정성태6/18/201234216제니퍼 .NET: 21. 제니퍼 닷넷 - Ninject DI 프레임워크의 성능 분석 [2]파일 다운로드2
1298정성태6/14/201235864VS.NET IDE: 72. Visual Studio에서 pfx 파일로 서명한 경우, 암호는 어디에 저장될까? [2]
1297정성태6/12/201232382VC++: 63. 다른 프로세스에 환경 변수 설정하는 방법파일 다운로드1
1296정성태6/5/201228930.NET Framework: 328. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법 - 두 번째 이야기 [4]파일 다운로드1
1295정성태6/5/201226334.NET Framework: 327. RSAParameters와 System.Numerics.BigInteger 이야기파일 다운로드1
1294정성태5/27/201250405.NET Framework: 326. 유니코드와 한글 - 유니코드와 닷넷을 이용한 한글 처리 [7]파일 다운로드2
1293정성태5/24/201230863.NET Framework: 325. System.Drawing.Bitmap 데이터를 Parallel.For로 처리하는 방법 [2]파일 다운로드1
1292정성태5/24/201224564.NET Framework: 324. First-chance exception에 대해 조건에 따라 디버거가 멈추게 할 수는 없을까? [1]파일 다운로드1
1291정성태5/23/201231458VC++: 62. 배열 초기화를 위한 기계어 코드 확인 [2]
1290정성태5/18/201236368.NET Framework: 323. 관리자 권한이 필요한 작업을 COM+에 대행 [7]파일 다운로드1
1289정성태5/17/201240714.NET Framework: 322. regsvcs.exe로 어셈블리 등록 시 시스템 변경 사항 [5]파일 다운로드2
1288정성태5/17/201227674.NET Framework: 321. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (3) - Type Library파일 다운로드1
1287정성태5/17/201230484.NET Framework: 320. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (2) - .NET 4.0 + .NET 2.0 [2]
1286정성태5/17/201239357.NET Framework: 319. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (1) - .NET 2.0 + x86/x64/AnyCPU [5]
1285정성태5/16/201234472.NET Framework: 318. gacutil.exe로 어셈블리 등록 시 시스템 변경 사항파일 다운로드1
1284정성태5/15/201226922오류 유형: 155. Windows Phone 연결 상태에서 DRIVER POWER STATE FAILURE 블루 스크린 뜨는 현상
1283정성태5/12/201234566.NET Framework: 317. C# 관점에서의 Observer 패턴 구현 [1]파일 다운로드1
... [151]  152  153  154  155  156  157  158  159  160  161  162  163  164  165  ...