{"id":331340,"date":"2022-03-31T21:00:15","date_gmt":"2022-03-31T21:00:15","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=331340"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=331340","title":{"rendered":"<span>Zynq 7000. \u041f\u0440\u0438\u043a\u0440\u0443\u0447\u0438\u0432\u0430\u0435\u043c Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044c RTL8822CS \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c SDIO \u0447\u0435\u0440\u0435\u0437 EMIO<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446-\u0442\u043e \u043f\u0440\u0438\u0448\u043b\u0430 \u043f\u043e\u0440\u0430 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u044c \u0438\u0437\u0443\u0447\u0435\u043d\u0438\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u043b\u0430\u0442\u044b Zynq QMTech \u0438 SoC XC7Z020. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0430\u044f \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u044f \u0434\u043b\u044f \u0441\u0435\u0431\u044f \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043e\u0431\u0443\u0447\u0430\u044e\u0449\u0435\u0439 &#8212; \u043e\u0441\u043d\u0430\u0441\u0442\u0438\u0442\u044c \u043f\u043b\u0430\u0442\u0443 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u0435\u043c Realtek RTL8822CS \u0438, \u0435\u0441\u043b\u0438 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044c \u0431\u0443\u0434\u0435\u0442 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d, \u0430 \u043d\u0443\u0436\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0435\u0449\u0451 \u043e\u0434\u043d\u0430 \u0444\u043b\u0435\u0448\u043a\u0430 &#8212; \u0432\u0442\u043e\u0440\u044b\u043c \u043f\u043e\u0440\u0442\u043e\u043c \u0434\u043b\u044f SD-\u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438. \u0415\u0441\u043b\u0438 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0441\u0442\u0438 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044f \u044d\u0442\u043e \u0432\u0441\u0451 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043b &#8212; \u0434\u043e\u0431\u0440\u043e \u043f\u043e\u0436\u0430\u043b\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0442.\u00a0<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/1f4\/0b1\/842\/1f40b1842a5c4beba0adc49d0afcdc35.png\" width=\"711\" height=\"405\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/1f4\/0b1\/842\/1f40b1842a5c4beba0adc49d0afcdc35.png\"\/><figcaption><\/figcaption><\/figure>\n<p><strong>\u0412\u0430\u0436\u043d\u043e!<\/strong> \u041f\u0435\u0440\u0435\u0434 \u043d\u0430\u0447\u0430\u043b\u043e\u043c \u043f\u043e\u0432\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043d\u0438\u044f, \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0431\u044b \u0437\u0430\u0440\u0430\u043d\u0435\u0435 \u043e\u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0446\u0435\u043b\u044c, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u044f \u043f\u0440\u0435\u0441\u043b\u0435\u0434\u0443\u044e \u043f\u0440\u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438 &#8212; \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043e \u0441\u0432\u043e\u0435\u043c \u043e\u043f\u044b\u0442\u0435, \u0441 \u0447\u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0447\u0430\u0442\u044c, \u043f\u0440\u0438 \u0438\u0437\u0443\u0447\u0435\u043d\u0438\u0438 \u043e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u044b\u0445 \u043f\u043b\u0430\u0442 \u043d\u0430 \u0431\u0430\u0437\u0435 Zynq. \u042f \u043d\u0435 \u044f\u0432\u043b\u044f\u044e\u0441\u044c \u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u043c \u043f\u043e\u0434 \u041f\u041b\u0418\u0421 \u0438 SoC Zynq, \u043d\u0435 \u044f\u0432\u043b\u044f\u044e\u0441\u044c \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0441\u0442\u043e\u043c \u043f\u043e\u0434 Linux \u0438 \u043c\u043e\u0433\u0443 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u043a\u0430\u043a\u0438\u0435-\u043b\u0438\u0431\u043e \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u0442\u0435\u0440\u043c\u0438\u043d\u043e\u043b\u043e\u0433\u0438\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0443\u0442\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447, etc. \u041d\u043e \u043e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u043b\u044e\u0431\u0430\u044f \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u0438 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u043a\u0440\u0438\u0442\u0438\u043a\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442\u0441\u044f. \u0427\u0442\u043e \u0436, \u043f\u043e\u0435\u0445\u0430\u043b\u0438\u2026<\/p>\n<h2>\u0421\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u043c \u0446\u0435\u043b\u044c \u0438 \u0437\u0430\u0434\u0430\u0447\u0438<\/h2>\n<p>\u0418\u0442\u0430\u043a, \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u043f\u043b\u0430\u0442\u0430, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u0430\u044f \u0432 \u044d\u0442\u043e\u0439 (<a href=\"https:\/\/habr.com\/ru\/post\/559946\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/559946\/<\/u><\/a>) \u0441\u0442\u0430\u0442\u044c\u0435 \u0438 \u0435\u0441\u0442\u044c \u0436\u0435\u043b\u0430\u043d\u0438\u0435 \u043f\u0440\u0438\u043a\u0440\u0443\u0442\u0438\u0442\u044c \u043a \u043d\u0435\u0439 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044c Realtek RTL8822CS. \u041c\u043e\u0434\u0443\u043b\u044c, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0434\u043e\u043b\u0436\u0435\u043d \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u041e\u0421 Linux \u0438 \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0438\u0442\u044c \u043f\u0440\u043e\u043f\u0443\u0441\u043a\u043d\u0443\u044e \u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c \u0434\u043e 150 \u041c\u0431\u0438\u0442\\\u0441 (\u0441 \u0447\u0435\u043c \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0442\u0430\u043a\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435\u00a0 \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u043e\u0439 \u0446\u0438\u0444\u0440\u043e\u0439 &#8212; \u043d\u0438\u0436\u0435). \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430 \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u043d\u043e\u0433\u043e SDIO &#8212; \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u0442\u043e\u0440\u043e\u0439 \u043f\u043e\u0440\u0442 \u0434\u043b\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f SD-\u043a\u0430\u0440\u0442.<\/p>\n<p>\u0418\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0434\u0430\u0447, \u0440\u0435\u0448\u0438\u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0434\u043e\u0441\u0442\u0438\u0433\u043d\u0443\u0442\u044c \u0446\u0435\u043b\u0438:<\/p>\n<ol>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u043d\u043e\u0441\u0430 \u043b\u0438\u043d\u0438\u0439 SDIO \u0447\u0435\u0440\u0435\u0437 EMIO (\u0442.\u0435. \u0447\u0435\u0440\u0435\u0437 \u043f\u0438\u043d\u044b PL-\u0447\u0430\u0441\u0442\u0438 Zynq) \u0438 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c bitstream-\u0444\u0430\u0439\u043b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c SDIO \u0447\u0435\u0440\u0435\u0437 EMIO \u0432 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0438 baremetal \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c microSD-\u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0418\u0437\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u0435\u0437\u043e\u043d\u0438\u043d\u043d\u044b\u0435 \u043f\u043b\u0430\u0442\u044b \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u043d\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c First Stage Bootloader, Device Tree Source, U-Boot, Linux Kernel \u0432 \u043d\u0443\u0436\u043d\u043e\u0439 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u043c\u043e\u0434\u0443\u043b\u044c cfg80211, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438\u043d\u0443\u043a\u0441\u043e\u0432\u044b\u043c API \u0434\u043b\u044f 802.11 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 88x2cs, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u043e\u043c \u0434\u043b\u044f \u043c\u043e\u0434\u0443\u043b\u044f Wi-Fi RTL8822CS \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e\u0432\u0435\u0440\u0445 SDIO-\u0448\u0438\u043d\u044b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u0438, \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043a\u0430\u043d\u044b \u044d\u0444\u0438\u0440\u0430, \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0440\u0430\u0431\u043e\u0447\u0438\u0435 \u0443\u0440\u043e\u0432\u043d\u0438, \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0437\u0430\u043c\u0435\u0440\u044b \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 downstream\/upstream-\u0442\u0440\u0430\u0444\u0438\u043a\u043e\u043c \u0447\u0435\u0440\u0435\u0437 iPerf;<\/p>\n<\/li>\n<\/ol>\n<p>\u0418\u0442\u0430\u043a. \u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0430\u043c\u0435\u0447\u0435\u043d\u043d\u043e\u0433\u043e, \u0432 \u0446\u0435\u043b\u043e\u043c, \u043d\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u0438\u043b\u044c\u043d\u043e \u0441\u043b\u043e\u0436\u043d\u043e =)<\/p>\n<h2>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432 Vivado \u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f PL<\/h2>\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0433\u043b\u0430\u0432\u0435 \u044f \u043a\u0440\u0430\u0442\u043a\u043e (\u0431\u0435\u0437 \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442\u043e\u0432) \u043e\u043f\u0438\u0448\u0443 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 \u0430\u043a\u0446\u0435\u043d\u0442\u0430\u043c\u0438 \u043d\u0430 \u0432\u0430\u0436\u043d\u044b\u0445 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u0445. \u0415\u0441\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f \u0441 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430\u043c\u0438 &#8212; \u043c\u043e\u0436\u043d\u043e \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c\u0441\u044f \u043a \u043c\u043e\u0438\u043c \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u043c \u0441\u0442\u0430\u0442\u044c\u044f\u043c.\u00a0<\/p>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c <strong><em>Vivado<\/em><\/strong> \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 \u0447\u0435\u0440\u0435\u0437 \u043a\u043d\u043e\u043f\u043a\u0443 <strong><em>Create Project<\/em><\/strong>. \u041e\u0442\u043a\u0440\u043e\u0435\u0442\u0441\u044f \u043c\u0430\u0441\u0442\u0435\u0440 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430, \u0431\u044b\u0441\u0442\u0440\u043e \u043f\u0440\u043e\u0439\u0434\u0435\u043c\u0441\u044f \u043f\u043e \u0448\u0430\u0433\u0430\u043c.\u00a0<\/p>\n<ol>\n<li>\n<p>\u0414\u0430\u0451\u043c \u0438\u043c\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0443, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 <strong><em>SDIO_EMIO<\/em><\/strong> \u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u043f\u0430\u043f\u043a\u0443 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p>\u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c, \u0447\u0442\u043e \u044d\u0442\u043e <strong><em>RTL Project<\/em><\/strong>, \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u0439 \u0433\u0430\u043b\u043e\u0447\u043a\u0443 <strong><em>Do not specify sources at this time<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0445\u043e\u0434\u0438\u043c \u043c\u043e\u0434\u0435\u043b\u044c SoC \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430 \u043f\u043b\u0430\u0442\u0435. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044d\u0442\u043e <strong><em>xc7z020clg400-1<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c Finish.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u043b\u0435\u0432\u043e\u043c \u043c\u0435\u043d\u044e <strong><em>IP Integrator<\/em><\/strong> \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Create Block Design<\/em><\/strong> \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0434\u0438\u0437\u0430\u0439\u043d. \u041d\u0430\u0437\u043e\u0432\u0451\u043c \u0435\u0433\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u044b <strong><em>block_design<\/em><\/strong>.<\/p>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b Zynq \u043d\u0430 \u0434\u0438\u0430\u0433\u0440\u0430\u043c\u043c\u0443 \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0436\u0430\u0442\u0438\u0435 \u043f\u0440\u0430\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u043e\u0439 <strong><em>Add IP &#8212; ZYNQ7 Processing System<\/em><\/strong>. \u0421\u0440\u0430\u0437\u0443 \u0436\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043e\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0442\u043e\u0440\u0430, \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u043d\u0430 \u0437\u0435\u043b\u0435\u043d\u043e\u043c \u043f\u043e\u043b\u0435 <strong><em>Run Block Automation<\/em><\/strong> \u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b.\u00a0<\/p>\n<p>\u042f \u0437\u0430\u0440\u0430\u043d\u0435\u0435 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u043b \u0448\u0430\u0431\u043b\u043e\u043d \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a PS, \u0447\u0442\u043e\u0431\u044b \u0432 \u043a\u0430\u0436\u0434\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043d\u0435 \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0451 \u0437\u0430\u043d\u043e\u0432\u043e. \u0412\u0437\u044f\u0442\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0442\u0443\u0442 (<a href=\"https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/ZynqQMTech.tcl\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/ZynqQMTech.tcl<\/u><\/a>). \u0427\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>Presets &#8212; Apply Configuration <\/em><\/strong>\u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0435\u0433\u043e \u0438 \u0441\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>Peripherial I\/O Pins<\/em><\/strong>.<\/p>\n<p>\u0421\u0442\u0430\u0432\u0438\u043c \u0433\u0430\u043b\u043e\u0447\u043a\u0443 \u0432\u043e\u0437\u043b\u0435 \u043c\u0435\u043d\u044e <strong><em>SD 1<\/em><\/strong> \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0432\u044b\u0431\u0440\u0430\u043d \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0447\u0435\u0440\u0435\u0437 <strong><em>EMIO<\/em><\/strong>:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/522\/4e6\/25a\/5224e625a4ecf1a10e2699c08bd368cc.png\" width=\"833\" height=\"720\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/522\/4e6\/25a\/5224e625a4ecf1a10e2699c08bd368cc.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u044f \u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439, \u0432 \u0442.\u0447. \u0447\u0430\u0441\u0442\u043e\u0442\u044b \u0442\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f SDIO, PL. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u0430\u0440\u0442\u0438\u043d\u0443 (\u0435\u0441\u043b\u0438 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0433\u0440\u0443\u043f\u043f\u0443 \u0441\u0438\u0433\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043b\u0438\u043d\u0438\u0439 <strong><em>SDIO_1<\/em><\/strong>):<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/1b4\/f6f\/385\/1b4f6f3853c024147049ddb371be1fa0.png\" width=\"568\" height=\"492\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/1b4\/f6f\/385\/1b4f6f3853c024147049ddb371be1fa0.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0430\u0441 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u044e\u0442 \u043b\u0438\u043d\u0438\u0438 CLK, CMD \u0438 4 \u043b\u0438\u043d\u0438\u0438 DATA, \u0447\u0442\u043e \u0432 \u043e\u0431\u0449\u0435\u043c-\u0442\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0434\u043b\u044f SDIO-\u0448\u0438\u043d\u044b. \u041d\u043e \u0432\u043e\u0442 \u043d\u0435\u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u0430\u0436\u0434\u0430\u044f \u0438\u0437 \u043b\u0438\u043d\u0438\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0442\u0440\u0435\u043c\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u043c\u0438 \u0441\u0438\u0433\u043d\u0430\u043b\u0430\u043c\u0438. \u0414\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0440\u0443\u043a\u0430\u043c\u0438 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0431\u0443\u0444\u0435\u0440 IOBUF, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0438\u043d T \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 \u0438 \u0440\u0430\u0437\u0440\u0443\u043b\u0438\u0442 Input, Output \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u043a\u0430\u043a \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0435\u0433\u043e \u0441 \u0434\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u043c \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u043c I\/O. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043e\u043d \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/6c4\/d76\/58b\/6c4d7658be9b0cf6c1c2d277866bb42e.png\" width=\"644\" height=\"408\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6c4\/d76\/58b\/6c4d7658be9b0cf6c1c2d277866bb42e.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0422.\u043a. \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0445 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u0432 \u043e\u043d \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 &#8212; \u043d\u0443\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0432\u043e\u0439 IP-\u043c\u043e\u0434\u0443\u043b\u044c \u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0435\u0433\u043e \u043d\u0430 \u0441\u0445\u0435\u043c\u0443. \u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u043e\u043d \u0431\u0443\u0434\u0435\u0442 \u0441\u0432\u043e\u0439.\u00a0\u00a0<\/p>\n<p>\u0427\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>Sources &#8212; Add Sources (Alt + A)<\/em><\/strong> \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c <strong><em>Design Source &#8212; Create File<\/em><\/strong>, \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0442\u0438\u043f \u0444\u0430\u0439\u043b\u0430 <strong><em>Verilog<\/em><\/strong> \u0438 \u043d\u0430\u0437\u043e\u0432\u0451\u043c \u0435\u0433\u043e <strong><em>iobuf_cmd<\/em><\/strong>.<\/p>\n<p>\u0417\u0430\u043f\u0438\u0448\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:<\/p>\n<pre><code>module iobuf_cmd ( \u00a0\u00a0\u00a0\u00a0input iobuf_i, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout\u00a0 iobuf_io \u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0.O(iobuf_o),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.IO(iobuf_io),\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0.I(iobuf_i),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.T(iobuf_t) \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 ); endmodule\u00a0<\/code><\/pre>\n<p>\u0422\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 CLK, \u0442\u043e\u043b\u044c\u043a\u043e \u0444\u0430\u0439\u043b \u043d\u0430\u0437\u043e\u0432\u0451\u043c <strong><em>iobuf_clk<\/em><\/strong>. \u0417\u0430\u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435:<\/p>\n<pre><code>module iobuf_clk ( \u00a0\u00a0\u00a0\u00a0input iobuf_i, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout\u00a0 iobuf_io\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0.O(iobuf_o),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.IO(iobuf_io),\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0.I(iobuf_i),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.T(iobuf_t) \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 ); endmodule\u00a0<\/code><\/pre>\n<p>\u0421 SDIO DATA \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u043b\u043e\u0436\u043d\u0435\u0435 \u0442.\u043a. \u043e\u043d\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043b\u0438\u043d\u0438\u0439. \u0422\u0430\u043a \u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0444\u0430\u0439\u043b <strong><em>iobuf_data<\/em><\/strong> \u0438 \u0437\u0430\u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:<\/p>\n<pre><code>module iobuf_data ( \u00a0\u00a0\u00a0\u00a0input [3:0] iobuf_i,\u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t,\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output [3:0]iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout [3:0] iobuf_io\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  \u00a0\u00a0\u00a0\u00a0generate\u00a0 genvar i ; for (i=0; i&lt;4; i=i+1)\u00a0 \u00a0\u00a0\u00a0\u00a0begin\u00a0  \u00a0\u00a0\u00a0\u00a0IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) \u00a0\u00a0\u00a0\u00a0\u00a0IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.O\u00a0 (iobuf_o[i]),\u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 .IO (iobuf_io[i]), \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.I\u00a0 (iobuf_i[i]),\u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.T\u00a0 (iobuf_t)\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0); \u00a0\u00a0\u00a0\u00a0end \u00a0\u00a0\u00a0\u00a0endgenerate endmodule<\/code><\/pre>\n<p>\u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437 \u043b\u0438\u043d\u0438\u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0441\u0432\u043e\u0439 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u0430 IOBUF.<\/p>\n<p>\u041f\u043e\u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e \u0440\u0430\u0437\u043c\u0435\u0449\u0430\u0435\u043c \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u043c\u043e\u0434\u0443\u043b\u0438 \u043d\u0430 \u0434\u0438\u0430\u0433\u0440\u0430\u043c\u043c\u0443 \u0447\u0435\u0440\u0435\u0437 \u043a\u043b\u0438\u043a \u043f\u0440\u0430\u0432\u043e\u0439 \u043c\u044b\u0448\u043a\u043e\u0439 \u043f\u043e <strong><em>Diagram &#8212; Add Module<\/em><\/strong>. \u0421\u043e\u0435\u0434\u0438\u043d\u044f\u0435\u043c \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u0441 \u043d\u0443\u0436\u043d\u044b\u043c\u0438 \u043f\u043e\u0440\u0442\u0430\u043c\u0438 \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435: <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/60c\/884\/937\/60c884937e087e0faa2b3445b80bfb74.png\" width=\"895\" height=\"552\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/60c\/884\/937\/60c884937e087e0faa2b3445b80bfb74.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0425\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0431\u044b \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0434\u0432\u0435 \u0432\u0430\u0436\u043d\u044b\u0435 \u0432\u0435\u0449\u0438:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430 \u043f\u043e\u0440\u0442 <strong><em>iobuf_t<\/em><\/strong> \u043c\u043e\u0434\u0443\u043b\u044f \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 <strong><em>CLK <\/em><\/strong>\u044f \u0434\u043e\u0431\u0430\u0432\u0438\u043b Constant \u0441 \u0448\u0438\u0440\u0438\u043d\u043e\u0439 \u0432 1 \u0431\u0438\u0442 \u0438 \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c 0, \u0442.\u043a. \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u044e\u0449\u0435\u0433\u043e T-\u043f\u0438\u043d\u0430 \u0434\u043b\u044f CLK \u043d\u0435 \u043f\u0440\u0435\u0434\u0443\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043e;<\/p>\n<\/li>\n<li>\n<p>\u0421\u0434\u0435\u043b\u0430\u043b \u043f\u043e\u0440\u0442\u044b <strong><em>iobuf_io<\/em><\/strong> \u043a\u0430\u043a <strong><em>External<\/em><\/strong> \u0438 \u0434\u0430\u043b \u0438\u043c \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p>\u0421\u043e\u0435\u0434\u0438\u043d\u0438\u043b \u043f\u043e\u0440\u0442\u044b <strong><em>Input<\/em><\/strong> \u0441 \u043f\u043e\u0440\u0442\u0430\u043c\u0438 <strong><em>Output<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u041d\u0430 \u0442\u0435\u043a\u0443\u0449\u0435\u043c \u044d\u0442\u0430\u043f\u0435 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0441\u0438\u043d\u0442\u0435\u0437 \u0438 \u043d\u0430\u0437\u043d\u0430\u0447\u0438\u0442\u044c \u0432\u044b\u0445\u043e\u0434\u044b \u043f\u043e\u0440\u0442\u043e\u0432 \u043d\u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043f\u043e\u0440\u0442\u044b. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c \u043d\u0430 \u043c\u0435\u043d\u044e <strong><em>block_design<\/em><\/strong> \u043f\u0440\u0430\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u043e\u0439 \u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>Create HDL Wrapper<\/em><\/strong>.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0412 \u043c\u0435\u043d\u044e <strong><em>IP Integrator<\/em><\/strong> \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Generate Block Design<\/em><\/strong>;\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Synthesis Option &#8212; Global<\/em><\/strong> \u0438 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Apply<\/em><\/strong>, \u0437\u0430\u0442\u0435\u043c <strong><em>Generate<\/em><\/strong>.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Run Synthesis<\/em><\/strong> \u0434\u043b\u044f \u0441\u0442\u0430\u0440\u0442\u0430 \u0441\u0438\u043d\u0442\u0435\u0437\u0430 \u043d\u0430\u0448\u0435\u0433\u043e \u0434\u0438\u0437\u0430\u0439\u043d\u0430.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0438\u043d\u0442\u0435\u0437\u0430;<\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0438\u043d\u0442\u0435\u0437\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>Open Synthesized Design <\/em><\/strong>\u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u0442\u0441\u044f \u043c\u0435\u043d\u044e <strong><em>Package<\/em><\/strong> \u0441 \u043d\u0438\u0436\u043d\u0438\u043c \u043c\u0435\u043d\u044e <strong><em>I\/O Ports<\/em><\/strong>. \u0414\u0430\u043b\u0435\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e:<\/p>\n<ol>\n<li>\n<p>\u041e\u0442\u043c\u0435\u0442\u0438\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438\u0435 I\/O \u043f\u0438\u043d\u044b<\/p>\n<\/li>\n<li>\n<p>\u0423\u0431\u0435\u0434\u0438\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0430 \u043f\u043e\u0434\u0442\u044f\u0436\u043a\u0430 PULLUP \u043d\u0430 \u0432\u0441\u0435\u0445 \u043f\u0438\u043d\u0430\u0445 \u043a\u0440\u043e\u043c\u0435 CLK;<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e38\/96e\/4c8\/e3896e4c823181edc37e95018b770af4.png\" width=\"1600\" height=\"524\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e38\/96e\/4c8\/e3896e4c823181edc37e95018b770af4.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438, \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0444\u0430\u0439\u043b \u0441 <strong><em>constraints<\/em><\/strong>. \u041d\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u0435\u0433\u043e \u043a\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u0438 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Ok<\/em><\/strong>. \u041f\u043e\u0441\u043b\u0435 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Generate bitstream<\/em><\/strong>, \u0441\u043e\u0433\u043b\u0430\u0448\u0430\u0435\u043c\u0441\u044f \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0441\u0438\u043d\u0442\u0435\u0437 \u0443\u0441\u0442\u0430\u0440\u0435\u043b \u0438 \u0436\u0434\u0435\u043c \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0432\u0441\u0435\u0445 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440 \u0434\u043e \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f:<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/36a\/53d\/b4a\/36a53db4a28eae08bea232d61d4c997b.png\" width=\"441\" height=\"354\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/36a\/53d\/b4a\/36a53db4a28eae08bea232d61d4c997b.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u0435\u043c \u044d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c BSP \u0432 SDK \u0438 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u0438 SDIO \u0432 baremetal. \u0414\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u044d\u0442\u043e \u0447\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>File &#8212; Export &#8212; Export Hardware<\/em><\/strong>, \u0441\u0442\u0430\u0432\u0438\u043c <strong><em>Include bitstream<\/em><\/strong>. \u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Ok<\/em><\/strong> \u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c SDK \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>File &#8212; Launch SDK<\/em><\/strong>.<\/p>\n<h2>\u041f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 SDIO \u0447\u0435\u0440\u0435\u0437 microSD-\u043a\u0430\u0440\u0442\u0443 \u0432 Baremetal<\/h2>\n<p>\u041f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u0442\u044c \u043a \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c microSD-\u043a\u0430\u0440\u0442\u0443 \u043a \u043f\u0438\u043d\u0430\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0440\u0430\u0437\u043c\u0435\u0447\u0430\u043b\u0438 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0440\u0430\u0437\u0434\u0435\u043b\u0435. \u0421\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u043f\u0435\u0440\u0432\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u043d\u0430 \u0440\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0443 microSD-\u043a\u0430\u0440\u0442\u044b:<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/594\/d64\/fd7\/594d64fd794748b2345a683a28f90da6.png\" width=\"421\" height=\"259\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/594\/d64\/fd7\/594d64fd794748b2345a683a28f90da6.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0421 \u043f\u0438\u043d\u0430\u043c\u0438 VDD (3.3V) \u0438 VSS (GND) \u0432\u0441\u0451 \u0432 \u0446\u0435\u043b\u043e\u043c \u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u0421 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u043f\u0438\u043d\u0430\u043c\u0438 \u0435\u0441\u0442\u044c \u043d\u044e\u0430\u043d\u0441, \u0434\u043b\u044f \u043f\u0438\u043d\u0430 CMD \u0438 \u0448\u0438\u043d\u044b DATA \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0442\u044f\u0436\u043a\u0430 \u043a \u0432\u044b\u0441\u043e\u043a\u043e\u043c\u0443 \u0443\u0440\u043e\u0432\u043d\u044e \u0447\u0435\u0440\u0435\u0437 10 \u043a\u041e\u043c \u0440\u0435\u0437\u0438\u0441\u0442\u043e\u0440\u044b. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0447\u0442\u043e\u0431\u044b \u043d\u0435 \u0433\u043e\u0440\u043e\u0434\u0438\u0442\u044c \u043d\u0430\u0432\u0435\u0441\u043d\u044b\u043c \u043c\u043e\u043d\u0442\u0430\u0436\u043e\u043c \u0440\u0435\u0437\u0438\u0441\u0442\u043e\u0440\u044b, \u044f \u0432\u0437\u044f\u043b \u043e\u0434\u043d\u0443 \u0438\u0437 \u043f\u043b\u0430\u0442, \u0437\u0430\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0445 \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u0437\u0430\u043f\u0430\u044f\u043b \u043d\u0430 \u043d\u0435\u0433\u043e \u0432\u0441\u0435 \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/3a0\/797\/40f\/3a079740ff6982ba2b59b4f298ac483f.png\" width=\"692\" height=\"611\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3a0\/797\/40f\/3a079740ff6982ba2b59b4f298ac483f.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u044d\u0442\u043e\u0439 \u043f\u043b\u0430\u0442\u044b &#8212; \u0432\u0441\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0432\u043e\u0442 \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/76e\/ab6\/fef\/76eab6fef6c96a4b520b67d4177ca83e.png\" width=\"877\" height=\"459\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/76e\/ab6\/fef\/76eab6fef6c96a4b520b67d4177ca83e.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041f\u0438\u0442\u0430\u043d\u0438\u0435 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043e \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u043e\u043d\u043e \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u043e \u043d\u0430 \u0433\u0440\u0435\u0431\u0435\u043d\u043a\u0443. \u0414\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430 \u043e\u0442\u043b\u0430\u0434\u043a\u0438 \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0430\u043d\u0430\u043b\u0438\u0437\u0430\u0442\u043e\u0440\u043e\u043c &#8212; \u044f \u043f\u043e\u0434\u043f\u0430\u0438\u0432\u0430\u043b \u041c\u0413\u0422\u0424-\u043f\u0440\u043e\u0432\u043e\u0434\u043a\u0438.\u00a0<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043b\u0438\u043d\u0438\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u044b &#8212; \u043c\u043e\u0436\u043d\u043e \u0432\u0435\u0440\u043d\u0443\u0442\u044c\u0441\u044f \u0432 SDK \u043a \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u043f\u0440\u043e\u0435\u043a\u0442\u0430. \u041f\u043e\u0441\u043b\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430 SDK \u043e\u0431\u0437\u044b\u0432\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 <strong><em>SDIO_EMIO<\/em><\/strong> \u0438 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Next<\/em><\/strong>, \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0448\u0430\u0431\u043b\u043e\u043d \u043f\u0440\u043e\u0435\u043a\u0442\u0430 <strong><em>Hello World<\/em><\/strong>.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e68\/cae\/1f9\/e68cae1f9e9d65ce3c694c6b7130053c.png\" width=\"569\" height=\"769\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e68\/cae\/1f9\/e68cae1f9e9d65ce3c694c6b7130053c.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0444\u0430\u0439\u043b helloworld.c \u0438\u0437 \u0434\u0440\u0435\u0432\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0438 \u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442 \u043d\u0443\u0436\u043d\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u043d\u0430\u043c \u0431\u044b\u0441\u0442\u0440\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443:<\/p>\n<pre><code class=\"cpp\">#include &lt;stdio.h> #include \"platform.h\" #include \"xil_printf.h\" #include \"xsdps.h\" #include \"xparameters.h\" #include \"xil_types.h\"  int main() { int Status;  static XSdPs SdInstance; XSdPs_Config *SdConfig;      init_platform();      xil_printf(\"\\r\\nSD Raw Read\/ Write Test\\r\\n\");  SdConfig = XSdPs_LookupConfig(XPAR_XSDPS_1_DEVICE_ID);      if (NULL == SdConfig)     {       xil_printf(\"XSdPs_LookupConfig failed\\r\\n\");       return XST_FAILURE;     }     else     {       xil_printf(\"XSdPs_LookupConfig ok \\r\\n\");     }      Status = XSdPs_CfgInitialize(&amp;SdInstance, SdConfig, SdConfig->BaseAddress);     if (Status != XST_SUCCESS)     {       xil_printf(\"XSdPs_CfgInitialize failed \\r\\n\");       return XST_FAILURE;     }     else     {       xil_printf(\"XSdPs_CfgInitialize ok \\r\\n\");     }      Status = XSdPs_CardInitialize(&amp;SdInstance);     xil_printf(\"XSdPs_CardInitialize... \\r\\n\");     if (Status != XST_SUCCESS)     {       xil_printf(\"XSdPs_CardInitialize failed \\r\\n\");     }     else     {       xil_printf(\"XSdPs_CardInitialize ok \\r\\n\");     } } <\/code><\/pre>\n<p>\u041a\u043b\u0438\u043a\u0430\u0435\u043c \u043f\u0440\u0430\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u043e\u0439 \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 <strong><em>SDIO_EMIO<\/em><\/strong> \u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Build Project<\/em><\/strong>. \u0421\u043c\u043e\u0442\u0440\u0438\u043c, \u0447\u0442\u043e \u043f\u0440\u043e\u0435\u043a\u0442 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u0442\u0441\u044f \u0431\u0435\u0437 \u043f\u0440\u043e\u0431\u043b\u0435\u043c. \u0412\u0430\u0436\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 &#8212; \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 SDIO-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u0432 \u0441\u0442\u0440\u043e\u043a\u0435 <strong>SdConfig = XSdPs_LookupConfig(XPAR_XSDPS_1_DEVICE_ID);<\/strong><\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c JTAG-\u043e\u0442\u043b\u0430\u0434\u0447\u0438\u043a \u0438 \u043f\u043e\u0441\u043b\u0435 \u0441\u0431\u043e\u0440\u043a\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0437\u0430\u043b\u0438\u0432\u0430\u0435\u043c <strong><em>bitstream-\u0444\u0430\u0439\u043b<\/em><\/strong> \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0432 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>Xilinx &#8212; Program FPGA<\/em><\/strong> \u0438 \u0434\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 <strong><em>FPGA DONE<\/em><\/strong> \u043d\u0430 \u043f\u043b\u0430\u0442\u0435.\u00a0<\/p>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c Serial Port, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0438\u0442 \u043d\u0430\u0448\u0435\u0439 \u043f\u043b\u0430\u0442\u0435. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440: minicom -D \/dev\/ttyUSB0. \u0423\u0437\u043d\u0430\u0442\u044c \u043a\u0430\u043a\u043e\u0439 \u043f\u043e\u0440\u0442 \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0438\u0442 \u043f\u043b\u0430\u0442\u0435 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0432 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 udevadm monitor | grep ttyUSB \u0438 \u0432\u044b\u0442\u043a\u043d\u0443\u0442\u044c-\u0432\u043e\u0442\u043a\u043d\u0443\u0442\u044c miniUSB \u043a\u0430\u0431\u0435\u043b\u044c \u0438\u0437 \u043f\u043b\u0430\u0442\u044b. \u0422\u0430\u043c \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u0442\u044c \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043d\u044f\u0442\u044c \u043a\u0430\u043a\u043e\u0439 \u0443 \u043d\u0430\u0441 \u043f\u043e\u0440\u0442. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<pre><code>megalloid@megalloid-lenovo:~$ udevadm monitor | grep ttyUSB KERNEL[191576.781021] remove   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0\/tty\/ttyUSB0 (tty) KERNEL[191576.781124] unbind   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) KERNEL[191576.781170] remove   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) UDEV  [191576.796568] remove   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0\/tty\/ttyUSB0 (tty) UDEV  [191576.804931] unbind   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) UDEV  [191576.811644] remove   \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) KERNEL[191579.176521] add      \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) KERNEL[191579.177593] add      \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0\/tty\/ttyUSB0 (tty) KERNEL[191579.177706] bind     \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) UDEV  [191579.217863] add      \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) UDEV  [191579.225195] add      \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0\/tty\/ttyUSB0 (tty) UDEV  [191579.229537] bind     \/devices\/pci0000:00\/0000:00:1d.0\/0000:05:00.0\/0000:06:01.0\/0000:08:00.0\/0000:09:02.0\/0000:0a:00.0\/usb3\/3-2\/3-2.1\/3-2.1.3\/3-2.1.3.2\/3-2.1.3.2.4\/3-2.1.3.2.4:1.0\/ttyUSB0 (usb-serial) <\/code><\/pre>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 \u0442\u0430\u043a\u0436\u0435 \u043a\u043b\u0438\u043a\u043d\u0443\u0432 \u043f\u043e \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c\u0443 \u0437\u043d\u0430\u0447\u043a\u0443 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432\u044b\u0431\u0440\u0430\u0432 \u043c\u0435\u043d\u044e <strong><em>Run As &#8212; Launch on hardware (System Debugger)<\/em><\/strong>. \u0412 \u0432\u044b\u0432\u043e\u0434\u0435 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0443\u0432\u0438\u0434\u0435\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/509\/c9f\/e1c\/509c9fe1c167cc3f9ae22df02ed60e50.png\" width=\"626\" height=\"444\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/509\/c9f\/e1c\/509c9fe1c167cc3f9ae22df02ed60e50.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0427\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u044e\u0442 \u044d\u0442\u0438 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f? \u042d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u0434\u0440\u0430\u0439\u0432\u0435\u0440 \u0443\u0441\u043f\u0435\u0448\u043d\u043e \u201c\u0434\u043e\u0441\u0442\u0443\u0447\u0430\u043b\u0441\u044f\u201d \u0434\u043e \u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438 \u0438 \u043c\u043e\u0436\u0435\u0442 \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u043d\u0435\u0439 \u043e\u0431\u043c\u0435\u043d. \u0417\u043d\u0430\u0447\u0438\u0442 \u043d\u0430\u0448 SDIO-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0418\u0434\u0451\u043c \u0434\u0430\u043b\u044c\u0448\u0435.<\/p>\n<p><em>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e standalone-\u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0442\u0443\u0442: <\/em><a href=\"https:\/\/xilinx-wiki.atlassian.net\/wiki\/spaces\/A\/pages\/18841881\/Zynq+SD+Standalone+driver\" rel=\"noopener noreferrer nofollow\"><em>https:\/\/xilinx-wiki.atlassian.net\/wiki\/spaces\/A\/pages\/18841881\/Zynq+SD+Standalone+driver<\/em><\/a><\/p>\n<h2>\u0422\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0430 \u0438 \u0438\u0437\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u043c\u0435\u0437\u043e\u043d\u0438\u043d\u043d\u044b\u0445 \u043f\u043b\u0430\u0442 \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f<\/h2>\n<p>\u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0448\u0430\u0433\u043e\u043c \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043f\u043b\u0430\u0442\u044b, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u044f \u0437\u0430\u043f\u0430\u044f\u044e \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044c, \u0441\u043e \u0432\u0441\u0435\u0439 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0439 \u043e\u0431\u0432\u044f\u0437\u043a\u043e\u0439. \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044f \u0431\u044b\u043b \u0432\u0437\u044f\u0442 \u043c\u043e\u0434\u0443\u043b\u044c \u043e\u0442 FN-Link \u0441 Realtek RTL8822CS \u0447\u0438\u043f\u043e\u043c, \u043c\u043e\u0434\u0435\u043b\u044c \u043c\u043e\u0434\u0443\u043b\u044f 6222B-SRC. \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0442\u0443\u0442: <a href=\"https:\/\/wikidevi.wi-cat.ru\/Fn-Link_6222B-SRC\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/wikidevi.wi-cat.ru\/Fn-Link_6222B-SRC<\/u><\/a> , Datasheet: <a href=\"https:\/\/www.signal.com.tr\/pdf\/cat\/6222B-SRC_03.pdf\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/www.signal.com.tr\/pdf\/cat\/6222B-SRC_03.pdf<\/u><\/a><\/p>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u0441\u043a\u0430\u0436\u0443, \u0447\u0442\u043e \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e\u0439 MIMO 2&#215;2 Dual Band \u043c\u043e\u0434\u0443\u043b\u044c Wi-Fi \u0441 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 802.11ac \u0438 Bluetooth 4.2 \u0438\u043b\u0438 5.0 \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u043c\u043e\u0434\u0435\u043b\u0438.\u00a0<\/p>\n<p>\u0422\u0430\u043a \u043a\u0430\u043a \u043c\u043e\u0434\u0443\u043b\u044c \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u043a \u0433\u0440\u0435\u0431\u0435\u043d\u043a\u0435 PLS \u043d\u0430 \u043f\u043b\u0430\u0442\u0435 \u0441 \u0448\u0430\u0433\u043e\u043c \u0432 2.54\u043c\u043c. &#8212; \u0431\u044b\u043b\u043e \u0440\u0435\u0448\u0435\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u0440\u0430\u0437\u044a\u0435\u043c \u0438 \u043d\u0430 \u043c\u0435\u0437\u043e\u043d\u0438\u043d\u043d\u043e\u0439 \u043f\u043b\u0430\u0442\u0435.\u00a0<\/p>\n<p>\u0420\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0430 \u0441\u043e \u0441\u0442\u043e\u0440\u043e\u043d\u044b \u043f\u043b\u0430\u0442\u044b:\u00a0<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/fd6\/bea\/ba3\/fd6beaba330e9c276e89c1c70635dc0e.png\" width=\"489\" height=\"237\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/fd6\/bea\/ba3\/fd6beaba330e9c276e89c1c70635dc0e.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0420\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0430 \u0441\u043e \u0441\u0442\u043e\u0440\u043e\u043d\u044b \u043c\u043e\u0434\u0443\u043b\u044f:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/c08\/551\/665\/c08551665f95f38e517da467eb9b9225.png\" width=\"1088\" height=\"486\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c08\/551\/665\/c08551665f95f38e517da467eb9b9225.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0420\u0435\u0448\u0435\u043d\u043e \u0431\u044b\u043b\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u0432 \u0442.\u0447. \u0438 Bluetooth \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0438\u0445 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u043e\u0432. \u0412 \u0438\u0442\u043e\u0433\u0435 \u043e\u0431\u0449\u0430\u044f \u043e\u0431\u0432\u044f\u0437\u043a\u0430 \u043c\u043e\u0434\u0443\u043b\u044f \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/647\/798\/510\/6477985104680c2496ae428262f1ef6d.png\" width=\"1434\" height=\"853\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/647\/798\/510\/6477985104680c2496ae428262f1ef6d.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0451 \u0432 \u0446\u0435\u043b\u043e\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u043e \u0438 \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0440\u0435\u0444\u0435\u0440\u0435\u043d\u0441\u043d\u043e\u0439 \u0441\u0445\u0435\u043c\u043e\u0439 \u0438 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u043c\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f\u043c\u0438, \u0442\u0430\u043a\u0438\u043c\u0438 \u043a\u0430\u043a \u043f\u0438\u043d \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f\\\u0432\u044b\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043f\u0438\u0442\u0430\u043d\u0438\u044f \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u043f\u0440\u043e\u0447\u0438\u0445 \u043c\u0435\u043b\u043a\u0438\u0445 \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043e\u043a. \u0410\u043d\u0442\u0435\u043d\u043d\u044b\u0439 \u0442\u0440\u0430\u043a\u0442 \u0431\u044b\u043b\u043e \u0440\u0435\u0448\u0435\u043d\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u043d\u0430 u.FL-\u0440\u0430\u0437\u044a\u0435\u043c, \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430 \u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043b\u044e\u0431\u044b\u0445 \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0445 \u0434\u043b\u044f 2.4\/5\u0413\u0413\u0446 \u0430\u043d\u0442\u0435\u043d\u043d.\u00a0<\/p>\n<p>\u041f\u043e\u043b\u0443\u0447\u0438\u0432\u0448\u0438\u0435\u0441\u044f \u043f\u043b\u0430\u0442\u044b \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u044b \u0432 \u0442\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0435 \u0438 \u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u0441\u043e\u0431\u043e\u0439 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043d\u043e\u0443-\u0445\u0430\u0443, \u043d\u043e \u043b\u0438\u043d\u0438\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0440\u043e\u0432\u043d\u044f\u0442\u044c \u0442.\u043a. SDIO-\u0448\u0438\u043d\u0430 \u0442\u0443\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u043d\u0430\u044f, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0435\u043d\u0435\u0431\u0440\u0435\u0447\u044c \u0442\u0430\u043a\u0438\u043c \u0432\u0430\u0436\u043d\u044b\u043c \u0430\u0441\u043f\u0435\u043a\u0442\u043e\u043c \u0442\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0438.\u00a0<\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0442\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0438 \u0432 2D:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e6a\/088\/8e6\/e6a0888e65459464618817f0dd7e2089.png\" width=\"669\" height=\"782\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e6a\/088\/8e6\/e6a0888e65459464618817f0dd7e2089.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0442\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0438 \u0432 3D:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/521\/50f\/f46\/52150ff46241c57edceb55ef6fe13b8d.png\" width=\"660\" height=\"802\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/521\/50f\/f46\/52150ff46241c57edceb55ef6fe13b8d.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0438\u0434 \u0441\u0432\u0435\u0440\u0445\u0443:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/2ca\/5cc\/e63\/2ca5cce635682082f3f3895c559998d7.png\" width=\"738\" height=\"467\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2ca\/5cc\/e63\/2ca5cce635682082f3f3895c559998d7.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0438\u0434 \u0441\u043d\u0438\u0437\u0443:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/d51\/b58\/48e\/d51b5848e2903bdc36415732f10b45e7.png\" width=\"767\" height=\"466\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d51\/b58\/48e\/d51b5848e2903bdc36415732f10b45e7.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0438\u0434 \u043f\u043b\u0430\u0442\u044b \u043f\u043e\u0441\u043b\u0435 \u043c\u043e\u043d\u0442\u0430\u0436\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/381\/d11\/d09\/381d11d093d12b6ab6a05cfd90a13316.png\" width=\"568\" height=\"596\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/381\/d11\/d09\/381d11d093d12b6ab6a05cfd90a13316.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0422.\u043a. \u043f\u043b\u0430\u0442\u0430 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u044d\u0442\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f &#8212; \u043e\u0441\u0442\u0430\u043b\u0438\u0441\u044c \u043d\u0435 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c\u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b.\u00a0<\/p>\n<p>\u0412 \u0446\u0435\u043b\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0433\u043e \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u0435\u043c \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u044e\u0449\u0438\u0445 \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u0438 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0444\u0430\u0439\u043b\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044f \u0432 Linux. \u041e\u0431 \u044d\u0442\u043e\u043c \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u0433\u043b\u0430\u0432\u0430\u0445. <\/p>\n<h2>\u041d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432 Vivado <\/h2>\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u0430 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0431\u043b\u044e\u0441\u0442\u0438 \u0434\u0432\u0430 \u0443\u0441\u043b\u043e\u0432\u0438\u044f:<\/p>\n<ol>\n<li>\n<p>\u041f\u043e\u0434\u0430\u0442\u044c \u043d\u0438\u0437\u043a\u043e\u0435 \u043d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u043d\u0430 \u0437\u0430\u0442\u0432\u043e\u0440 P-\u043a\u0430\u043d\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430 <strong><em>VT1<\/em><\/strong>, \u0442.\u0435. \u043d\u0430 \u043b\u0438\u043d\u0438\u044e <strong><em>WL_BT_ON<\/em><\/strong>, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0434\u0430\u0442\u044c \u043f\u0438\u0442\u0430\u043d\u0438\u0435 \u043d\u0430 \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044c;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0430\u0442\u044c \u0432\u044b\u0441\u043e\u043a\u043e\u0435 \u043d\u0430\u043f\u0440\u044f\u0436\u0435\u043d\u0438\u0435 \u043d\u0430 \u043d\u043e\u0436\u043a\u0443 <strong><em>WL_REG_ON<\/em><\/strong> \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u044f, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0435\u0433\u043e;<\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430 \u044d\u0442\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u043d\u0430\u043c \u0431\u0443\u0434\u0435\u0442 \u043d\u0443\u0436\u043d\u043e \u0441\u043b\u0435\u0433\u043a\u0430 \u043c\u043e\u0434\u0435\u0440\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0435\u043a\u0442 \u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c 2 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u0441 AXI GPIO-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u0438 \u0437\u0430\u0432\u0435\u0441\u0442\u0438 \u0438\u0445 \u043d\u0430 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u043d\u043e\u0436\u043a\u0438:\u00a0<\/p>\n<ol>\n<li>\n<p>\u0414\u043b\u044f \u0442\u0440\u0430\u043d\u0437\u0438\u0441\u0442\u043e\u0440\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u044d\u0442\u043e \u043d\u043e\u0436\u043a\u0430 11 \u043d\u0430 \u043e\u0431\u0449\u0435\u0439 \u0433\u0440\u0435\u0431\u0435\u043d\u043a\u0435, \u0447\u0442\u043e \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u043c\u0443 \u043f\u0438\u043d\u0443 <strong><em>W20<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0414\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 <strong><em>WL_REG_ON<\/em><\/strong> \u044d\u0442\u043e 25-\u044f \u043d\u043e\u0436\u043a\u0430 \u043d\u0430 \u0442\u043e\u0439 \u0436\u0435 \u0433\u0440\u0435\u0431\u0435\u043d\u043a\u0435, \u0447\u0442\u043e \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u0438\u043d\u0443 <strong><em>V17<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u041a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 <strong><em>AXI GPIO<\/em><\/strong> \u042f \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 (<a href=\"https:\/\/habr.com\/ru\/post\/565368\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/565368\/<\/u><\/a>) \u0438 \u043d\u0430 \u0434\u0435\u0442\u0430\u043b\u044f\u0445 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0442\u044c\u0441\u044f \u043d\u0435 \u0431\u0443\u0434\u0443. \u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043b\u0438\u0448\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0448\u0430\u0433\u043e\u0432:<\/p>\n<ol>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0432 \u0434\u0438\u0437\u0430\u0439\u043d IP-\u043c\u043e\u0434\u0443\u043b\u044c <strong><em>AXI GPIO<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u0448\u0430\u0433\u0438 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 Vivado, \u043e\u0442\u043c\u0435\u0442\u0438\u0432 \u0432\u0441\u0435 \u0433\u0430\u043b\u043e\u0447\u043a\u0438;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u0431\u043b\u043e\u043a <strong><em>AXI GPIO<\/em><\/strong>, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0437\u0430\u0439\u0442\u0438 \u0432 \u0435\u0433\u043e \u043e\u043f\u0446\u0438\u0438 \u0438 \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0433\u0430\u043b\u043e\u0447\u043a\u0443 <strong><em>All Outputs<\/em><\/strong>, \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0448\u0438\u0440\u0438\u043d\u0443 \u0448\u0438\u043d\u044b <strong><em>GPIO Width<\/em><\/strong> \u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <strong><em>2<\/em><\/strong> (\u043d\u0443\u0436\u043d\u043e 2 \u0441\u0438\u0433\u043d\u0430\u043b\u0430) \u0438 \u0432 <strong><em>Default Output<\/em><\/strong> \u0432\u043f\u0438\u0441\u0430\u0442\u044c <strong><em>0x00000002<\/em><\/strong>, \u0447\u0442\u043e\u0431\u044b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043f\u043e\u0441\u043b\u0435 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 bitstream-\u0444\u0430\u0439\u043b\u0430 \u043e\u0431\u0430 \u043f\u0438\u043d\u0430 \u043f\u0440\u0438\u043d\u044f\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0437\u044b\u0432\u0430\u0435\u043c <strong><em>External Interface<\/em><\/strong> \u043e\u0442 <strong><em>AXI GPIO<\/em><\/strong> \u043a\u0430\u043a <strong><em>MGMT_GPIO<\/em><\/strong> \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c\u0441\u044f. \u0414\u043e\u043b\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<\/li>\n<\/ol>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/234\/98f\/107\/23498f1072db7330570a736b1a6085e3.png\" width=\"1205\" height=\"715\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/234\/98f\/107\/23498f1072db7330570a736b1a6085e3.png\"\/><figcaption><\/figcaption><\/figure>\n<ol>\n<li>\n<p>\u0421\u0438\u043d\u0442\u0435\u0437\u0438\u0440\u0443\u0435\u043c \u0434\u0438\u0437\u0430\u0439\u043d, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0432\u0441\u0451 \u043f\u0440\u043e\u0448\u043b\u043e \u0443\u0441\u043f\u0435\u0448\u043d\u043e;<\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>Open Synthesized Design<\/em><\/strong> \u0438 \u043d\u0430\u0437\u043d\u0430\u0447\u0430\u0435\u043c <strong><em>MGMT_GPIO[0]<\/em><\/strong> \u043f\u0438\u043d <strong><em>W20<\/em><\/strong>, \u0430 <strong><em>MGMT_GPIO[1]<\/em><\/strong> \u043f\u0438\u043d <strong><em>V17<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0418\u0437\u043c\u0435\u043d\u044f\u0435\u043c \u0443 \u044d\u0442\u0438\u0445 \u0434\u0432\u0443\u0445 \u043f\u0438\u043d\u043e\u0432<strong><em> I\/O Std<\/em><\/strong> \u043d\u0430 <strong><em>LVCMOS3.3<\/em><\/strong> \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c;<\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044e bitstream-\u0444\u0430\u0439\u043b\u0430 \u0447\u0435\u0440\u0435\u0437 <strong><em>Generate bitstream<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u042d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u043c \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 <strong><em>bitstream<\/em><\/strong> \u0438 \u0432\u0441\u0451 \u0447\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0438\u0445 \u0448\u0430\u0433\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>File &#8212; Export &#8212; Export Hardware<\/em><\/strong>;\u00a0<\/p>\n<\/li>\n<\/ol>\n<p>\u0412\u0441\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043d\u0430 \u044d\u0442\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u043c\u044b \u0432\u043d\u0435\u0441\u043b\u0438. \u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u043a \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0433\u043e \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u0435\u043c \u0432 Linux;<\/p>\n<h2>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 FSBL, Device Tree Sources, U-Boot<\/h2>\n<p>\u041d\u0430 \u044d\u0442\u043e\u043c \u044d\u0442\u0430\u043f\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u0437\u0430\u0433\u0440\u0443\u0437\u0447\u0438\u043a\u043e\u0432, \u0444\u0430\u0439\u043b\u0443 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0436\u0435\u043b\u0435\u0437\u0430 \u0438 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u044f\u0434\u0440\u0430 Linux. \u041c\u043d\u043e\u0433\u0438\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b \u0438 \u0434\u0435\u0442\u0430\u043b\u0438 \u042f \u0446\u0435\u043b\u0435\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e \u043e\u043f\u0443\u0449\u0443 \u0442.\u043a. \u0443\u0436\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b \u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 (<a href=\"https:\/\/habr.com\/ru\/post\/565368\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/565368\/<\/u><\/a>) \u0430 \u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0449\u0438\u043c\u0441\u044f \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043c \u043f\u043e\u0441\u0432\u044f\u0449\u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u043f\u043e\u0432\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043d\u0438\u044f.\u00a0<\/p>\n<p>\u041f\u0435\u0440\u0432\u044b\u043c \u044d\u0442\u0430\u043f\u043e\u043c \u043d\u0430\u0434\u043e \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c <strong><em>FSBL<\/em><\/strong>. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u0412 \u043c\u0435\u043d\u044e <strong><em>Xilinx SDK<\/em><\/strong> \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>File &#8212; New &#8212; Application Project<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0418\u043c\u0435\u043d\u0443\u0435\u043c \u0435\u0433\u043e \u043a\u0430\u043a <strong><em>FSBL<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c \u043a\u043b\u0430\u0432\u0438\u0448\u0443 <strong><em>Next<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0418\u0437 \u0437\u0430\u0433\u043e\u0442\u043e\u0432\u043e\u043a \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Zynq FSBL<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0444\u0430\u0439\u043b <strong><em>FSBL.elf<\/em><\/strong><\/p>\n<\/li>\n<\/ol>\n<p>\u0412\u0442\u043e\u0440\u044b\u043c \u044d\u0442\u0430\u043f\u043e\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c <strong><em>Device Tree Source\/Blob<\/em><\/strong> \u0444\u0430\u0439\u043b \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 U-Boot. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<ol>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c<strong> <em>BSP Repository<\/em><\/strong> \u0438\u0437 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f <strong><em>device-tree-xlnx<\/em><\/strong>. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u043c\u0435\u043d\u044e <strong><em>Xilinx &#8212; Repositories<\/em><\/strong> \u0438 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u0430\u043f\u043a\u0443 \u0441 <strong><em>device-tree-xlnx<\/em><\/strong> \u0432 \u0441\u0435\u043a\u0446\u0438\u044e <strong><em>Global Repositories<\/em><\/strong>.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c <strong><em>BSP Project<\/em><\/strong> \u0447\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e<strong><em> File &#8212; New &#8212; Board Support Package<\/em><\/strong>, \u0434\u0430\u0451\u043c \u0435\u043c\u0443 \u0438\u043c\u044f \u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0432\u043d\u0438\u0437\u0443 \u043c\u0435\u043d\u044e <strong><em>device_tree<\/em><\/strong> \u0438 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043c\u0435\u043d\u044e \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Ok<\/em><\/strong>, \u0435\u0441\u043b\u0438 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0432\u043d\u0435\u0441\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u0430<strong><em> zynq-7000.dtsi<\/em><\/strong><em> <\/em>\u0438 \u043d\u0430\u0445\u043e\u0434\u0438\u043c \u0441\u0435\u043a\u0446\u0438\u044e \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u044e\u0449\u0443\u044e SDIO1 \u0432 \u0441\u0442\u0440\u043e\u043a\u0435 sdhci1: mmc@e0101000;<\/p>\n<\/li>\n<\/ol>\n<p>\u0414\u043e\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u0441\u0435\u043a\u0446\u0438\u044e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435\u043c (\u0444\u0430\u0439\u043b \u043c\u043e\u0436\u043d\u043e \u0432\u0437\u044f\u0442\u044c \u0442\u0443\u0442 &#8212; <a href=\"https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/zynq-7000.dtsi\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/zynq-7000.dtsi<\/u><\/a>) :<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/68a\/fa8\/9da\/68afa89dac5d3025b33798e58a3833c8.png\" width=\"409\" height=\"505\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/68a\/fa8\/9da\/68afa89dac5d3025b33798e58a3833c8.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c\u0438 dts-\u0444\u0430\u0439\u043b\u0430\u043c\u0438 \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u043e\u0439 \u043a\u043e\u043d\u0441\u043e\u043b\u0438: <\/p>\n<pre><code>megalloid@megalloid-lenovo:~$ cd Zynq\/Projects\/SDIO_EMIO\/SDIO_EMIO.sdk\/device_tree\/<\/code><\/pre>\n<p>\u041a\u043e\u043c\u043f\u043e\u043d\u0443\u0435\u043c \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438: <\/p>\n<pre><code>gcc -I my_dts -E -nostdinc -undef -D__DTS__ -x assembler-with-cpp -o system.dts system-top.dts<\/code><\/pre>\n<p>\u041a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u043c \u0432 blob: <\/p>\n<pre><code>dtc -I dts -O dtb -o system.dtb system.dts<\/code><\/pre>\n<p>\u0412\u0441\u0451. Device Tree \u0433\u043e\u0442\u043e\u0432.<\/p>\n<p>\u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u044d\u0442\u0430\u043f\u043e\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c U-Boot \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u043f\u043b\u0430\u0442\u044b. \u041d\u0443\u0436\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0441\u0442\u044b\u0445 \u0448\u0430\u0433\u043e\u0432:<\/p>\n<ol>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0439\u0442\u0438 \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 U-Boot: <strong>cd u-boot-xlnx<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u0434\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u043a\u0440\u043e\u0441\u0441-\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438: <strong>export CROSS_COMPILE=arm-linux-gnueabihf-; export ARCH=arm<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0441\u044b\u0440\u0446\u044b \u043e\u0442 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u043a\u043e\u043d\u0444\u0438\u0433 \u0434\u043b\u044f Zynq \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e: <strong>make distclean; make xilinx_zynq_virt_defconfig<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u043b\u043e\u0436\u0438\u0442\u044c \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 U-Boot \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0439 \u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u043c \u0448\u0430\u0433\u0435 <strong><em>system.dtb<\/em><\/strong> \u0432 \u043f\u0430\u043f\u043a\u0443 <strong><em>arch\/arm\/dts\/<\/em><\/strong> c \u0438\u043c\u0435\u043d\u0435\u043c <strong><em>zynq-qmtech.dtb<\/em><\/strong><\/p>\n<\/li>\n<li>\n<p>\u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u043a\u0430\u043a\u043e\u0439 <strong><em>Device Tree<\/em><\/strong> \u0444\u0430\u0439\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c: <strong>export DEVICE_TREE=&#187;zynq-qmtech&#187;<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0437\u0430\u0439\u0442\u0438 \u0432 \u043c\u0435\u043d\u044e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0442\u043e\u0440\u0430 \u0438 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u044f\u0434 \u043e\u043f\u0446\u0438\u0439: <strong>make menuconfig<\/strong>\u00a0<\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443 AXI GPIO, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043f\u0438\u0442\u0430\u043d\u0438\u044f \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u043f\u043e\u0434\u0430\u0447\u0438 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 WL_REG_ON \u043d\u0430 \u0440\u0430\u0434\u0438\u043e\u043c\u043e\u0434\u0443\u043b\u0435: <strong><em>Device Drivers &#8212; GPIO Support &#8212; Xilinx GPIO Driver\u00a0<\/em><\/strong><\/p>\n<\/li>\n<li>\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u043a\u043e\u043d\u0444\u0438\u0433 (\u043c\u043e\u0436\u043d\u043e \u0432\u0437\u044f\u0442\u044c \u0442\u0443\u0442) \u0432 \u0444\u0430\u0439\u043b <strong>.config<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u0441\u0431\u043e\u0440\u043a\u0443: <strong>make -j$(nproc) <\/strong>\u0438 \u0434\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438;<\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u043a\u043e\u043c\u043f\u043e\u043d\u043e\u0432\u0430\u0442\u044c FSBL, Bitstream-\u0444\u0430\u0439\u043b \u0438 U-Boot \u0432 \u043e\u0434\u0438\u043d \u0437\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u044b\u0439 \u0444\u0430\u0439\u043b BOOT.BIN. \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u043e\u0432\u043a\u0438 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0432 \u043c\u043e\u0435\u0439 \u043f\u0440\u043e\u0448\u043b\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 (<a href=\"https:\/\/habr.com\/ru\/post\/565368\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/565368\/<\/u><\/a>). \u0412 \u0446\u0435\u043b\u043e\u043c \u043d\u0430\u0434\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u043e\u0441\u0442\u044b\u0445 \u0448\u0430\u0433\u043e\u0432:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430\u0439\u0442\u0438 \u0444\u0430\u0439\u043b \u0432 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0435 \u0441 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u043c <strong><em>First stage bootloader<\/em><\/strong>. \u041f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043e\u043d \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0432 <strong><em>SDIO_EMIO\/SDIO_EMIO.sdk\/FSBL\/Debug\/FSBL.elf<\/em><\/strong><\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0439\u0442\u0438 <strong><em>Bitstream-\u0444\u0430\u0439\u043b<\/em><\/strong> \u0434\u043b\u044f \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u0443\u0435\u043c\u043e\u0439 \u043b\u043e\u0433\u0438\u043a\u0438. \u041d\u0430\u0439\u0442\u0438 \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0432 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0435 <strong>SDIO_EMIO\/SDIO_EMIO.sdk\/block_design_wrapper_hw_platform_0\/block_design_wrapper.bit<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0439\u0442\u0438 \u0431\u0438\u043d\u0430\u0440\u043d\u044b\u0439 \u0444\u0430\u0439\u043b <strong><em>U-Boot<\/em><\/strong>. \u0414\u0430\u043d\u043d\u044b\u0439 \u0444\u0430\u0439\u043b \u043f\u043e\u0441\u043b\u0435 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u043b\u0435\u0436\u0438\u0442 \u0432 \u043f\u0430\u043f\u043a\u0435 \u0441 U-Boot: <strong>u-boot-xlnx\/u-boot.elf<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0432 Xilinx SDK \u043f\u0443\u043d\u043a\u0442 \u043c\u0435\u043d\u044e <strong><em>Xilinx &#8212; Create Boot Image<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u043a\u0443\u0434\u0430 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u044c \u043d\u043e\u0432\u044b\u0439 bif-\u0444\u0430\u0439\u043b, \u044f \u0435\u0433\u043e \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044e \u0432 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u0430;<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043f\u043e\u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e \u0444\u0430\u0439\u043b\u044b <strong><em>FSBL.elf, block_design_wrapper.bit, u-boot.elf<\/em><\/strong> \u0432 \u0441\u0435\u043a\u0446\u0438\u044e <strong><em>Boot Image Partitions<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Create Image<\/em><\/strong> \u0438 \u0432\u0438\u0434\u0438\u043c \u043a\u0430\u043a \u0432 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0435 \u0441 bif-\u0444\u0430\u0439\u043b\u043e\u043c \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <strong><em>BOOT.BIN<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0437\u0430\u043b\u0438\u0442\u044c \u044d\u0442\u043e\u0442 \u0444\u0430\u0439\u043b \u043d\u0430 <strong><em>\u0437\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u0443\u044e SD-\u043a\u0430\u0440\u0442\u0443 <\/em><\/strong>\u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0442\u044c\u0441\u044f. \u0415\u0441\u043b\u0438 \u043c\u044b \u0432\u0438\u0434\u0438\u043c \u043f\u0440\u0438\u0433\u043b\u0430\u0448\u0435\u043d\u0438\u0435 \u043e\u0442<strong><em> U-Boot <\/em><\/strong>\u0438 \u0447\u0442\u043e \u0441\u0432\u0435\u0442\u0438\u0442\u0441\u044f \u0441\u0432\u0435\u0442\u043e\u0434\u0438\u043e\u0434 <strong><em>FPGA DONE <\/em><\/strong>&#8212; \u0437\u043d\u0430\u0447\u0438\u0442 \u043c\u044b \u0432\u0441\u0451 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u043b\u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e.\u00a0<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/d57\/46a\/95a\/d5746a95acb71fa17314158be3af4802.png\" width=\"619\" height=\"444\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d57\/46a\/95a\/d5746a95acb71fa17314158be3af4802.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043a \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0435 \u0442\u043e\u0433\u043e, \u043f\u0440\u043e\u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d \u043b\u0438<strong><em> AXI GPIO \u0432 U-Boot<\/em><\/strong> \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043c \u0438\u0445. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u044b\u0432\u0435\u0434\u0435\u043c \u0441\u043f\u0438\u0441\u043e\u043a \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u044b. \u042d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 dm tree.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/a9a\/d52\/c2f\/a9ad52c2f7ca103c3f6b91c3bf6ba6c3.png\" width=\"689\" height=\"462\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a9a\/d52\/c2f\/a9ad52c2f7ca103c3f6b91c3bf6ba6c3.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0442\u043b\u0438\u0447\u043d\u043e. \u0412\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u043d\u0430 \u0431\u043e\u0440\u0442\u0443 \u0435\u0441\u0442\u044c \u0434\u0432\u0430 SDIO-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430, \u0438 \u0434\u0432\u0430 GPIO-\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430. \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043d\u043e\u0436\u043a\u0438 \u0442\u0440\u0430\u043d\u0437\u0438\u0441\u0442\u043e\u0440\u0430. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043a\u0430\u043a\u0438\u0435 \u0430\u0434\u0440\u0435\u0441\u0430 \u0432 GPIO \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u0438 \u043a\u0430\u043a\u0438\u0435 \u043e\u0442\u0432\u0435\u0447\u0430\u044e\u0442 \u0437\u0430 \u0442\u0435, \u0438\u043b\u0438 \u0438\u043d\u044b\u0435 \u043d\u043e\u0436\u043a\u0438:\u00a0 <strong>gpio status -a<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0412 \u043a\u043e\u043d\u0446\u0435 \u0432\u044b\u0432\u043e\u0434\u0430 \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0435\u0441\u0442\u044c Bank GPIO \u0441 \u0434\u0432\u0443\u043c\u044f \u043d\u043e\u0436\u043a\u0430\u043c\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044e \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/240\/c10\/252\/240c10252a3cc4b9f6f81d0028e607cb.png\" alt=\"\" title=\"\" width=\"716\" height=\"488\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/240\/c10\/252\/240c10252a3cc4b9f6f81d0028e607cb.png\"\/><figcaption><\/figcaption><\/figure>\n<ol>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0440\u0430\u0434\u0438 \u043c\u043e\u0436\u043d\u043e \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043d\u043e\u0436\u043a\u0438 <strong><em>gpio@412000000<\/em><\/strong> \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443: <strong>gpio toogle gpio@412000000<\/strong> \u0438\u043b\u0438 <strong>gpio set gpio@412000000 \/ gpio clear gpio@412000000<\/strong> \u0434\u043b\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0439 1 \u0438\u043b\u0438 0 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e<\/p>\n<\/li>\n<\/ol>\n<\/li>\n<\/ol>\n<p>\u0422\u0430\u043a. \u0417\u0430\u0433\u0440\u0443\u0437\u0447\u0438\u043a \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d. \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0435 \u044f\u0434\u0440\u0430 Linux \u0438 RootFS \u0441\u043e \u0432\u0441\u0435\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u043c \u0434\u043b\u044f \u043d\u0430\u0441 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u044b\u043c<\/p>\n<h2>\u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u044f\u0434\u0440\u0430 Linux \u0438 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 RootFS \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c Buildroot<\/h2>\n<p>\u0422\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0438 \u043f\u0440\u043e\u0448\u043b\u044b\u0445 \u0433\u043b\u0430\u0432\u0430\u0445, \u0434\u043b\u044f \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0433\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0448\u0430\u0433\u0430, \u0441\u043e\u0448\u043b\u044e\u0441\u044c \u043d\u0430 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e (<a href=\"https:\/\/habr.com\/ru\/post\/565368\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/565368\/<\/u><\/a>) \u043a\u0430\u043a \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044f\u0434\u0440\u043e Linux. \u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044e \u0448\u0430\u0433\u043e\u0432, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 \u044f\u0434\u0440\u0430 \u0441 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u043c\u0438 \u043c\u043e\u0434\u0443\u043b\u044f\u043c\u0438 \u0438 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430\u043c\u0438. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0439\u0442\u0438 \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 \u043a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0435\u043c linux-xlnx;<\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u043d\u043e\u0432\u0438\u0442\u044c \u0435\u0433\u043e (\u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438): <strong>cd linux-xlnx; git fetch -p; git checkout master; git pull;<\/strong>\u00a0<\/p>\n<\/li>\n<li>\n<p>\u042d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u043c \u0442\u0430\u043a\u0436\u0435 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u043a\u0440\u043e\u0441\u0441-\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438: <strong>export CROSS_COMPILE=arm-linux-gnueabihf-; export ARCH=arm<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0414\u0435\u043b\u0430\u0435\u043c \u043e\u0447\u0438\u0441\u0442\u043a\u0443 \u043e\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0441\u0431\u043e\u0440\u043e\u043a: <strong>make distclean<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0439 \u043a\u043e\u043d\u0444\u0438\u0433: <strong>make ARCH=arm xilinx_zynq_defconfig;<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0418\u0437\u043c\u0435\u043d\u0438\u043c \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0439 \u043a\u043e\u043d\u0444\u0438\u0433 \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0432 \u043c\u0435\u043d\u044e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438: <strong>make ARCH=arm menuconfig<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0418\u0437\u043c\u0435\u043d\u0438\u043c \u043e\u043f\u0446\u0438\u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 (\u043c\u043e\u0436\u043d\u043e \u0432\u0437\u044f\u0442\u044c \u0442\u0443\u0442 <a href=\"https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/kernel.config\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/kernel.config<\/u><\/a>) , \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043e\u043f\u0446\u0438\u044e (\u043f\u0440\u043e\u0441\u043b\u0435\u0434\u0438\u043c, \u0447\u0442\u043e \u0442\u0430\u043c \u0432\u043c\u0435\u0441\u0442\u043e [M] \u0432 \u043f\u043e\u043b\u0435 \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u0442\u043e\u0438\u0442 \u0441\u0438\u043c\u0432\u043e\u043b \u0437\u0432\u0435\u0437\u0434\u043e\u0447\u043a\u0438 [*] : <strong><em>Networking Support &#8212; Wireless &#8212; cfg80211\u00a0<\/em><\/strong><\/p>\n<\/li>\n<li>\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u043a\u043e\u043d\u0444\u0438\u0433 \u0432 \u0444\u0430\u0439\u043b <strong><em>.config <\/em><\/strong>\u0438 \u0432\u044b\u0445\u043e\u0434\u0438\u043c \u0438\u0437 \u043c\u0435\u043d\u044e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438: <strong>make ARCH=arm UIMAGE_LOADADDR=0x8000 uImage -j8<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0435\u043c \u043c\u043e\u0434\u0443\u043b\u0438 \u044f\u0434\u0440\u0430: <strong>make ARCH=arm -j8 modules<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043f\u0438\u0440\u0443\u0435\u043c <strong><em>uImage<\/em><\/strong> \u0438\u0437 \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0430 <strong><em>linux-xlnx\/arch\/arm\/boot\/<\/em><\/strong> \u043d\u0430 \u0437\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u0443\u044e <strong><em>SD-\u043a\u0430\u0440\u0442\u0443<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043e\u0431\u0440\u0430\u0437 <strong><em>RootFS<\/em><\/strong> \u0441 \u0432\u0441\u0435\u043c\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u043c userspace-\u0443\u0442\u0438\u043b\u0438\u0442\u0430\u043c\u0438, \u0442\u0438\u043f\u0430 <strong><em>wpa_supplicant, wpa_cli, etc.<\/em><\/strong> \u0421\u043e\u0431\u0438\u0440\u0430\u0442\u044c <strong><em>RootFS<\/em><\/strong> \u0431\u0443\u0434\u0435\u043c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0441\u0431\u043e\u0440\u043a\u0438 <strong><em>buildroot<\/em><\/strong>, \u0441\u0442\u0430\u0442\u044c\u044e \u043e \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u042f \u043f\u0438\u0441\u0430\u043b \u0434\u043e \u044d\u0442\u043e\u0433\u043e (<a href=\"https:\/\/habr.com\/ru\/post\/567408\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/567408\/<\/u><\/a>). \u0418\u0442\u0430\u043a, \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0441\u0431\u043e\u0440\u043a\u0435, \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u0417\u0430\u0445\u043e\u0434\u0438\u043c \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 buildroot: <strong>cd buildroot<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u043c \u0435\u0433\u043e \u0434\u043e \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0432\u0435\u0440\u0441\u0438\u0438: <strong>git fetch -p; git checkout master; git pull;<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0414\u0435\u043b\u0430\u0435\u043c \u043e\u0447\u0438\u0441\u0442\u043a\u0443 \u043e\u0442 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0441\u0431\u043e\u0440\u043e\u043a: <strong>make distclean<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043c\u0435\u043d\u044e \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438: <strong>make -C \/home\/megalloid\/buildroot O=$PWD ARCH=arm nconfig<\/strong><\/p>\n<p>\u0418\u0437\u043c\u0435\u043d\u044f\u0435\u043c \u043e\u043f\u0446\u0438\u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u043f\u0438\u0441\u043a\u0443 \u043d\u0438\u0436\u0435;<\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 1: <strong>Target options &#8212; Target Architecture &#8212; ARM (little endian)<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 2: <strong>Target options &#8212; Target Architecture Variant &#8212; cortex-A9<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 3: <strong>Target options &#8212; Enable NEON SIMD extension support &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 4: <strong>Target options &#8212; Enable VFP extension support &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 5: <strong>Target options &#8212; Target ABI &#8212; EABIhf<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 6: <strong>Target options &#8212; Floating point strategy &#8212; NEON<\/strong>\u00a0<\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 7: <strong>Build options &#8212; Number of jobs to run simultaneously &#8212; 8 (\u043f\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0443 \u044f\u0434\u0435\u0440 CPU)<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 8: <strong>Toolchain &#8212; C library &#8212; glibc<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 9: <strong>Toolchain &#8212; Kernel headers &#8212; Custom Git Repository<\/strong>\u00a0<\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 10: <strong>Toolchain &#8212; URL of custom repository &#8212;\u00a0 &lt;\/home\/megalloid\/linux-xlnx><\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 11: <strong>Toolchain &#8212; Custom repository version &#8212; &lt;\u0445\u044d\u0448-\u0441\u0443\u043c\u043c\u0430 \u043e\u0442 git show-ref | grep master \u0438\u0437 \u043f\u0430\u043f\u043a\u0438 linux-xlnx><\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 12: <strong>Toolchain &#8212; Custom kernel headers series &#8212; 5.15.x<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 13: <strong>Toolchain &#8212; Install glibc utilities &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 14: <strong>Toolchain &#8212; GCC compiler Version &#8212; gcc 9.x<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 15: <strong>Toolchain &#8212; Enable C++ support &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 16: <strong>Toolchain &#8212; Enable compiler link-time-optimization support &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 17: <strong>Toolchain &#8212; Enable compiler OpenMP support &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 18: <strong>Target packages &#8212; Miscellaneous &#8212; haveged<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 19: <strong>Target packages &#8212; Networking applications &#8212; dhcpd<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 20: <strong>Target packages &#8212; Networking applications &#8212; dropbear<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 21: <strong>Target packages &#8212; Networking applications &#8212; ifupdown scripts<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 22: <strong>Target packages &#8212; Networking applications &#8212; hostapd<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 23: <strong>Target packages &#8212; Networking applications &#8212; iperf<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 24: <strong>Target packages &#8212; Networking applications &#8212; iperf3<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 25: <strong>Target packages &#8212; Networking applications &#8212; fping<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 26: <strong>Target packages &#8212; Networking applications &#8212; iw<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 27: <strong>Target packages &#8212; Networking applications &#8212; iwd<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 28: <strong>Target packages &#8212; Networking applications &#8212; wpa_supplicant<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 28: <strong>Target packages &#8212; Networking applications &#8212; wireless tools<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 29: <strong>Filesystem images &#8212; cpio the root filesystem &#8212; [*]<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 30:\u00a0 <strong>Filesystem images &#8212; Compression method &#8212; lzma<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 31: <strong>Host Utilites &#8212; host dosfstools<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 32: <strong>Host Utilites &#8212; host genimage<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u043f\u0446\u0438\u044f 33: <strong>Host Utilites &#8212; host mtools<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0439 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong>Save<\/strong> \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u043a\u043e\u043d\u0444\u0438\u0433 (\u043c\u043e\u0436\u043d\u043e \u0432\u0437\u044f\u0442\u044c \u0442\u0443\u0442 \u0438 \u043f\u043e\u0434\u043b\u043e\u0436\u0438\u0442\u044c \u043a \u0441\u0435\u0431\u0435 <a href=\"https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/buildroot.config\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/buildroot.config<\/u><\/a>);<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c F9 \u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0441\u0431\u043e\u0440\u043a\u0438: <strong>make -C \/home\/megalloid\/buildroot O=&#187; class=&#187;formula inline&#187;>PWD ARCH=arm BR2_JLEVEL=&#187;<img decoding=\"async\" class=\"formula inline\" source=\"((\" alt=\"((\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e5d\/55b\/77d\/e5d55b77d535464756de9815f50f4c6a.svg\"\/>(nproc) &#8212; 1))&#187;<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0416\u0434\u0451\u043c \u043a\u043e\u0433\u0434\u0430 \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u0442\u0441\u044f \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f, \u0441\u0430\u043c\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u0432\u0430\u0440\u0438\u0442\u044c \u0438 \u0432\u044b\u043f\u0438\u0442\u044c \u043a\u043e\u0444\u0435 =)<\/p>\n<\/li>\n<\/ol>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043a\u043e\u0433\u0434\u0430 \u043e\u0431\u0440\u0430\u0437 RootFS \u0441\u043e\u0431\u0440\u0430\u043b\u0441\u044f \u043d\u0430\u0434\u043e \u0435\u0433\u043e \u043f\u043e\u0434\u043f\u0438\u0441\u0430\u0442\u044c \u0438 \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u043a \u0432\u0438\u0434\u0443, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0435\u0433\u043e \u0441\u043c\u043e\u0436\u0435\u0442 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u043f\u0435\u0440\u0435\u0432\u0430\u0440\u0438\u0442\u044c U-Boot:<\/p>\n<ol>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043f\u0430\u043f\u043a\u0443 \u0441 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 \u043e\u0431\u0440\u0430\u0437\u0430\u043c\u0438: <strong>cd buildroot\/images<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043c \u043f\u043e\u0434\u043f\u0438\u0441\u044c: <strong>mkimage -A arm -T ramdisk -C gzip -d rootfs.cpio uramdisk.image.gz<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0421\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u043c <strong>uramdisk.image.gz<\/strong> \u043d\u0430 \u0437\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u0443\u044e SD-\u043a\u0430\u0440\u0442\u0443;<\/p>\n<\/li>\n<\/ol>\n<p>\u041d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0443 \u043e\u0431\u0440\u0430\u0437\u043e\u0432 \u0432 U-Boot:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430\u0434\u043e \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0442\u044c\u0441\u044f \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c U-Boot \u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0442\u0443\u0434\u0430: <strong>setenv mmc_boot \u201cfatload mmc 0 0x2000000 uramdisk.image.gz; fatload mmc 0 0x4000000 uImage; fatload mmc 0 0x4500000 system.dtb; bootm 0x4000000 0x2000000 0x4500000;\u201d<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u044d\u0442\u0443 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e \u0447\u0435\u0440\u0435\u0437 <strong>saveenv<\/strong> \u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c\u0441\u044f;<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u041e\u0421;<\/p>\n<\/li>\n<\/ol>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043c\u043e\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430 \u0438 \u043d\u0435\u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f.<\/p>\n<h2>\u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u043c\u043e\u0434\u0443\u043b\u044f \u044f\u0434\u0440\u0430 88\u04452cs \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f<\/h2>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u043a \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u043c\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0443, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u043c\u0443 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f &#8212; \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0443 \u043d\u0430\u0448\u0435\u0433\u043e Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f. \u041d\u0430 \u043f\u0440\u043e\u0441\u0442\u043e\u0440\u0430\u0445 GITHUB \u044f \u043d\u0430\u0448\u0435\u043b \u0432\u043f\u043e\u043b\u043d\u0435 \u0441\u0435\u0431\u0435 \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u043c\u044b\u0439 \u0438 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430. \u0427\u0442\u043e\u0431\u044b \u0441\u043e\u0431\u0440\u0430\u0442\u044c \u0434\u0440\u0430\u0439\u0432\u0435\u0440 out-of-tree \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<ol>\n<li>\n<p>\u0421\u043a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0435 \u043a\u043e\u0434\u044b \u0441\u0435\u0431\u0435: <strong>git clone <\/strong><a href=\"https:\/\/github.com\/megalloid\/rtl88x2cs\" rel=\"noopener noreferrer nofollow\"><strong>https:\/\/github.com\/megalloid\/rtl88x2cs<\/strong><\/a><\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u043c \u0432\u0435\u0442\u043a\u0443 \u043d\u0430 \u0432\u0435\u0440\u0441\u0438\u044e \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u0443\u044e \u0441 5.15: <strong>git checkout tune_for_jethub_5_14<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044e: <strong>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- KSRC=&#187;\/home\/megalloid\/linux-xlnx&#187;<\/strong> (\u0433\u0434\u0435 KSRC &#8212; \u043f\u0443\u0442\u044c \u0434\u043e \u043f\u0430\u043f\u043a\u0438 \u0441 \u044f\u0434\u0440\u043e\u043c LInux \u0438\u0437 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0433\u043e \u0448\u0430\u0433\u0430);<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430 \u0432\u044b\u0445\u043e\u0434\u0435 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0432 \u044d\u0442\u043e\u0439 \u043f\u0430\u043f\u043a\u0435 \u0444\u0430\u0439\u043b <strong><em>88x2cs.ko<\/em><\/strong>, \u0435\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c \u0442\u0443\u0434\u0430 \u0436\u0435 \u043d\u0430 \u0437\u0430\u0433\u0440\u0443\u0437\u043e\u0447\u043d\u0443\u044e <strong><em>SD-\u043a\u0430\u0440\u0442\u0443<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f \u043b\u0438 \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 \u0438 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043b\u0438 wlan-\u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441:<\/p>\n<ol>\n<li>\n<p>\u041c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c SD-\u043a\u0430\u0440\u0442\u0443 \u0432 \u0444\u0430\u0439\u043b\u043e\u0432\u0443\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443: <strong>mount \/dev\/mmcblk0p1 \/mnt<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043a\u0430\u0442\u0430\u043b\u043e\u0433 SD-\u043a\u0430\u0440\u0442\u044b: <strong>cd \/mnt\/<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u043c <strong>insmod 88x2cs.ko<\/strong> \u0434\u043b\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043c\u043e\u0434\u0443\u043b\u044f \u044f\u0434\u0440\u0430;<\/p>\n<\/li>\n<\/ol>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0443 <strong><em>ifconfig<\/em><\/strong> &#8212; \u0438 \u0432\u0438\u0434\u0438\u043c, \u0447\u0442\u043e \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f <strong><em>wlan0<\/em><\/strong> \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/71f\/efc\/c9a\/71fefcc9af149185e1a6ac8b0e0f437b.png\" width=\"632\" height=\"533\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/71f\/efc\/c9a\/71fefcc9af149185e1a6ac8b0e0f437b.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u042d\u0442\u043e \u0433\u043e\u0432\u043e\u0440\u0438\u0442 \u043e \u0442\u043e\u043c, \u0447\u0442\u043e \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 \u0443\u0441\u043f\u0435\u0448\u043d\u043e \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u043b\u0441\u044f \u0438 \u0433\u043e\u0442\u043e\u0432 \u043a \u0440\u0430\u0431\u043e\u0442\u0435. \u0412 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0433\u043b\u0430\u0432\u0435 \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435 <strong><em>wlan0<\/em><\/strong> \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0435 \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u0438 <strong><em>Wi-Fi<\/em><\/strong>, \u043f\u0440\u043e\u0433\u043e\u043d\u0443 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0447\u0435\u0440\u0435\u0437 <strong><em>iPerf<\/em><\/strong>;<\/p>\n<p>\u041f\u0440\u043e \u043c\u043e\u0434\u0443\u043b\u0438 \u044f\u0434\u0440\u0430 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0442\u0443\u0442: <a href=\"https:\/\/habr.com\/ru\/post\/117654\/\" rel=\"noopener noreferrer nofollow\">https:\/\/habr.com\/ru\/post\/117654\/<\/a><\/p>\n<h2>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 Wi-Fi \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 \u0438 \u0438\u0437\u043c\u0435\u0440\u0435\u043d\u0438\u0435 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c iPerf<\/h2>\n<p>\u0414\u043b\u044f \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 Wi-Fi \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u0444\u0438\u0433, \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0435\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043d\u0430 SD-\u043a\u0430\u0440\u0442\u0435 \u0432 \u0432\u0438\u0434\u0435 \u0444\u0430\u0439\u043b\u0430 <strong><em>wpa_supplicant.conf<\/em><\/strong>.\u00a0<\/p>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438 Zynq \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b:<\/p>\n<ol>\n<li>\n<p>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0444\u0430\u0439\u043b \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438: <strong>touch \/mnt\/wpa_supplicant.conf<\/strong><\/p>\n<\/li>\n<li>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u0435\u0433\u043e \u043d\u0430 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435: <strong>vi \/mnt\/wpa_supplicant.conf<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c:\u00a0<\/p>\n<\/li>\n<\/ol>\n<pre><code>network={ ssid=\"ASUS\" scan_ssid=1 key_mgmt=WPA-PSK psk=\"megapassword\" }<\/code><\/pre>\n<ol start=\"4\">\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c wpa_supplicant: <strong>wpa_supplicant -B -Dnl80211 -iwlan0 -c\/mnt\/wpa_supplicant.conf -P\/var\/run\/wpa_supplicant.pid -dd -f\/mnt\/wpa_supplicant.log<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0427\u0435\u0440\u0435\u0437 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f IP-\u0430\u0434\u0440\u0435\u0441 \u043d\u0430 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0435 <strong>wlan0<\/strong> \u0438 \u0431\u0443\u0434\u0435\u0442 <strong>\u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0430<\/strong> \u0441\u0432\u044f\u0437\u044c \u0441 \u0440\u043e\u0443\u0442\u0435\u0440\u043e\u043c;<\/p>\n<\/li>\n<\/ol>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0433\u043d\u0430\u0442\u044c \u0442\u0440\u0430\u0444\u0438\u043a \u0441 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0430 (\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d \u043a \u0440\u043e\u0443\u0442\u0435\u0440\u0443 \u043a\u0430\u0431\u0435\u043b\u0435\u043c) \u043d\u0430 Zynq \u0438 \u043e\u0431\u0440\u0430\u0442\u043d\u043e. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043d\u0430 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0435: <strong>iperf3 -s<\/strong><\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043d\u0430 Zynq: <strong>iperf3 -c &lt;IP \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0430> -N -i1 -t60 -u<\/strong>\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0427\u0442\u043e\u0431\u044b \u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0442\u0440\u0430\u0444\u0438\u043a \u0432 \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u043c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043d\u0430 Zynq \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c: <strong>iperf3 -c &lt;IP \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u0430> -N -i1 -t60 -R -u<\/strong><\/p>\n<\/li>\n<\/ol>\n<p>\u041d\u0430\u0431\u043b\u044e\u0434\u0430\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:<\/p>\n<pre><code># iperf3 -c 192.168.2.3 -N -i1 -u -b300M Connecting to host 192.168.2.3, port 5201 [\u00a0 5] local 192.168.2.233 port 55279 connected to 192.168.2.3 port 5201 [ ID] Interval \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 Transfer \u00a0 \u00a0 Bitrate \u00a0 \u00a0 \u00a0 \u00a0 Total Datagrams [\u00a0 5] \u00a0 0.00-1.00 \u00a0 sec\u00a0 15.9 MBytes \u00a0 133 Mbits\/sec\u00a0 11481\u00a0\u00a0 [\u00a0 5] \u00a0 1.00-2.00 \u00a0 sec\u00a0 16.8 MBytes \u00a0 141 Mbits\/sec\u00a0 12154\u00a0\u00a0 [\u00a0 5] \u00a0 2.00-3.00 \u00a0 sec\u00a0 17.0 MBytes \u00a0 143 Mbits\/sec\u00a0 12336\u00a0\u00a0 [\u00a0 5] \u00a0 3.00-4.00 \u00a0 sec\u00a0 17.0 MBytes \u00a0 142 Mbits\/sec\u00a0 12275\u00a0\u00a0 [\u00a0 5] \u00a0 4.00-5.00 \u00a0 sec\u00a0 16.3 MBytes \u00a0 137 Mbits\/sec\u00a0 11812\u00a0\u00a0 [\u00a0 5] \u00a0 5.00-6.00 \u00a0 sec\u00a0 16.3 MBytes \u00a0 137 Mbits\/sec\u00a0 11831\u00a0\u00a0 [\u00a0 5] \u00a0 6.00-7.00 \u00a0 sec\u00a0 17.0 MBytes \u00a0 143 Mbits\/sec\u00a0 12332\u00a0\u00a0 [\u00a0 5] \u00a0 7.00-8.00 \u00a0 sec\u00a0 10.4 MBytes\u00a0 87.4 Mbits\/sec\u00a0 7545\u00a0\u00a0 [\u00a0 5] \u00a0 8.00-9.00 \u00a0 sec\u00a0 14.8 MBytes \u00a0 124 Mbits\/sec\u00a0 10736\u00a0\u00a0 [\u00a0 5] \u00a0 9.00-10.00\u00a0 sec\u00a0 15.3 MBytes \u00a0 128 Mbits\/sec\u00a0 11050\u00a0\u00a0  - - - - - - - - - - - - - - - - - - - - - - - - -  [ ID] Interval \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 Transfer \u00a0 \u00a0 Bitrate \u00a0 \u00a0 \u00a0 \u00a0 Jitter\u00a0 \u00a0 Lost\/Total Datagrams [\u00a0 5] \u00a0 0.00-10.00\u00a0 sec \u00a0 157 MBytes \u00a0 132 Mbits\/sec\u00a0 0.000 ms\u00a0 0\/113552 (0%)\u00a0 sender [\u00a0 5] \u00a0 0.00-10.03\u00a0 sec \u00a0 157 MBytes \u00a0 131 Mbits\/sec\u00a0 0.066 ms\u00a0 0\/113551 (0%)\u00a0 receiver iperf Done.  # iperf3 -c 192.168.2.3 -N -i1 -u -b300M -R Connecting to host 192.168.2.3, port 5201 Reverse mode, remote host 192.168.2.3 is sending [\u00a0 5] local 192.168.2.233 port 50266 connected to 192.168.2.3 port 5201 [ ID] Interval \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 Transfer \u00a0 \u00a0 Bitrate \u00a0 \u00a0 \u00a0 \u00a0 Jitter\u00a0 \u00a0 Lost\/Total Datagrams [\u00a0 5] \u00a0 0.00-1.00 \u00a0 sec\u00a0 12.0 MBytes \u00a0 101 Mbits\/sec\u00a0 0.043 ms\u00a0 0\/8693 (0%)\u00a0\u00a0 [\u00a0 5] \u00a0 1.00-2.00 \u00a0 sec\u00a0 12.2 MBytes \u00a0 102 Mbits\/sec\u00a0 0.072 ms\u00a0 0\/8842 (0%)\u00a0\u00a0 [\u00a0 5] \u00a0 2.00-3.00 \u00a0 sec\u00a0 12.6 MBytes \u00a0 105 Mbits\/sec\u00a0 0.161 ms\u00a0 16279\/25380 (64%)\u00a0\u00a0 [\u00a0 5] \u00a0 3.00-4.00 \u00a0 sec\u00a0 12.1 MBytes \u00a0 101 Mbits\/sec\u00a0 0.032 ms\u00a0 16435\/25185 (65%)\u00a0\u00a0 [\u00a0 5] \u00a0 4.00-5.00 \u00a0 sec\u00a0 12.5 MBytes \u00a0 105 Mbits\/sec\u00a0 0.076 ms\u00a0 17924\/27002 (66%)\u00a0\u00a0 [\u00a0 5] \u00a0 5.00-6.00 \u00a0 sec\u00a0 12.4 MBytes \u00a0 104 Mbits\/sec\u00a0 0.320 ms\u00a0 16380\/25350 (65%)\u00a0\u00a0 [\u00a0 5] \u00a0 6.00-7.00 \u00a0 sec\u00a0 12.6 MBytes \u00a0 105 Mbits\/sec\u00a0 0.055 ms\u00a0 16807\/25910 (65%)\u00a0\u00a0 [\u00a0 5] \u00a0 7.00-8.00 \u00a0 sec\u00a0 12.5 MBytes \u00a0 105 Mbits\/sec\u00a0 0.196 ms\u00a0 17230\/26287 (66%)\u00a0\u00a0 [\u00a0 5] \u00a0 8.00-9.00 \u00a0 sec\u00a0 12.3 MBytes \u00a0 103 Mbits\/sec\u00a0 0.050 ms\u00a0 16305\/25184 (65%)\u00a0\u00a0 [\u00a0 5] \u00a0 9.00-10.00\u00a0 sec\u00a0 12.6 MBytes \u00a0 106 Mbits\/sec\u00a0 0.100 ms\u00a0 11046\/20165 (55%)\u00a0\u00a0  - - - - - - - - - - - - - - - - - - - - - - - - -  [ ID] Interval \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 Transfer \u00a0 \u00a0 Bitrate \u00a0 \u00a0 \u00a0 \u00a0 Jitter\u00a0 \u00a0 Lost\/Total Datagrams [\u00a0 5] \u00a0 0.00-10.03\u00a0 sec \u00a0 359 MBytes \u00a0 300 Mbits\/sec\u00a0 0.000 ms\u00a0 0\/259695 (0%)\u00a0 sender [\u00a0 5] \u00a0 0.00-10.00\u00a0 sec \u00a0 124 MBytes \u00a0 104 Mbits\/sec\u00a0 0.100 ms\u00a0 128406\/217998 (59%)\u00a0 receiver  iperf Done.<\/code><\/pre>\n<p>\u0421\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432 \u0446\u0435\u043b\u043e\u043c \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0437\u0430\u044f\u0432\u043b\u0435\u043d\u043d\u044b\u043c Xilinx \u0446\u0438\u0444\u0440\u0430\u043c: \u043e\u043a\u043e\u043b\u043e 20 \u041c\u0431\u0430\u0439\u0442\\\u0441\u0435\u043a <strong>(\u043e\u043a\u043e\u043b\u043e 150 \u041c\u0431\u0438\u0442\\\u0441)<\/strong>. \u0412 \u0438\u0442\u043e\u0433\u0435 \u0435\u0441\u043b\u0438 \u0431\u0443\u0434\u0435\u043c \u0438\u043c\u0435\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u0432 \u044d\u0444\u0438\u0440\u0435 &#8212; \u044d\u0442\u0430 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0431\u0443\u0434\u0435\u0442 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u0438 \u0432 2.4 \u0413\u0413\u0446 \u0438 5 \u0413\u0413\u0446. \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u0441\u0435\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f\u043c. <\/p>\n<h2>\u041f\u043e\u0434\u0432\u0435\u0434\u0435\u043c \u0438\u0442\u043e\u0433<\/h2>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u0440\u043e\u043f\u043e\u0442\u043b\u0438\u0432\u043e\u0433\u043e \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0431\u0435\u0437 \u043a\u0430\u043a\u0438\u0445-\u043b\u0438\u0431\u043e how-to \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u043e\u0431\u0443\u0437\u0434\u0430\u0442\u044c \u044d\u0442\u0443 \u0436\u0435\u043b\u0435\u0437\u043a\u0443. \u041d\u0430 \u043e\u0431\u0449\u0443\u044e \u043f\u0440\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u044d\u0442\u043e\u0433\u043e \u0432\u0441\u0435\u0433\u043e \u0443\u0448\u043b\u043e \u043e\u043a\u043e\u043b\u043e \u043d\u0435\u0434\u0435\u043b\u0438, \u0447\u0442\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u0434\u043e\u0441\u0442\u0430\u0432\u0438\u043b\u043e \u043d\u0435\u043c\u0430\u043b\u043e \u0443\u0434\u043e\u0432\u043e\u043b\u044c\u0441\u0442\u0432\u0438\u044f \u043f\u043e \u043c\u0435\u0440\u0435 \u043f\u0440\u043e\u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u043a \u0440\u0435\u0448\u0435\u043d\u0438\u044e \u0437\u0430\u0434\u0430\u0447\u0438. \u0411\u0443\u0434\u0443 \u043d\u0430\u0434\u0435\u044f\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u043c\u043e\u0439 \u043e\u043f\u044b\u0442 \u043a\u043e\u043c\u0443-\u043d\u0438\u0431\u0443\u0434\u044c \u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u0441\u044f \u0438 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0441\u043e\u043a\u043e \u043e\u0446\u0435\u043d\u0435\u043d. \u0421\u043f\u0430\u0441\u0438\u0431\u043e!<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \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\/658487\/\"> https:\/\/habr.com\/ru\/post\/658487\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446-\u0442\u043e \u043f\u0440\u0438\u0448\u043b\u0430 \u043f\u043e\u0440\u0430 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u044c \u0438\u0437\u0443\u0447\u0435\u043d\u0438\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u043b\u0430\u0442\u044b Zynq QMTech \u0438 SoC XC7Z020. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0430\u044f \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u044f \u0434\u043b\u044f \u0441\u0435\u0431\u044f \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043e\u0431\u0443\u0447\u0430\u044e\u0449\u0435\u0439 &#8212; \u043e\u0441\u043d\u0430\u0441\u0442\u0438\u0442\u044c \u043f\u043b\u0430\u0442\u0443 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u0435\u043c Realtek RTL8822CS \u0438, \u0435\u0441\u043b\u0438 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044c \u0431\u0443\u0434\u0435\u0442 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d, \u0430 \u043d\u0443\u0436\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0435\u0449\u0451 \u043e\u0434\u043d\u0430 \u0444\u043b\u0435\u0448\u043a\u0430 &#8212; \u0432\u0442\u043e\u0440\u044b\u043c \u043f\u043e\u0440\u0442\u043e\u043c \u0434\u043b\u044f SD-\u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438. \u0415\u0441\u043b\u0438 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0441\u0442\u0438 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044f \u044d\u0442\u043e \u0432\u0441\u0451 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043b &#8212; \u0434\u043e\u0431\u0440\u043e \u043f\u043e\u0436\u0430\u043b\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0442.\u00a0<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p><strong>\u0412\u0430\u0436\u043d\u043e!<\/strong> \u041f\u0435\u0440\u0435\u0434 \u043d\u0430\u0447\u0430\u043b\u043e\u043c \u043f\u043e\u0432\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043d\u0438\u044f, \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0431\u044b \u0437\u0430\u0440\u0430\u043d\u0435\u0435 \u043e\u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0446\u0435\u043b\u044c, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u044f \u043f\u0440\u0435\u0441\u043b\u0435\u0434\u0443\u044e \u043f\u0440\u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438 &#8212; \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043e \u0441\u0432\u043e\u0435\u043c \u043e\u043f\u044b\u0442\u0435, \u0441 \u0447\u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0447\u0430\u0442\u044c, \u043f\u0440\u0438 \u0438\u0437\u0443\u0447\u0435\u043d\u0438\u0438 \u043e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u044b\u0445 \u043f\u043b\u0430\u0442 \u043d\u0430 \u0431\u0430\u0437\u0435 Zynq. \u042f \u043d\u0435 \u044f\u0432\u043b\u044f\u044e\u0441\u044c \u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u043c \u043f\u043e\u0434 \u041f\u041b\u0418\u0421 \u0438 SoC Zynq, \u043d\u0435 \u044f\u0432\u043b\u044f\u044e\u0441\u044c \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0441\u0442\u043e\u043c \u043f\u043e\u0434 Linux \u0438 \u043c\u043e\u0433\u0443 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u043a\u0430\u043a\u0438\u0435-\u043b\u0438\u0431\u043e \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u0442\u0435\u0440\u043c\u0438\u043d\u043e\u043b\u043e\u0433\u0438\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0443\u0442\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447, etc. \u041d\u043e \u043e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u043b\u044e\u0431\u0430\u044f \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u0438 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u043a\u0440\u0438\u0442\u0438\u043a\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u0435\u0442\u0441\u044f. \u0427\u0442\u043e \u0436, \u043f\u043e\u0435\u0445\u0430\u043b\u0438\u2026<\/p>\n<h2>\u0421\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u043c \u0446\u0435\u043b\u044c \u0438 \u0437\u0430\u0434\u0430\u0447\u0438<\/h2>\n<p>\u0418\u0442\u0430\u043a, \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u043f\u043b\u0430\u0442\u0430, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u0430\u044f \u0432 \u044d\u0442\u043e\u0439 (<a href=\"https:\/\/habr.com\/ru\/post\/559946\/\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/habr.com\/ru\/post\/559946\/<\/u><\/a>) \u0441\u0442\u0430\u0442\u044c\u0435 \u0438 \u0435\u0441\u0442\u044c \u0436\u0435\u043b\u0430\u043d\u0438\u0435 \u043f\u0440\u0438\u043a\u0440\u0443\u0442\u0438\u0442\u044c \u043a \u043d\u0435\u0439 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044c Realtek RTL8822CS. \u041c\u043e\u0434\u0443\u043b\u044c, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0434\u043e\u043b\u0436\u0435\u043d \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u041e\u0421 Linux \u0438 \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0438\u0442\u044c \u043f\u0440\u043e\u043f\u0443\u0441\u043a\u043d\u0443\u044e \u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c \u0434\u043e 150 \u041c\u0431\u0438\u0442\\\u0441 (\u0441 \u0447\u0435\u043c \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0442\u0430\u043a\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435\u00a0 \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u043e\u0439 \u0446\u0438\u0444\u0440\u043e\u0439 &#8212; \u043d\u0438\u0436\u0435). \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430 \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u043d\u043e\u0433\u043e SDIO &#8212; \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u0442\u043e\u0440\u043e\u0439 \u043f\u043e\u0440\u0442 \u0434\u043b\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f SD-\u043a\u0430\u0440\u0442.<\/p>\n<p>\u0418\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u0434\u0430\u0447, \u0440\u0435\u0448\u0438\u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0434\u043e\u0441\u0442\u0438\u0433\u043d\u0443\u0442\u044c \u0446\u0435\u043b\u0438:<\/p>\n<ol>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u043d\u043e\u0441\u0430 \u043b\u0438\u043d\u0438\u0439 SDIO \u0447\u0435\u0440\u0435\u0437 EMIO (\u0442.\u0435. \u0447\u0435\u0440\u0435\u0437 \u043f\u0438\u043d\u044b PL-\u0447\u0430\u0441\u0442\u0438 Zynq) \u0438 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c bitstream-\u0444\u0430\u0439\u043b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c SDIO \u0447\u0435\u0440\u0435\u0437 EMIO \u0432 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0438 baremetal \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c microSD-\u043a\u0430\u0440\u0442\u043e\u0447\u043a\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0418\u0437\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u0435\u0437\u043e\u043d\u0438\u043d\u043d\u044b\u0435 \u043f\u043b\u0430\u0442\u044b \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u043d\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c First Stage Bootloader, Device Tree Source, U-Boot, Linux Kernel \u0432 \u043d\u0443\u0436\u043d\u043e\u0439 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e \u043c\u043e\u0434\u0443\u043b\u044c cfg80211, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438\u043d\u0443\u043a\u0441\u043e\u0432\u044b\u043c API \u0434\u043b\u044f 802.11 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432;<\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c \u044f\u0434\u0440\u0430 88x2cs, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u043e\u043c \u0434\u043b\u044f \u043c\u043e\u0434\u0443\u043b\u044f Wi-Fi RTL8822CS \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e\u0432\u0435\u0440\u0445 SDIO-\u0448\u0438\u043d\u044b;<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u0438, \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043a\u0430\u043d\u044b \u044d\u0444\u0438\u0440\u0430, \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0440\u0430\u0431\u043e\u0447\u0438\u0435 \u0443\u0440\u043e\u0432\u043d\u0438, \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0437\u0430\u043c\u0435\u0440\u044b \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 downstream\/upstream-\u0442\u0440\u0430\u0444\u0438\u043a\u043e\u043c \u0447\u0435\u0440\u0435\u0437 iPerf;<\/p>\n<\/li>\n<\/ol>\n<p>\u0418\u0442\u0430\u043a. \u041f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u043a \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0430\u043c\u0435\u0447\u0435\u043d\u043d\u043e\u0433\u043e, \u0432 \u0446\u0435\u043b\u043e\u043c, \u043d\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u0438\u043b\u044c\u043d\u043e \u0441\u043b\u043e\u0436\u043d\u043e =)<\/p>\n<h2>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432 Vivado \u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f PL<\/h2>\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0433\u043b\u0430\u0432\u0435 \u044f \u043a\u0440\u0430\u0442\u043a\u043e (\u0431\u0435\u0437 \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442\u043e\u0432) \u043e\u043f\u0438\u0448\u0443 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 \u0430\u043a\u0446\u0435\u043d\u0442\u0430\u043c\u0438 \u043d\u0430 \u0432\u0430\u0436\u043d\u044b\u0445 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u0445. \u0415\u0441\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f \u0441 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430\u043c\u0438 &#8212; \u043c\u043e\u0436\u043d\u043e \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c\u0441\u044f \u043a \u043c\u043e\u0438\u043c \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u043c \u0441\u0442\u0430\u0442\u044c\u044f\u043c.\u00a0<\/p>\n<p>\u041e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u043c <strong><em>Vivado<\/em><\/strong> \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 \u0447\u0435\u0440\u0435\u0437 \u043a\u043d\u043e\u043f\u043a\u0443 <strong><em>Create Project<\/em><\/strong>. \u041e\u0442\u043a\u0440\u043e\u0435\u0442\u0441\u044f \u043c\u0430\u0441\u0442\u0435\u0440 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430, \u0431\u044b\u0441\u0442\u0440\u043e \u043f\u0440\u043e\u0439\u0434\u0435\u043c\u0441\u044f \u043f\u043e \u0448\u0430\u0433\u0430\u043c.\u00a0<\/p>\n<ol>\n<li>\n<p>\u0414\u0430\u0451\u043c \u0438\u043c\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0443, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 <strong><em>SDIO_EMIO<\/em><\/strong> \u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u043f\u0430\u043f\u043a\u0443 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p>\u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c, \u0447\u0442\u043e \u044d\u0442\u043e <strong><em>RTL Project<\/em><\/strong>, \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u0439 \u0433\u0430\u043b\u043e\u0447\u043a\u0443 <strong><em>Do not specify sources at this time<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0445\u043e\u0434\u0438\u043c \u043c\u043e\u0434\u0435\u043b\u044c SoC \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430 \u043f\u043b\u0430\u0442\u0435. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044d\u0442\u043e <strong><em>xc7z020clg400-1<\/em><\/strong>;<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c Finish.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u043b\u0435\u0432\u043e\u043c \u043c\u0435\u043d\u044e <strong><em>IP Integrator<\/em><\/strong> \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Create Block Design<\/em><\/strong> \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u0434\u0438\u0437\u0430\u0439\u043d. \u041d\u0430\u0437\u043e\u0432\u0451\u043c \u0435\u0433\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u044b <strong><em>block_design<\/em><\/strong>.<\/p>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b Zynq \u043d\u0430 \u0434\u0438\u0430\u0433\u0440\u0430\u043c\u043c\u0443 \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0436\u0430\u0442\u0438\u0435 \u043f\u0440\u0430\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u043e\u0439 <strong><em>Add IP &#8212; ZYNQ7 Processing System<\/em><\/strong>. \u0421\u0440\u0430\u0437\u0443 \u0436\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u043c \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043e\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0442\u043e\u0440\u0430, \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u043d\u0430 \u0437\u0435\u043b\u0435\u043d\u043e\u043c \u043f\u043e\u043b\u0435 <strong><em>Run Block Automation<\/em><\/strong> \u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b.\u00a0<\/p>\n<p>\u042f \u0437\u0430\u0440\u0430\u043d\u0435\u0435 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u043b \u0448\u0430\u0431\u043b\u043e\u043d \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a PS, \u0447\u0442\u043e\u0431\u044b \u0432 \u043a\u0430\u0436\u0434\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043d\u0435 \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0451 \u0437\u0430\u043d\u043e\u0432\u043e. \u0412\u0437\u044f\u0442\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0442\u0443\u0442 (<a href=\"https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/ZynqQMTech.tcl\" rel=\"noopener noreferrer nofollow\"><u>https:\/\/github.com\/megalloid\/zynq_qmtech\/blob\/main\/ZynqQMTech.tcl<\/u><\/a>). \u0427\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>Presets &#8212; Apply Configuration <\/em><\/strong>\u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0435\u0433\u043e \u0438 \u0441\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>Peripherial I\/O Pins<\/em><\/strong>.<\/p>\n<p>\u0421\u0442\u0430\u0432\u0438\u043c \u0433\u0430\u043b\u043e\u0447\u043a\u0443 \u0432\u043e\u0437\u043b\u0435 \u043c\u0435\u043d\u044e <strong><em>SD 1<\/em><\/strong> \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0432\u044b\u0431\u0440\u0430\u043d \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f \u0447\u0435\u0440\u0435\u0437 <strong><em>EMIO<\/em><\/strong>:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u044f \u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439, \u0432 \u0442.\u0447. \u0447\u0430\u0441\u0442\u043e\u0442\u044b \u0442\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f SDIO, PL. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u0430\u0440\u0442\u0438\u043d\u0443 (\u0435\u0441\u043b\u0438 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0433\u0440\u0443\u043f\u043f\u0443 \u0441\u0438\u0433\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043b\u0438\u043d\u0438\u0439 <strong><em>SDIO_1<\/em><\/strong>):<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0430\u0441 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u044e\u0442 \u043b\u0438\u043d\u0438\u0438 CLK, CMD \u0438 4 \u043b\u0438\u043d\u0438\u0438 DATA, \u0447\u0442\u043e \u0432 \u043e\u0431\u0449\u0435\u043c-\u0442\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0434\u043b\u044f SDIO-\u0448\u0438\u043d\u044b. \u041d\u043e \u0432\u043e\u0442 \u043d\u0435\u0437\u0430\u0434\u0430\u0447\u0430, \u043a\u0430\u0436\u0434\u0430\u044f \u0438\u0437 \u043b\u0438\u043d\u0438\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0442\u0440\u0435\u043c\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u043c\u0438 \u0441\u0438\u0433\u043d\u0430\u043b\u0430\u043c\u0438. \u0414\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0440\u0443\u043a\u0430\u043c\u0438 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0431\u0443\u0444\u0435\u0440 IOBUF, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u0443\u0434\u0435\u0442 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0438\u043d T \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 \u0438 \u0440\u0430\u0437\u0440\u0443\u043b\u0438\u0442 Input, Output \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u043a\u0430\u043a \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0435\u0433\u043e \u0441 \u0434\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u043c \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u043c I\/O. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043e\u043d \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0422.\u043a. \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0445 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u0432 \u043e\u043d \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 &#8212; \u043d\u0443\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0432\u043e\u0439 IP-\u043c\u043e\u0434\u0443\u043b\u044c \u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0435\u0433\u043e \u043d\u0430 \u0441\u0445\u0435\u043c\u0443. \u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u043e\u043d \u0431\u0443\u0434\u0435\u0442 \u0441\u0432\u043e\u0439.\u00a0\u00a0<\/p>\n<p>\u0427\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>Sources &#8212; Add Sources (Alt + A)<\/em><\/strong> \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c <strong><em>Design Source &#8212; Create File<\/em><\/strong>, \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0442\u0438\u043f \u0444\u0430\u0439\u043b\u0430 <strong><em>Verilog<\/em><\/strong> \u0438 \u043d\u0430\u0437\u043e\u0432\u0451\u043c \u0435\u0433\u043e <strong><em>iobuf_cmd<\/em><\/strong>.<\/p>\n<p>\u0417\u0430\u043f\u0438\u0448\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:<\/p>\n<pre><code>module iobuf_cmd ( \u00a0\u00a0\u00a0\u00a0input iobuf_i, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout\u00a0 iobuf_io \u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0.O(iobuf_o),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.IO(iobuf_io),\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0.I(iobuf_i),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.T(iobuf_t) \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 ); endmodule\u00a0<\/code><\/pre>\n<p>\u0422\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 CLK, \u0442\u043e\u043b\u044c\u043a\u043e \u0444\u0430\u0439\u043b \u043d\u0430\u0437\u043e\u0432\u0451\u043c <strong><em>iobuf_clk<\/em><\/strong>. \u0417\u0430\u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435:<\/p>\n<pre><code>module iobuf_clk ( \u00a0\u00a0\u00a0\u00a0input iobuf_i, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t, \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout\u00a0 iobuf_io\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0.O(iobuf_o),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.IO(iobuf_io),\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0.I(iobuf_i),\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0.T(iobuf_t) \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 ); endmodule\u00a0<\/code><\/pre>\n<p>\u0421 SDIO DATA \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u043b\u043e\u0436\u043d\u0435\u0435 \u0442.\u043a. \u043e\u043d\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043b\u0438\u043d\u0438\u0439. \u0422\u0430\u043a \u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0444\u0430\u0439\u043b <strong><em>iobuf_data<\/em><\/strong> \u0438 \u0437\u0430\u043f\u0438\u0448\u0435\u043c \u0432 \u043d\u0435\u0433\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:<\/p>\n<pre><code>module iobuf_data ( \u00a0\u00a0\u00a0\u00a0input [3:0] iobuf_i,\u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0input iobuf_t,\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438, high=input, low=output \u00a0\u00a0\u00a0\u00a0output [3:0]iobuf_o,\u00a0 \u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0inout [3:0] iobuf_io\u00a0 \u00a0 \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 (\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043a top-level \u043f\u043e\u0440\u0442\u0443) );  \u00a0\u00a0\u00a0\u00a0generate\u00a0 genvar i ; for (i=0; i&lt;4; i=i+1)\u00a0 \u00a0\u00a0\u00a0\u00a0begin\u00a0  \u00a0\u00a0\u00a0\u00a0IOBUF #( \u00a0\u00a0\u00a0\u00a0.DRIVE(12), \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f Drive Strength \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u043e\u0432 \u00a0\u00a0\u00a0\u00a0.IBUF_LOW_PWR(\"FALSE\"), \u00a0 \u00a0 \/\/ Low Power - \"TRUE\", High Perforrmance = \"FALSE\" \u00a0\u00a0\u00a0\u00a0.IOSTANDARD(\"LVCMOS33\"),\u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442 \u0441\u0438\u0433\u043d\u0430\u043b\u0430 \u00a0\u00a0\u00a0\u00a0.SLEW(\"FAST\") \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \/\/ \u0423\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f slew rate ) \u00a0\u00a0\u00a0\u00a0\u00a0IOBUF_inst ( \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.O\u00a0 (iobuf_o[i]),\u00a0 \/\/ \u0412\u044b\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 .IO (iobuf_io[i]), \/\/ \u0414\u0432\u0443\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043f\u043e\u0440\u0442 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.I\u00a0 (iobuf_i[i]),\u00a0 \/\/ \u0412\u0445\u043e\u0434 \u0431\u0443\u0444\u0435\u0440\u0430 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0.T\u00a0 (iobuf_t)\u00a0 \u00a0 \u00a0 \/\/ \u0412\u0445\u043e\u0434\u043d\u043e\u0439 \u0441\u0438\u0433\u043d\u0430\u043b \u0441 \u0442\u0440\u0435\u043c\u044f \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c\u0438 \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0); \u00a0\u00a0\u00a0\u00a0end \u00a0\u00a0\u00a0\u00a0endgenerate endmodule<\/code><\/pre>\n<p>\u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437 \u043b\u0438\u043d\u0438\u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u0441\u0432\u043e\u0439 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u0430 IOBUF.<\/p>\n<p>\u041f\u043e\u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e \u0440\u0430\u0437\u043c\u0435\u0449\u0430\u0435\u043c \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u043c\u043e\u0434\u0443\u043b\u0438 \u043d\u0430 \u0434\u0438\u0430\u0433\u0440\u0430\u043c\u043c\u0443 \u0447\u0435\u0440\u0435\u0437 \u043a\u043b\u0438\u043a \u043f\u0440\u0430\u0432\u043e\u0439 \u043c\u044b\u0448\u043a\u043e\u0439 \u043f\u043e <strong><em>Diagram &#8212; Add Module<\/em><\/strong>. \u0421\u043e\u0435\u0434\u0438\u043d\u044f\u0435\u043c \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u0441 \u043d\u0443\u0436\u043d\u044b\u043c\u0438 \u043f\u043e\u0440\u0442\u0430\u043c\u0438 \u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435: <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0425\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0431\u044b \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0434\u0432\u0435 \u0432\u0430\u0436\u043d\u044b\u0435 \u0432\u0435\u0449\u0438:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430 \u043f\u043e\u0440\u0442 <strong><em>iobuf_t<\/em><\/strong> \u043c\u043e\u0434\u0443\u043b\u044f \u0434\u043b\u044f \u0441\u0438\u0433\u043d\u0430\u043b\u0430 <strong><em>CLK <\/em><\/strong>\u044f \u0434\u043e\u0431\u0430\u0432\u0438\u043b Constant \u0441 \u0448\u0438\u0440\u0438\u043d\u043e\u0439 \u0432 1 \u0431\u0438\u0442 \u0438 \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c 0, \u0442.\u043a. \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u044e\u0449\u0435\u0433\u043e T-\u043f\u0438\u043d\u0430 \u0434\u043b\u044f CLK \u043d\u0435 \u043f\u0440\u0435\u0434\u0443\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043e;<\/p>\n<\/li>\n<li>\n<p>\u0421\u0434\u0435\u043b\u0430\u043b \u043f\u043e\u0440\u0442\u044b <strong><em>iobuf_io<\/em><\/strong> \u043a\u0430\u043a <strong><em>External<\/em><\/strong> \u0438 \u0434\u0430\u043b \u0438\u043c \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f;<\/p>\n<\/li>\n<li>\n<p>\u0421\u043e\u0435\u0434\u0438\u043d\u0438\u043b \u043f\u043e\u0440\u0442\u044b <strong><em>Input<\/em><\/strong> \u0441 \u043f\u043e\u0440\u0442\u0430\u043c\u0438 <strong><em>Output<\/em><\/strong>;<\/p>\n<\/li>\n<\/ol>\n<p>\u041d\u0430 \u0442\u0435\u043a\u0443\u0449\u0435\u043c \u044d\u0442\u0430\u043f\u0435 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0441\u0438\u043d\u0442\u0435\u0437 \u0438 \u043d\u0430\u0437\u043d\u0430\u0447\u0438\u0442\u044c \u0432\u044b\u0445\u043e\u0434\u044b \u043f\u043e\u0440\u0442\u043e\u0432 \u043d\u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043f\u043e\u0440\u0442\u044b. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<ol>\n<li>\n<p>\u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c \u043d\u0430 \u043c\u0435\u043d\u044e <strong><em>block_design<\/em><\/strong> \u043f\u0440\u0430\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u043e\u0439 \u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>Create HDL Wrapper<\/em><\/strong>.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0412 \u043c\u0435\u043d\u044e <strong><em>IP Integrator<\/em><\/strong> \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Generate Block Design<\/em><\/strong>;\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Synthesis Option &#8212; Global<\/em><\/strong> \u0438 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Apply<\/em><\/strong>, \u0437\u0430\u0442\u0435\u043c <strong><em>Generate<\/em><\/strong>.\u00a0<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438;<\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c <strong><em>Run Synthesis<\/em><\/strong> \u0434\u043b\u044f \u0441\u0442\u0430\u0440\u0442\u0430 \u0441\u0438\u043d\u0442\u0435\u0437\u0430 \u043d\u0430\u0448\u0435\u0433\u043e \u0434\u0438\u0437\u0430\u0439\u043d\u0430.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0436\u0438\u0434\u0430\u0435\u043c\u0441\u044f \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0438\u043d\u0442\u0435\u0437\u0430;<\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0441\u0438\u043d\u0442\u0435\u0437\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u0432 \u043c\u0435\u043d\u044e <strong><em>Open Synthesized Design <\/em><\/strong>\u0438 \u043e\u0442\u043a\u0440\u043e\u0435\u0442\u0441\u044f \u043c\u0435\u043d\u044e <strong><em>Package<\/em><\/strong> \u0441 \u043d\u0438\u0436\u043d\u0438\u043c \u043c\u0435\u043d\u044e <strong><em>I\/O Ports<\/em><\/strong>. \u0414\u0430\u043b\u0435\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e:<\/p>\n<ol>\n<li>\n<p>\u041e\u0442\u043c\u0435\u0442\u0438\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438\u0435 I\/O \u043f\u0438\u043d\u044b<\/p>\n<\/li>\n<li>\n<p>\u0423\u0431\u0435\u0434\u0438\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u0430 \u043f\u043e\u0434\u0442\u044f\u0436\u043a\u0430 PULLUP \u043d\u0430 \u0432\u0441\u0435\u0445 \u043f\u0438\u043d\u0430\u0445 \u043a\u0440\u043e\u043c\u0435 CLK;<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0421\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438, \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0444\u0430\u0439\u043b \u0441 <strong><em>constraints<\/em><\/strong>. \u041d\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u0435\u0433\u043e \u043a\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u0438 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Ok<\/em><\/strong>. \u041f\u043e\u0441\u043b\u0435 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Generate bitstream<\/em><\/strong>, \u0441\u043e\u0433\u043b\u0430\u0448\u0430\u0435\u043c\u0441\u044f \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0441\u0438\u043d\u0442\u0435\u0437 \u0443\u0441\u0442\u0430\u0440\u0435\u043b \u0438 \u0436\u0434\u0435\u043c \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0432\u0441\u0435\u0445 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440 \u0434\u043e \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f:<\/p>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u0435\u043c \u044d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c BSP \u0432 SDK \u0438 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u0438 SDIO \u0432 baremetal. \u0414\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u044d\u0442\u043e \u0447\u0435\u0440\u0435\u0437 \u043c\u0435\u043d\u044e <strong><em>File &#8212; Export &#8212; Export Hardware<\/em><\/strong>, \u0441\u0442\u0430\u0432\u0438\u043c <strong><em>Include bitstream<\/em><\/strong>. \u041d\u0430\u0436\u0438\u043c\u0430\u0435\u043c <strong><em>Ok<\/em><\/strong> \u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c SDK \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u043c\u0430\u043d\u0434\u0443 <strong><em>File &#8212; Launch SDK<\/em><\/strong>.<\/p>\n<h2>\u041f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 SDIO \u0447\u0435\u0440\u0435\u0437 microSD-\u043a\u0430\u0440\u0442\u0443 \u0432 Baremetal<\/h2>\n<p>\u041f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u0442\u044c \u043a \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c microSD-\u043a\u0430\u0440\u0442\u0443 \u043a \u043f\u0438\u043d\u0430\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0440\u0430\u0437\u043c\u0435\u0447\u0430\u043b\u0438 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u0440\u0430\u0437\u0434\u0435\u043b\u0435. \u0421\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u043f\u0435\u0440\u0432\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u043d\u0430 \u0440\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0443 microSD-\u043a\u0430\u0440\u0442\u044b:<\/p>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u0421 \u043f\u0438\u043d\u0430\u043c\u0438 VDD (3.3V) \u0438 VSS (GND) \u0432\u0441\u0451 \u0432 \u0446\u0435\u043b\u043e\u043c \u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u0421 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u043f\u0438\u043d\u0430\u043c\u0438 \u0435\u0441\u0442\u044c \u043d\u044e\u0430\u043d\u0441, \u0434\u043b\u044f \u043f\u0438\u043d\u0430 CMD \u0438 \u0448\u0438\u043d\u044b DATA \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0442\u044f\u0436\u043a\u0430 \u043a \u0432\u044b\u0441\u043e\u043a\u043e\u043c\u0443 \u0443\u0440\u043e\u0432\u043d\u044e \u0447\u0435\u0440\u0435\u0437 10 \u043a\u041e\u043c \u0440\u0435\u0437\u0438\u0441\u0442\u043e\u0440\u044b. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0447\u0442\u043e\u0431\u044b \u043d\u0435 \u0433\u043e\u0440\u043e\u0434\u0438\u0442\u044c \u043d\u0430\u0432\u0435\u0441\u043d\u044b\u043c \u043c\u043e\u043d\u0442\u0430\u0436\u043e\u043c \u0440\u0435\u0437\u0438\u0441\u0442\u043e\u0440\u044b, \u044f \u0432\u0437\u044f\u043b \u043e\u0434\u043d\u0443 \u0438\u0437 \u043f\u043b\u0430\u0442, \u0437\u0430\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0445 \u0434\u043b\u044f Wi-Fi \u043c\u043e\u0434\u0443\u043b\u044f \u0438 \u0437\u0430\u043f\u0430\u044f\u043b \u043d\u0430 \u043d\u0435\u0433\u043e \u0432\u0441\u0435 \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u044d\u0442\u043e\u0439 \u043f\u043b\u0430\u0442\u044b &#8212; \u0432\u0441\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0432\u043e\u0442 \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041f\u0438\u0442\u0430\u043d\u0438\u0435 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043e \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0442\u0435\u043c, \u043a\u0430\u043a \u043e\u043d\u043e \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u043e \u043d\u0430 \u0433\u0440\u0435\u0431\u0435\u043d\u043a\u0443. \u0414\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430 \u043e\u0442\u043b\u0430\u0434\u043a\u0438 \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0430\u043d\u0430\u043b\u0438\u0437\u0430\u0442\u043e\u0440\u043e\u043c &#8212; \u044f \u043f\u043e\u0434\u043f\u0430\u0438\u0432\u0430\u043b \u041c\u0413\u0422\u0424-\u043f\u0440\u043e\u0432\u043e\u0434\u043a\u0438.\u00a0<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\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-331340","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/331340","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=331340"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/331340\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=331340"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=331340"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=331340"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}