Microsoft MVP성태의 닷넷 이야기
사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [링크 복사], [링크+제목 복사],
조회: 20073
글쓴 사람
정성태 (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)
999정성태2/28/201146567개발 환경 구성: 108. RemoteFX - Windows 7 가상 머신에서 DirectX 9c 환경을 제공 [5]
998정성태2/27/201120271Team Foundation Server: 42. TFS Application-Tier만 재설치
996정성태2/12/201137721디버깅 기술: 35. windbg - 분석 예: 시작하자마자 비정상 종료하는 프로세스 - NullReferenceException
995정성태2/11/201156256.NET Framework: 205. 코드(C#)를 통한 풀 덤프 만드는 방법 [4]
994정성태2/10/201136189디버깅 기술: 34. Windbg - ERROR: Unable to load DLL mscordacwks_x86_x86_2.0.50727.4200.dll, Win32 error 0n2 [1]
993정성태2/10/201128517개발 환경 구성: 107. 하나의 WPF 프로젝트를 WinExe / Library로 빌드하는 방법
992정성태10/15/201129362개발 환경 구성: 106. VSS(Volume Shadow Service)를 이용한 Hyper-V VM 백업/복원 [2]
991정성태2/6/201148832개발 환경 구성: 105. 풀 덤프 파일을 남기는 방법 [4]
990정성태2/2/201134001개발 환경 구성: 104. Visual C++ Custom Build Tool 사용예 [1]파일 다운로드1
989정성태2/1/201130512개발 환경 구성: 103. DOS batch - 동기 방식으로 원격 서비스 제어
988정성태1/30/201126684개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정
987정성태1/29/201139858디버깅 기술: 33. PDB Symbol 로드 오류 - Cannot find or open the PDB file. [2]
986정성태1/26/201131275.NET Framework: 204. 분리된 ThreadPool 사용 - Smart Thread Pool
985정성태1/25/201127942디버깅 기술: 32. 인증서로 서명된 닷넷 어셈블리의 실행 지연 현상
984정성태1/25/201122646개발 환경 구성: 101. SharePoint 2010 - Form Design
983정성태1/23/201127689제니퍼 .NET: 15. 눈으로 확인하는 maxWorkerThreads, minFreeThreads 설정값 [1]
982정성태1/22/201124993개발 환경 구성: 100. SharePoint 2010 - iPad 친화적인 게시판 만들기 (사용자 지정 목록) [1]
981정성태1/19/201120876개발 환경 구성: 99. SharePoint 2010 - 웹 애플리케이션 생성 시 고려해야 할 점. [1]
980정성태1/19/201132299개발 환경 구성: 98. SharePoint 2010 - Office Web Apps 설치
979정성태1/18/201124999개발 환경 구성: 97. SharePoint 2010 팀 사이트 구성
978정성태1/16/201131960.NET Framework: 203. VPN 자동 연결 및 Router 설정 추가
977정성태1/12/201131303개발 환경 구성: 96. SharePoint 2010 설치 [5]
976정성태1/11/201153938오류 유형: 111. IIS - 500.19 오류 (0x8007000d)
975정성태1/10/201128160.NET Framework: 202. CLR JIT 컴파일러가 생성한 기계어 코드 확인하는 방법 [3]파일 다운로드1
974정성태1/8/201126967.NET Framework: 201. 윈폼 TreeView - Bold 폰트 설정 후 텍스트가 잘리는 문제 [1]파일 다운로드1
973정성태1/7/201126306.NET Framework: 200. IIS Metabase와 ServerManager 개체 활용파일 다운로드1
... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...