{"id":300984,"date":"2020-03-30T21:00:11","date_gmt":"2020-03-30T21:00:11","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=300984"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=300984","title":{"rendered":"DOOM Watch \u043d\u0430 ESP32. \u0427\u0430\u0441\u0442\u044c 1"},"content":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\" data-io-article-url=\"https:\/\/habr.com\/ru\/post\/494748\/\">\u041f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0432 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0441 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 \u043c\u043e\u0434\u0443\u043b\u044f\u043c\u0438 ESP32 \u0437\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u0435 \u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0435. \u0420\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0430\u0441\u044b. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u043e\u0434\u0443\u043c\u0430\u043b \u043e <a href=\"https:\/\/www.espressif.com\/sites\/default\/files\/documentation\/esp32-pico-d4_datasheet_en.pdf\" rel=\"nofollow\">ESP32-PICO-D4<\/a>. \u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0432 \u043d\u0435\u0439 \u0442\u043e\u043b\u044c\u043a\u043e 4Mb flash \u043f\u043e\u0434 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0443, \u0440\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u0441 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\u043c \u0434\u0430 16Mb flash \u0438 8Mb SRAM. \u0427\u0442\u043e \u0431\u044b \u043d\u0430 \u0447\u0430\u0441\u0430\u0445 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 Doom. \u0412 \u043e\u0431\u0449\u0435\u043c \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u0432\u0441\u0435 \u043d\u0430 \u043f\u043e\u043b\u043d\u043e\u043c \u0444\u0430\u0440\u0448\u0435!<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/r0\/tm\/qh\/r0tmqhwcgq1geu0iyijuroahpvq.png\"><\/p>\n<p>  \u0427\u0442\u043e \u043d\u0435 \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0438\u043b\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0438:<\/p>\n<ol>\n<li>\u0418\u043d\u0434\u0438\u043a\u0430\u0442\u043e\u0440 \u0431\u0430\u0442\u0430\u0440\u0435\u0438<\/li>\n<li> \u0421\u0445\u0435\u043c\u0430 \u0431\u0430\u0440\u044c\u0435\u0440\u0430 \u0437\u0430\u0440\u044f\u0434\u043a\u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u043d\u0430 Schottky \u0434\u0438\u043e\u0434\u0435<\/li>\n<li>\u0410\u043d\u0442\u0435\u043d\u0430 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0430 \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u0443\u0434\u0430\u0447\u043d\u043e \u0438 \u043d\u0430 \u0434\u0440\u0443\u0433\u043e\u043c \u0441\u043b\u043e\u0435 \u043e\u0442 ESP32  <\/li>\n<\/ol>\n<p>  \u041d\u0435 \u0442\u0443\u0442\u043e\u0440\u0438\u0430\u043b!<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bw\/cn\/gr\/bwcngruk2zywo5wuqk-zvco4toq.jpeg\"><br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h3>\u041f\u043e \u0434\u0438\u0441\u043f\u043b\u0435\u044e<\/h3>\n<p>  <img decoding=\"async\" width=\"400\" src=\"https:\/\/habrastorage.org\/webt\/y-\/0a\/rp\/y-0arpnjd4fsidh22irudjow-qg.png\"><\/p>\n<p>  \u042f \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u043b \u0446\u0432\u0435\u0442\u043d\u043e\u0439 \u0434\u0438\u0441\u043f\u043b\u0435\u0439 \u043d\u0430 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0435 ST7789 \u0441 \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u0438\u0435\u043c 240&#215;240. \u041e\u043d \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u044b\u0439 \u0438 \u0434\u0435\u0448\u0435\u0432\u044b\u0439. \u0412 \u0441\u0435\u0442\u0438 \u0432\u0441\u0435 \u0431\u043e\u043b\u044c\u0448\u0435 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u043e\u0432 \u0438 \u043f\u043e\u0440\u0442\u043e\u0432. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0435\u0441\u0442\u044c \u043f\u043e\u0440\u0442 \u0434\u043b\u044f <a href=\"https:\/\/github.com\/littlevgl\/lv_port_esp32\" rel=\"nofollow\">LittlevGL<\/a>, \u043d\u043e \u043d\u0430 \u044d\u0442\u043e\u043c \u0434\u0438\u0441\u043f\u043b\u0435\u0435 \u043d\u0435\u0442 \u0442\u0430\u0447\u0430. \u0414\u0443\u043c\u0430\u044e \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0434\u043e\u043a\u0443\u043f\u0438\u0442\u044c \u0438 \u043f\u0440\u0438\u043a\u043b\u0435\u0438\u0442\u044c. \u041c\u043e\u0436\u0435\u0442 \u0443 \u043a\u043e\u0433\u043e-\u0442\u043e \u0435\u0441\u0442\u044c \u043e\u043f\u044b\u0442? \u041f\u043e\u0434\u0435\u043b\u0438\u0442\u0435\u0441\u044c<\/p>\n<p>  \u042f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043d\u0430 ST7789 \u043e\u0434\u043d\u0443 \u043f\u043b\u0430\u0442\u0443 \u0438 \u043e\u043d\u0430 \u00ab\u0437\u0430\u0432\u0435\u043b\u0430\u0441\u044c\u00bb \u0431\u0435\u0437 \u043a\u0430\u043a\u0438\u0445 \u043b\u0438\u0431\u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c<\/p>\n<p>  <img decoding=\"async\" width=\"500\" src=\"https:\/\/habrastorage.org\/webt\/fw\/ic\/mc\/fwicmcivnyq44nxvhwqpjqrlsco.jpeg\">  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">LittlevGL esp32<\/b><\/p>\n<div class=\"spoiler_text\">\n<div class=\"oembed\">\n<div>\n<div style=\"left: 0; width: 100%; height: 0; position: relative; padding-bottom: 56.25%;\"><iframe src=\"https:\/\/www.youtube.com\/embed\/15qrV2CNSoQ?rel=0&amp;showinfo=1&amp;hl=en-US\" style=\"border: 0; top: 0; left: 0; width: 100%; height: 100%; position: absolute;\" allowfullscreen scrolling=\"no\" allow=\"encrypted-media; accelerometer; gyroscope; picture-in-picture\"><\/iframe><\/div>\n<\/div>\n<\/div>\n<p>  <\/div>\n<\/div>\n<p>  <\/p>\n<h3>\u041f\u043e \u0437\u0430\u043b\u0438\u0432\u043a\u0435 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c \u0438 debug<\/h3>\n<p>  \u042f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b <a href=\"https:\/\/www.silabs.com\/documents\/public\/data-sheets\/CP2102-9.pdf\" rel=\"nofollow\">USB-TO-UART BRIDGE<\/a> \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c CP2102. \u0412\u043e \u043f\u0435\u0440\u0432\u044b\u0445 \u043e\u043d \u043a\u043e\u043c\u043f\u0430\u043a\u0442\u043d\u044b\u0439 \u0438 \u0432\u043e \u0432\u0442\u043e\u0440\u044b\u0445 \u0441\u0445\u0435\u043c\u0430 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0438 \u043f\u043e\u0447\u0442\u0438 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0434\u0435\u0442\u0430\u043b\u0435\u0439.  <\/p>\n<blockquote><p>Option 2: A 4.7 \u03bcF capacitor can be added if powering other devices from the on-chip regulator.<\/p><\/blockquote>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c REGIN \u0438 VBUS \u043a \u043f\u0438\u0442\u0430\u043d\u0438\u044e USB 5V \u0442\u043e \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0448\u0443\u043d\u0442\u0438\u0440\u0443\u044e\u0449\u0438\u0439 \u043a\u043e\u043d\u0434\u0435\u043d\u0441\u0430\u0442\u043e\u0440 \u043d\u0430 \u0432\u0445\u043e\u0434\u0435. \u0425\u043e\u0442\u044f \u0434\u0443\u043c\u0430\u044e \u043c\u043e\u0436\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0438 \u0431\u0435\u0437 \u043d\u0435\u0433\u043e. VDD \u043d\u0430 \u0447\u0438\u043f\u0435 \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044d\u0442\u043e \u0432\u044b\u0445\u043e\u0434! \u042f \u0441\u0434\u0435\u043b\u0430\u043b \u043e\u0448\u0438\u0431\u043a\u0443 \u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u043b \u0435\u0433\u043e \u043a 3.3V \u043f\u0438\u0442\u0430\u043d\u0438\u044f \u0441\u0445\u0435\u043c\u044b \u0438 \u043d\u0435 \u043c\u043e\u0433 \u043f\u043e\u043d\u044f\u0442\u044c \u043f\u043e\u0447\u0435\u043c\u0443 \u0443 \u043c\u0435\u043d\u044f \u043d\u0430 \u043f\u0438\u0442\u0430\u043d\u0438\u0438 4.65V ?!<\/p>\n<p>  \u041f\u043e \u0441\u0441\u044b\u043b\u043a\u0435 \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u0432\u043d\u0438\u0437\u0443 \u0435\u0441\u0442\u044c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043a 3.3V \u043f\u0438\u0442\u0430\u043d\u0438\u044f. \u041d\u043e \u0434\u0443\u043c\u0430\u044e \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u043d\u0435 \u043d\u0430\u0434\u043e \u043f\u0438\u0442\u0430\u0442\u044c CP2102 \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u043c \u043d\u0435 \u043d\u0430\u0434\u043e \u0437\u0430\u043b\u0438\u0432\u0430\u0442\u044c \u0438\u043b\u0438 \u0434\u0435\u0431\u0430\u0436\u0438\u0442\u044c \u0434\u0435\u0432\u0430\u0439\u0441 <\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/yy\/-k\/go\/yy-kgo5r6igfhil55qe7zg2j7wu.png\"><\/p>\n<h3>\u041f\u043e \u043c\u043e\u0434\u0443\u043b\u044e \u0437\u0430\u0440\u044f\u0434\u043a\u0438 \u0431\u0430\u0442\u0430\u0440\u0435\u0438<\/h3>\n<p>  \u0420\u0435\u0437\u0438\u0441\u0442\u043e\u0440 \u043d\u0430 LTC4054 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u0442 \u0442\u043e\u043a \u0437\u0430\u0440\u044f\u0434\u043a\u0438:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/rd\/ex\/5q\/rdex5qbeqitjred4al5o0c267ju.png\"><\/p>\n<h3>\u041f\u043e \u043f\u0438\u0442\u0430\u043d\u0438\u044e<\/h3>\n<p>  \u041f\u0438\u0442\u0430\u043d\u0438\u0435 \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0442 \u0431\u0430\u0442\u0430\u0440\u0435\u0439 3.7V \u0441\u043e \u0441\u0442\u0430\u0431\u0438\u043b\u0438\u0437\u0430\u0442\u043e\u0440\u043e\u043c HT7833. \u0412\u044b\u0445\u043e\u0434\u043d\u043e\u0439 \u0442\u043e\u043a 500mA. \u041e\u043d \u0438\u043c\u0435\u0435\u0442 \u043c\u0430\u043b\u043e\u0435 ~300mV \u043f\u0430\u0434\u0435\u043d\u0438\u0435 \u043d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u044f. LD1117-3.3 \u0438\u043c\u0435\u0435\u0442 \u00ab\u043d\u0435\u043c\u043d\u043e\u0433\u043e\u00bb \u0431\u043e\u043b\u044c\u0448\u0435.<\/p>\n<p>  \u0417\u0430\u043c\u0435\u0447\u0430\u043d\u0438\u0435 \u043f\u0440\u043e \u0432\u044b\u0432\u043e\u0434\u044b VDD_SDIO. \u042d\u0442\u043e\u0442 \u043f\u0438\u043d \u0432\u044b\u0445\u043e\u0434 \u043f\u0438\u0442\u0430\u043d\u0438\u044f 1.8V \u0438\u043b\u0438 3.3V \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0442\u043e\u0433\u043e \u0432 \u043a\u0430\u043a\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f IO12 \u043c\u0438\u043a\u0440\u043e\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 <b>\u043f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435<\/b>. 3.3V GPIO12 is 0 (default)   <\/p>\n<blockquote><p>VDD_SDIO works as the power supply for the related IO, and also for an external device.<\/p>\n<p>  When VDD_SDIO operates at 1.8 V, it can be generated from ESP32\u2019s internal LDO. The maximum currentthis LDO can offer is 40 mA, and the output voltage range is 1.65 V~2.0 V. <\/p>\n<p>  When the VDD_SDIO outputs 1.8 V, the value of GPIO12 should be set to 1 when the chip boots and it is recommended that users add a2 k\u2126 ground resistor and a 4.7 mF filter capacitor close to VDD_SDIO.<\/p>\n<p>  When VDD_SDIO operates at 3.3 V, it is driven directly by VDD3P3_RTC through a 6\u2126resistor, therefore,there will be some voltage drop from VDD3P3_RTC. <\/p>\n<p>  When the VDD_SDIO outputs 3.3 V, the value of GPIO12 is 0 (default) when the chip boots and it is recommended that users add a 1mF capacitor close to VDD_SDIO  <\/p><\/blockquote>\n<p>  \u042d\u0442\u043e \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u043e \u0435\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 flash 1.8V. \u041d\u043e \u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044f \u0437\u0430\u0431\u0438\u043b \u043d\u0430 \u044d\u0442\u043e\u0442 \u0432\u044b\u0432\u043e\u0434 \u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u043b \u043c\u043e\u044e 3V3 flash \u0438 PSRAM \u043a \u043e\u0431\u0449\u0435\u043c\u0443 \u043f\u0438\u0442\u0430\u043d\u0438\u044e<\/p>\n<p>  \u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0434\u0443\u043b\u0438 ESP32 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 VDD_SDIO \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430 IO12 \u043d\u0435\u043b\u044c\u0437\u044f \u043d\u0438\u0447\u0435\u0433\u043e \u0432\u0435\u0448\u0430\u0442\u044c \u0438\u0437 \u043f\u0435\u0440\u0435\u0444\u0438\u0440\u0438\u0438 \u043f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435. \u041c\u043e\u0436\u043d\u043e \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u043f\u043e\u0432\u0435\u0441\u0438\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443. \u0412 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u043c\u043e\u0438\u0445 \u0440\u0435\u0448\u0435\u043d\u0438\u0439 \u044f \u043f\u043e\u0432\u0435\u0441\u0438\u043b \u043d\u0430 IO12 \u043d\u043e\u0433\u0443 SPI \u0438 \u043c\u043e\u0434\u0443\u043b\u044c \u043d\u0435 \u0441\u0442\u0430\u0440\u0442\u043e\u0432\u0430\u043b. \u0412\u0438\u0434\u0438\u043c\u043e \u043d\u0430 IO12 \u043f\u043e\u043f\u0430\u043b\u0430 \u0435\u0434\u0438\u043d\u0438\u0446\u0430 \u0441 \u044d\u0442\u043e\u0433\u043e \u043f\u043e\u0440\u0442\u0430 SPI, \u0430 \u043d\u0443\u0436\u0435\u043d \u0431\u044b\u043b 0 \u0438\u043b\u0438 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442. \u042d\u0442\u043e \u043d\u0430\u0434\u043e \u0443\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c!<\/p>\n<p>  All together:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/cx\/-o\/ku\/cx-oku_wxajemjbyrjrilqm0xpc.png\" alt=\"image\">  <\/p>\n<h3>8MB PSRAM<\/h3>\n<p>  <a href=\"http:\/\/blog.pagefault-limited.co.uk\/lolin32-lite-esp32-8mb-psram-upgrade-mod\" rel=\"nofollow\">8MB PSRAM Upgrade Mod<\/a><br \/>  <a href=\"https:\/\/docs.espressif.com\/projects\/esp-idf\/en\/latest\/esp32\/api-guides\/external-ram.html\" rel=\"nofollow\">Support for external RAM<\/a><\/p>\n<h3>PCB antenna<\/h3>\n<p>  \u042f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b <a href=\"http:\/\/www.ti.com\/lit\/an\/swra117d\/swra117d.pdf\" rel=\"nofollow\">Small Size 2.4 GHz PCB antenna<\/a>. \u041e\u043d\u0430 \u0435\u0441\u0442\u044c \u0432 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 Eagle Autodesk \u0438 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0443\u044e \u043f\u043b\u043e\u0449\u0430\u0434\u044c. \u041c\u043e\u0436\u043d\u043e \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c CERAMIC DIELECTRIC ANTENNA \u043d\u043e \u0435\u0435 \u043d\u0430\u0434\u043e \u043f\u043e\u043a\u0443\u043f\u0430\u0442\u044c, \u0430 \u0446\u0435\u043d\u0430 PCB \u0430\u043d\u0442\u0435\u043d\u043d\u044b \u044d\u0442\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0431\u041e\u043b\u044c\u0448\u0435\u0435 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u043c\u043e\u0435 \u043c\u0435\u0441\u0442\u043e. \u041e\u0434\u043d\u0430\u043a\u043e \u043a\u0435\u0440\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0430\u043d\u0442\u0435\u043d\u043d\u0430 \u043c\u0435\u043d\u0435\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0430. \u0414\u043b\u044f \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u043a\u043e\u043d\u0446\u0435\u043f\u0442\u0430 \u043f\u043e\u0439\u0434\u0435\u0442<\/p>\n<p>  <img decoding=\"async\" width=\"400\" src=\"https:\/\/habrastorage.org\/webt\/m9\/0b\/lq\/m90blqi_al7oqlx6cgobpazbk4c.png\" alt=\"image\"><\/p>\n<p>  <a href=\"https:\/\/www.cypress.com\/file\/136236\/download\" rel=\"nofollow\">Antenna Design and RF Layout Guidelines<\/a><\/p>\n<h3>\u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043e \u0441 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u0438 \u0430\u043d\u0442\u0435\u043d\u043d\u044b<\/h3>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/py\/o-\/lx\/pyo-lxfj7y7lu51eltxs_f3u-mm.png\"><\/p>\n<p>  \u0412 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 <a href=\"https:\/\/www.espressif.com\/sites\/default\/files\/documentation\/esp32_hardware_design_guidelines_en.pdf\" rel=\"nofollow\">ESP32 Hardware Design Guidelines<\/a> \u043d\u0430 \u0441\u0442\u0440 7 \u0434\u0430\u0435\u0442\u0441\u044f \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u043f\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 RF \u0444\u0438\u043b\u044c\u0442\u0440\u0430:  <\/p>\n<blockquote><p>The output impedance of the RF pins of ESP32 (QFN 6*6) and ESP32 (QFN 5*5) are (30+j10) \u2126 and (35+j10) \u2126, respectively  <\/p><\/blockquote>\n<p>\u0414\u043b\u044f \u0440\u0430\u0441\u0447\u0435\u0442\u0430 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f <a href=\"https:\/\/www.will-kelsey.com\/smith_chart\/\" rel=\"nofollow\">Online Smith Chart Tool<\/a>. \u041e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0438\u0434\u0435\u044f \u043f\u043e\u043f\u0430\u0441\u0442\u044c \u0432 \u0446\u0435\u043d\u0442\u0440 \u043a\u0440\u0443\u0433\u0430 \u043f\u0440\u0438 (30+j10). \u041e\u0434\u043d\u0430\u043a\u043e \u044d\u0442\u043e \u0440\u0430\u0441\u0447\u0435\u0442\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0438 \u043d\u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u0432\u043b\u0438\u044f\u0442\u044c \u0442\u043e\u043b\u0449\u0438\u043d\u0430 \u0434\u043e\u0440\u043e\u0436\u0435\u043a \u0438 \u0442\u0435\u043a\u0441\u0442\u043e\u043b\u0438\u0442\u0430, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0434\u0440\u0443\u0433\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0441\u0445\u0435\u043c\u044b<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/mb\/lw\/w2\/mblww2rcjw5h5otg0bwgbfoqhgw.png\"><br \/>  \u042d\u0442\u043e \u043d\u0435 \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f \u0441\u0445\u0435\u043c\u0430 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u0430\u043d\u0442\u0435\u043d\u043d\u044b. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u043e\u0433\u043b\u0430\u0441\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430 \u043f\u043b\u0430\u0442\u0435 esp32-pic \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0438\u043d\u0430\u0447\u0435:<\/p>\n<p>  <a href=\"https:\/\/dl.espressif.com\/dl\/schematics\/esp32-pico-kit-v4_schematic.pdf\" rel=\"nofollow\">esp32-pico-kit-v4_schematic<\/a><\/p>\n<p>  <a href=\"https:\/\/nptel.ac.in\/content\/storage2\/nptel_data3\/html\/mhrd\/ict\/text\/108101112\/lec13.pdf\" rel=\"nofollow\">Smith Chart and Impedance Matching<\/a><\/p>\n<p>  \u0422\u0430\u043a \u0436\u0435 \u0432\u0430\u0436\u043d\u043e \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0430\u043d\u0442\u0435\u043d\u043d\u044b \u0438 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u0430\u044f \u043e\u0431\u043b\u0430\u0441\u0442\u044c \u0432\u043e\u043a\u0440\u0443\u0433 \u043d\u0435\u0435. \u041a\u0430\u043a \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0440\u0430\u043d\u0435\u0435, \u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0432\u044b\u0431\u0440\u0430\u043d\u043e \u043d\u0435 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e. \u041d\u043e \u0434\u043b\u044f \u043f\u0435\u0440\u0432\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043f\u043b\u0430\u0442\u044b \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u043a\u043e\u043d\u0446\u0435\u043f\u0442\u0430 \u043f\u043e\u0439\u0434\u0435\u0442<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/2y\/sk\/me\/2yskmeit4qo4hv0fhldmyq0xgpq.png\"><\/p>\n<p>  \u0412\u0442\u043e\u0440\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d\u0430 \u0441\u0430\u043c\u043e\u0439 \u043f\u043b\u0430\u0442\u0435 \u0430 \u0442\u0440\u0435\u0442\u044c\u044f \u043f\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \u0441\u043e\u0444\u0442\u0430. \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u0432\u0441\u0435 \u0443\u043c\u0435\u0441\u0442\u0438\u0442\u0441\u044f \u0432 \u043e\u0434\u043d\u0443. <\/p>\n<p>  \u042f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0437\u0430\u0431\u0435\u0433\u0443 \u0432\u043f\u0435\u0440\u0435\u0434 \u043f\u043e \u043f\u043e\u0440\u0442\u0443 <a href=\"https:\/\/github.com\/espressif\/esp32-doom\" rel=\"nofollow\">Doom<\/a> \u043e\u0442 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044f Espressif Systems. \u0412 \u043f\u043e\u0440\u0442\u0435 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f ILI9341 \u0443 \u043d\u0430\u0441 ST7789. \u041d\u043e \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0438 \u0432\u044b\u0432\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u0432\u044b\u043d\u0435\u0441\u0435\u043d \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0444\u0430\u0439\u043b \u0438 \u0440\u0430\u0437\u0431\u0438\u0442 \u043d\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b, \u0430\u0434\u0430\u043f\u0442\u0430\u0446\u0438\u044f \u043f\u043e\u0434 \u043c\u043e\u0439 \u0434\u0438\u0441\u043f\u043b\u0435\u0439 \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438. <\/p>\n<ul>\n<li>\u0417\u0430 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u0434\u0438\u0441\u043f\u043b\u0435\u044f \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 ili_init \u0438 displayTask<\/li>\n<li>\u0417\u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043d\u0430 \u0434\u0438\u0441\u043f\u043b\u0435\u0435 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 displayTask<\/li>\n<\/ul>\n<p>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">displayTask<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">void IRAM_ATTR displayTask(void *arg) { \tint x, i; \tint idx=0; \tint inProgress=0; \tstatic uint16_t *dmamem[NO_SIM_TRANS]; \tspi_transaction_t trans[NO_SIM_TRANS]; \tspi_transaction_t *rtrans;      esp_err_t ret;     spi_bus_config_t buscfg={         .miso_io_num=-1,         .mosi_io_num=PIN_NUM_MOSI,         .sclk_io_num=PIN_NUM_CLK,         .quadwp_io_num=-1,         .quadhd_io_num=-1,         .max_transfer_sz=(MEM_PER_TRANS*2)+16     };     spi_device_interface_config_t devcfg={         .clock_speed_hz=26000000,               \/\/Clock out at 26 MHz. Yes, that's heavily overclocked.         .mode=0,                                \/\/SPI mode 0         .spics_io_num=PIN_NUM_CS,               \/\/CS pin         .queue_size=NO_SIM_TRANS,               \/\/We want to be able to queue this many transfers         .pre_cb=ili_spi_pre_transfer_callback,  \/\/Specify pre-transfer callback to handle D\/C line     };  \tprintf(&quot;*** Display task starting.\\n&quot;);      \/\/Initialize the SPI bus     ret=spi_bus_initialize(HSPI_HOST, &amp;buscfg, 1);     assert(ret==ESP_OK);     \/\/Attach the LCD to the SPI bus     ret=spi_bus_add_device(HSPI_HOST, &amp;devcfg, &amp;spi);     assert(ret==ESP_OK);     \/\/Initialize the LCD     ili_init(spi);  \t\/\/We're going to do a fair few transfers in parallel. Set them all up. \tfor (x=0; x&lt;NO_SIM_TRANS; x++) { \t\tdmamem[x]=pvPortMallocCaps(MEM_PER_TRANS*2, MALLOC_CAP_DMA); \t\tassert(dmamem[x]); \t\tmemset(&amp;trans[x], 0, sizeof(spi_transaction_t)); \t\ttrans[x].length=MEM_PER_TRANS*2; \t\ttrans[x].user=(void*)1; \t\ttrans[x].tx_buffer=&amp;dmamem[x]; \t} \txSemaphoreGive(dispDoneSem);  \twhile(1) { \t\txSemaphoreTake(dispSem, portMAX_DELAY); \/\/\t\tprintf(&quot;Display task: frame.\\n&quot;); #ifndef DOUBLE_BUFFER \t\tuint8_t *myData=(uint8_t*)currFbPtr; #endif  \t\tsend_header_start(spi, 0, 0, 320, 240); \t\tsend_header_cleanup(spi); \t\tfor (x=0; x&lt;320*240; x+=MEM_PER_TRANS) { #ifdef DOUBLE_BUFFER \t\t\tfor (i=0; i&lt;MEM_PER_TRANS; i+=4) { \t\t\t\tuint32_t d=currFbPtr[(x+i)\/4]; \t\t\t\tdmamem[idx][i+0]=lcdpal[(d&gt;&gt;0)&amp;0xff]; \t\t\t\tdmamem[idx][i+1]=lcdpal[(d&gt;&gt;8)&amp;0xff]; \t\t\t\tdmamem[idx][i+2]=lcdpal[(d&gt;&gt;16)&amp;0xff]; \t\t\t\tdmamem[idx][i+3]=lcdpal[(d&gt;&gt;24)&amp;0xff]; \t\t\t} #else \t\t\tfor (i=0; i&lt;MEM_PER_TRANS; i++) { \t\t\t\tdmamem[idx][i]=lcdpal[myData[i]]; \t\t\t} \t\t\tmyData+=MEM_PER_TRANS; #endif \t\t\ttrans[idx].length=MEM_PER_TRANS*16; \t\t\ttrans[idx].user=(void*)1; \t\t\ttrans[idx].tx_buffer=dmamem[idx]; \t\t\tret=spi_device_queue_trans(spi, &amp;trans[idx], portMAX_DELAY); \t\t\tassert(ret==ESP_OK);  \t\t\tidx++; \t\t\tif (idx&gt;=NO_SIM_TRANS) idx=0;  \t\t\tif (inProgress==NO_SIM_TRANS-1) { \t\t\t\tret=spi_device_get_trans_result(spi, &amp;rtrans, portMAX_DELAY); \t\t\t\tassert(ret==ESP_OK); \t\t\t} else { \t\t\t\tinProgress++; \t\t\t} \t\t} #ifndef DOUBLE_BUFFER \t\txSemaphoreGive(dispDoneSem); #endif \t\twhile(inProgress) { \t\t\tret=spi_device_get_trans_result(spi, &amp;rtrans, portMAX_DELAY); \t\t\tassert(ret==ESP_OK); \t\t\tinProgress--; \t\t} \t} } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u0417\u0430\u043a\u0430\u0437 \u043d\u0430 \u043f\u043b\u0430\u0442\u0443 \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u0435\u043d \u043d\u0430 \u0444\u0430\u0431\u0440\u0438\u043a\u0443 Jlcpcb.<\/p>\n<p>  \u0427\u0435\u043b\u0435\u043d\u0436 \u0437\u0430\u043f\u0443\u0449\u0435\u043d!<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/494748\/\"> https:\/\/habr.com\/ru\/post\/494748\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\" data-io-article-url=\"https:\/\/habr.com\/ru\/post\/494748\/\">\u041f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0432 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0441 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 \u043c\u043e\u0434\u0443\u043b\u044f\u043c\u0438 ESP32 \u0437\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u0435 \u0438 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0435. \u0420\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0430\u0441\u044b. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u043e\u0434\u0443\u043c\u0430\u043b \u043e <a href=\"https:\/\/www.espressif.com\/sites\/default\/files\/documentation\/esp32-pico-d4_datasheet_en.pdf\" rel=\"nofollow\">ESP32-PICO-D4<\/a>. \u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0432 \u043d\u0435\u0439 \u0442\u043e\u043b\u044c\u043a\u043e 4Mb flash \u043f\u043e\u0434 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0443, \u0440\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u0441 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\u043c \u0434\u0430 16Mb flash \u0438 8Mb SRAM. \u0427\u0442\u043e \u0431\u044b \u043d\u0430 \u0447\u0430\u0441\u0430\u0445 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 Doom. \u0412 \u043e\u0431\u0449\u0435\u043c \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u0432\u0441\u0435 \u043d\u0430 \u043f\u043e\u043b\u043d\u043e\u043c \u0444\u0430\u0440\u0448\u0435!<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/r0\/tm\/qh\/r0tmqhwcgq1geu0iyijuroahpvq.png\"><\/p>\n<p>  \u0427\u0442\u043e \u043d\u0435 \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0438\u043b\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0438:<\/p>\n<ol>\n<li>\u0418\u043d\u0434\u0438\u043a\u0430\u0442\u043e\u0440 \u0431\u0430\u0442\u0430\u0440\u0435\u0438<\/li>\n<li> \u0421\u0445\u0435\u043c\u0430 \u0431\u0430\u0440\u044c\u0435\u0440\u0430 \u0437\u0430\u0440\u044f\u0434\u043a\u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u043d\u0430 Schottky \u0434\u0438\u043e\u0434\u0435<\/li>\n<li>\u0410\u043d\u0442\u0435\u043d\u0430 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0430 \u043d\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u0443\u0434\u0430\u0447\u043d\u043e \u0438 \u043d\u0430 \u0434\u0440\u0443\u0433\u043e\u043c \u0441\u043b\u043e\u0435 \u043e\u0442 ESP32  <\/li>\n<\/ol>\n<p>  \u041d\u0435 \u0442\u0443\u0442\u043e\u0440\u0438\u0430\u043b!<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bw\/cn\/gr\/bwcngruk2zywo5wuqk-zvco4toq.jpeg\">  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-300984","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/300984","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=300984"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/300984\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=300984"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=300984"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=300984"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}