Microsoft MVP성태의 닷넷 이야기
사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [링크 복사], [링크+제목 복사],
조회: 19926
글쓴 사람
정성태 (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분
정성태

... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11099정성태11/7/201630657.NET Framework: 620. C#에서 C/C++ 함수로 콜백 함수를 전달하는 예제 코드파일 다운로드1
11098정성태11/7/201619997오류 유형: 368. 빌드 이벤트에서 robocopy 사용 시 $(TargetDir) 매크로를 지정하는 경우 오류 발생
11097정성태11/7/201622917오류 유형: 367. go install: no install location for directory [...경로...] outside GOPATH
11096정성태11/6/201626723디버깅 기술: 83. PDB 파일을 수동으로 다운로드하는 방법
11095정성태11/6/201622976.NET Framework: 619. C# - Cognitive Services 중의 하나인 Face API를 사용해 얼굴 인식 및 흐림(blur) 효과 적용 [1]파일 다운로드1
11094정성태11/5/201624617VC++: 105. Visual Studio 2013/2015 - Ceemple OpenCV 확장을 이용한 웹캠 영상 출력
11093정성태11/4/201624517웹: 34. Edge 브라우저도 지원하는 클립보드 복사를 위한 자바스크립트 코드
11092정성태11/3/201631525.NET Framework: 618. C# - NAudio를 이용한 MP3 파일 재생 [5]파일 다운로드1
11091정성태11/3/201626310VC++: 104. std::call_once를 이용해 thread-safe한 Singleton 객체 생성파일 다운로드1
11090정성태11/1/201627754VC++: 103. C++ CreateTimerQueue, CreateTimerQueueTimer 예제 코드 [9]파일 다운로드1
11089정성태11/1/201626569디버깅 기술: 82. Windows 10을 위한 Symbol(PDB) 파일 내려받는 방법 [2]
11088정성태11/1/201630685.NET Framework: 617. C# - AForge.NET을 이용한 MP4 동영상 파일 재생 [7]파일 다운로드1
11087정성태11/1/201625092.NET Framework: 616. AForge.Video.FFMPEG를 최신 버전의 ffmpeg 파일로 의존성을 변경하는 방법파일 다운로드1
11086정성태11/1/201618937오류 유형: 366. The Microsoft Passport Container service terminated with the following error: General access denied error
11085정성태10/27/201633288.NET Framework: 615. C# - AForge.NET을 이용한 웹캠 영상 출력 [2]파일 다운로드1
11084정성태10/26/201621377오류 유형: 365. The User Profile Service service failed to the sign-in.
11083정성태10/26/201627860Windows: 131. 윈도우 10에서 사라진 "Adapters and Bindings" 네트워크 우선 순위 조정 기능 [1]
11082정성태10/26/201629776.NET Framework: 614. C# - DateTime.Ticks의 정밀도 [4]파일 다운로드1
11081정성태10/26/201620303오류 유형: 364. You need to fix your Microsoft Account for apps on your other devices to be able to launch apps and continue experiences on this device.
11080정성태10/24/201623424Windows: 130. Windows Server 2016 Nano 서버 설치 방법
11079정성태10/21/201620577Windows: 129. Windows Server 2016 설치 CD에 있는 Convert-WindowsImage.ps1 사용 방법 정리
11078정성태10/21/201621878Windows: 128. Windows Server 2016 Nano 서버 VHD 이미지 만드는 방법 - TP5 기준
11077정성태10/21/201620381오류 유형: 363. Active Directory 서버의 NETLOGON 서비스가 멈췄을 때 발생하는 문제
11076정성태10/21/201619919오류 유형: 362. 윈도우 백업 시 오류 - 0x80780040
11075정성태10/20/201620922Windows: 127. Convert-WindowsImage.ps1 사용 방법 정리
11074정성태10/20/201629194Windows: 126. Windows Server 2016 평가판을 정식 버전으로 라이선스 변경하는 방법
... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...