{"id":347844,"date":"2023-05-24T21:01:01","date_gmt":"2023-05-24T21:01:01","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=347844"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=347844","title":{"rendered":"<span>\u0420\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 SDRAM<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<p>\u0412 <a href=\"https:\/\/habr.com\/ru\/articles\/736812\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435 \u043f\u0440\u043e VGA \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441<\/a> \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b, \u0447\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0432\u043d\u0435\u0448\u043d\u044e\u044e \u043f\u0430\u043c\u044f\u0442\u044c SDRAM &nbsp;\u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0444\u0440\u0435\u043c \u0431\u0443\u0444\u0435\u0440\u0430. \u0425\u043e\u0447\u0443 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0435\u0433\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0435\u0439, \u0445\u043e\u0442\u044f \u0431\u044b \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e, \u043a\u043e\u0433\u0434\u0430 \u044f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u043e\u0439 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0434\u0443\u043b\u044f \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438, \u0432\u0435\u0434\u044c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 IP-\u044f\u0434\u0440\u0430 \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 \u044d\u0442\u0443 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0443. \u0418, \u043a\u0430\u043a \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u0445\u043e\u0447\u0443 \u043a\u043e\u043c\u0443-\u043d\u0438\u0431\u0443\u0434\u044c \u043f\u043e\u043c\u043e\u0447\u044c \u0432 \u044d\u0442\u043e\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u0435.<\/p>\n<p>\u041e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u0430\u044f \u043f\u043b\u0430\u0442\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u0432\u0441\u0435 \u0442\u0430 \u0436\u0435 \u0441 \u041f\u041b\u0418\u0421 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u0430 Spartan6 xc6slx16. \u041d\u0430 \u0431\u043e\u0440\u0442\u0443 \u0442\u0430\u043a\u0436\u0435 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043f\u0430\u043c\u044f\u0442\u044c SDRAM(MT48LC16M16A2) \u043e\u0431\u044a\u0451\u043c\u043e\u043c 32 \u041c\u0431\u0430\u0439\u0442\u0430.<\/p>\n<details class=\"spoiler\">\n<summary>\u0412\u043e\u0442 \u0444\u043e\u0442\u043e\u0433\u0440\u0430\u0444\u0438\u044f \u043e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u043e\u0439 \u043f\u043b\u0430\u0442\u044b:<\/summary>\n<div class=\"spoiler__content\">\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/052\/774\/76c\/05277476c8ef8b0f11419d7e79372816.jpg\" width=\"1000\" height=\"1000\"><\/figure>\n<\/p>\n<\/div>\n<\/details>\n<h3>\u0412\u0432\u043e\u0434\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435<\/h3>\n<p>\u0418 \u0442\u0430\u043a, \u0438\u0437 <a href=\"https:\/\/media-www.micron.com\/-\/media\/client\/global\/documents\/products\/data-sheet\/dram\/256mb_sdr.pdf\" rel=\"noopener noreferrer nofollow\">\u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0430<\/a> \u043d\u0430 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0443 MT48LC16M16A2, \u043e\u043d\u0430 \u0438\u043c\u0435\u0435\u0442 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0438\u0437 4 \u0431\u0430\u043d\u043e\u043a \u043f\u043e 4 \u043c\u043b\u043d \u044f\u0447\u0435\u0435\u043a \u0441 \u0440\u0430\u0437\u0440\u044f\u0434\u043d\u043e\u0441\u0442\u044c\u044e 16 \u0431\u0438\u0442 (4M \u044f\u0447\u0435\u0435\u043a x 16 x 4 \u0431\u0430\u043d\u043a\u0430). \u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u0442\u0443\u0442 \u0432\u0441\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e. <\/p>\n<p>\u0414\u043b\u044f \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u044d\u0442\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442 \u0438 \u0432\u0438\u0434\u0438\u043c \u0442\u0430\u043a\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u043d\u0430\u0441 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0441\u0442\u043e\u043b\u0431\u0438\u043a:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/dae\/c36\/399\/daec36399ed1a9e5267b829249fbb3b7.png\" width=\"887\" height=\"207\"><\/figure>\n<p>\u0418\u0437 \u043d\u0435\u0433\u043e \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c 13 \u0431\u0438\u0442 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u0442\u0440\u043e\u043a\u0430\u043c, 9 \u0431\u0438\u0442 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u0430\u043c \u0438 2 \u0431\u0438\u0442\u0430 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0431\u0430\u043d\u043a\u0430\u043c; \u0432\u0441\u0435\u0433\u043e 24 \u0431\u0438\u0442\u0430 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0432\u0441\u0435\u043c\u0443 \u043e\u0431\u044a\u0451\u043c\u0443 \u043f\u0430\u043c\u044f\u0442\u0438. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u043d\u0435\u0445\u0438\u0442\u0440\u0443\u044e \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u043a\u0443, \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u0431\u044a\u0451\u043c\u044b \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u0431\u0435\u0449\u0430\u044e\u0442 \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0435: 16*2^24 = 268435456 \u0431\u0438\u0442 (33554432 \u0431\u0430\u0439\u0442). <\/p>\n<p>\u0415\u0441\u043b\u0438 \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u0440\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0443 \u044d\u0442\u043e\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u043c, \u0447\u0442\u043e \u043f\u0438\u043d\u043e\u0432 \u043f\u043e\u0434 \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u044e \u0432\u0441\u0435\u0433\u043e 13 \u0431\u0438\u0442 + 2 \u0431\u0438\u0442\u0430 \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u0431\u0430\u043d\u043a\u043e\u0432. \u041d\u0430 \u0440\u0438\u0441\u0443\u043d\u043a\u0435 \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u04100-\u041012 \u044d\u0442\u043e \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430 \u0438 \u0412\u04100-\u0412\u04101 \u044d\u0442\u043e \u0448\u0438\u043d\u0430 \u0432\u044b\u0431\u043e\u0440\u0430 \u0431\u0430\u043d\u043a\u0430, \u043d\u0443 \u0438 \u043a\u0430\u043a \u0431\u044b \u0432\u0441\u0435\u2026 \u0413\u0434\u0435 \u0435\u0449\u0435 9 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430?<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9c5\/1a6\/97b\/9c51a697b9407fda274e55283cf1e238.png\" width=\"530\" height=\"474\"><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043b\u0443\u0447\u0448\u0435 \u0438\u0437\u0443\u0447\u0438\u0442\u044c \u0432\u043e\u043f\u0440\u043e\u0441 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u0440\u0430\u0431\u043e\u0442\u044b SDRAM (\u043b\u0438\u0431\u043e \u043b\u0443\u0447\u0448\u0435 \u0437\u0430\u043f\u043e\u043c\u0438\u043d\u0430\u0442\u044c \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b \u043d\u0430 \u043f\u0430\u0440\u0430\u0445, \u043a\u0430\u043a \u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435[\u044f, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0432\u0441\u0435 \u0437\u0430\u0431\u044b\u043b]), \u0442\u043e \u0432\u044b\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u0432\u0430 \u0440\u0430\u0437\u0430. \u0412 \u043f\u0435\u0440\u0432\u044b\u0439 \u0440\u0430\u0437 \u043e\u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u0442\u0440\u043e\u043a\u0438, \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0432\u0441\u0435 13 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430; \u0430 \u0432\u043e \u0432\u0442\u043e\u0440\u043e\u0439 \u0440\u0430\u0437 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 (\u0442\u043e\u043b\u044c\u043a\u043e 9 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430), \u043f\u043e \u0441\u0443\u0442\u0438, \u044f\u0447\u0435\u0439\u043a\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u044d\u0442\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u0415\u0449\u0435 \u0440\u0430\u0437: \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u044b\u0431\u043e\u0440 \u0441\u0442\u0440\u043e\u043a\u0438 (N \u0442\u0430\u043a\u0442 \u043a\u043b\u043e\u043a\u0430), \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0431\u043e\u0440 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 (N+x \u0442\u0430\u043a\u0442 \u043a\u043b\u043e\u043a\u0430) \u0438 \u0438\u0445 \u043f\u0435\u0440\u0435\u0441\u0435\u0447\u0435\u043d\u0438\u0435 \u0434\u0430\u0441\u0442 \u043d\u0430\u043c \u044f\u0447\u0435\u0439\u043a\u0443 \u043f\u0430\u043c\u044f\u0442\u0438, \u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c \u043e \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u043c \u0431\u0430\u043d\u043a\u0435.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/75f\/6f8\/576\/75f6f857619357d853b44fd8eac15a92.png\" width=\"928\" height=\"698\"><\/figure>\n<p>\u0422\u0430\u043a \u0436\u0435 \u0432 \u0433\u043b\u0430\u0437\u0430 \u0431\u0440\u043e\u0441\u0430\u0435\u0442\u0441\u044f \u0448\u0438\u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 DQ0-DQ15. \u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e, \u043e\u043d\u0430 \u043e\u0434\u043d\u0430 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u2014 \u0438 \u0434\u043b\u044f \u0437\u0430\u043f\u0438\u0441\u0438, \u0438 \u0434\u043b\u044f \u0447\u0442\u0435\u043d\u0438\u044f. \u041c\u043d\u0435, \u043a\u0430\u043a \u0447\u0435\u043b\u043e\u0432\u0435\u043a\u0443 \u0447\u0430\u0441\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b BRAM \u0432 \u041f\u041b\u0418\u0421, \u043f\u043e\u0434\u043e\u0431\u043d\u0430\u044f \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0430 \u043f\u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u043a\u0440\u0430\u0439\u043d\u0435 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e\u0439. \u041d\u043e \u0435\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u044d\u0442\u043e \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043c\u043e\u0436\u043d\u043e \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0430 \u2014 \u044d\u0442\u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u043e \u0440\u0430\u0441\u043f\u0430\u0438\u0432\u0430\u0435\u043c\u043e\u0435 \u043d\u0430 \u043f\u043b\u0430\u0442\u0435, \u0438 \u0435\u0441\u043b\u0438 \u0431\u044b \u0432\u0441\u0435 \u043f\u0438\u043d\u044b \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0440\u0430\u0437\u0432\u043e\u0434\u0438\u0442\u044c, \u0442\u043e \u044d\u0442\u043e \u0431\u044b\u043b \u0431\u044b \u0435\u0449\u0435 \u0442\u043e\u0442 \u0433\u0435\u043c\u043e\u0440\u0440\u043e\u0439, \u0430 \u043e\u043d \u043d\u0438\u043a\u043e\u043c\u0443 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d. \u041a \u0442\u043e\u043c\u0443 \u0436\u0435 \u0442\u0443\u0442 \u043e\u0434\u043d\u0430 \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430, \u0430 \u0441\u043b\u0443\u0447\u0430\u0438, \u043a\u043e\u0433\u0434\u0430 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043d\u0430\u0434\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u0438\u0442\u044c \u0447\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u0430\u0434\u0440\u0435\u0441\u0443 \u044f \u043d\u0435 \u0437\u043d\u0430\u044e.<\/p>\n<h3>\u0410\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0440\u0430\u0431\u043e\u0442\u044b<\/h3>\n<p>SDRAM \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043a\u043e\u043c\u0430\u043d\u0434, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0437\u0430\u0434\u0430\u0435\u0442 \u0440\u0435\u0436\u0438\u043c \u0438 \u0441\u0442\u0430\u0434\u0438\u0438 \u0440\u0430\u0431\u043e\u0442\u044b. \u0412\u043e\u0442 \u0441\u043f\u0438\u0441\u043e\u043a \u043a\u043e\u043c\u0430\u043d\u0434 \u0434\u043b\u044f \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b MT48LC16M16A2:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/f19\/1e2\/043\/f191e204347763d1f9dd70d68a5e1830.png\" alt=\"\u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0441 \u0441\u0430\u0439\u0442\u0430 http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html   \" title=\"\u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0441 \u0441\u0430\u0439\u0442\u0430 http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html   \" width=\"908\" height=\"312\"><\/p>\n<div><figcaption>\u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0441 \u0441\u0430\u0439\u0442\u0430 <a href=\"https:\/\/%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B0%20%D1%81%20%D1%81%D0%B0%D0%B9%D1%82%D0%B0%20http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html\" rel=\"noopener noreferrer nofollow\">http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html<\/a>   <\/figcaption><\/div>\n<\/figure>\n<p>\u0423 \u0441\u0430\u043c\u043e\u0439 \u0436\u0435 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b \u043f\u043e\u043b\u043d\u043e \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u0440\u0435\u0436\u0438\u043c\u043e\u0432 \u0440\u0430\u0431\u043e\u0442\u044b, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<ul>\n<li>\n<p>\u0420\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0434\u043b\u0438\u043d\u044b \u043f\u0430\u043a\u0435\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0437\u0430 \u0440\u0430\u0437 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c.<\/p>\n<\/li>\n<li>\n<p>\u0410\u0432\u0442\u043e \u043f\u0435\u0440\u0435\u0437\u0430\u0440\u044f\u0434\u043a\u0430 \u044f\u0447\u0435\u0435\u043a \u043f\u0430\u043c\u044f\u0442\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0443\u0447\u0430\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u0431\u0430\u043d\u043a\u043e\u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0437\u0430\u0440\u044f\u0434\u0430.<\/p>\n<\/li>\n<li>\n<p>\u0422\u0430\u043a \u0436\u0435 \u0438\u043c\u0435\u044e\u0442\u0441\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0430 \u043e\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u043a \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044e.<\/p>\n<\/li>\n<\/ul>\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u0443\u043f\u0440\u043e\u0441\u0442\u0438\u0442\u044c \u0441\u0435\u0431\u0435 \u0436\u0438\u0437\u043d\u044c, \u044f \u043f\u0435\u0440\u0435\u0448\u0435\u043b \u0432 \u0440\u0435\u0436\u0438\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a \u043e\u0434\u043d\u043e\u0439 \u044f\u0447\u0435\u0439\u043a\u0435 \u0437\u0430 \u043e\u0434\u043d\u043e \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435. \u0422\u0430\u043a \u0436\u0435 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0441\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e\u043c, \u0447\u0442\u043e \u043f\u043e\u0441\u043b\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0447\u0442\u0435\u043d\u0438\u044f\/\u0437\u0430\u043f\u0438\u0441\u0438 \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u0447\u0442\u0435\u043d\u0438\u044f\/\u0437\u0430\u043f\u0438\u0441\u0438, \u0435\u0441\u043b\u0438 \u043d\u043e\u0432\u044b\u0439 \u0430\u0434\u0440\u0435\u0441 \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u044f \u043c\u043e\u0433 \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e 512 \u0441\u043b\u043e\u0432 \u0431\u0435\u0437 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438, \u0437\u0430\u0442\u0435\u043c \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0441\u0441 &nbsp;\u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u044f\u0447\u0435\u0435\u043a \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0430\u0432\u0442\u043e\u043c\u0430\u0442 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442 \u0432 \u0440\u0435\u0436\u0438\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u043a\u043e\u043c\u0430\u043d\u0434\u044b. \u0412 \u0438\u0442\u043e\u0433\u0435 \u0443 \u043c\u0435\u043d\u044f \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0432\u043e\u0442 \u0442\u0430\u043a\u043e\u0439 \u043c\u043e\u0434\u0443\u043b\u044c:<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/45e\/dba\/ec2\/45edbaec288679a9e5698c024528ce40.png\" width=\"360\" height=\"509\"><\/figure>\n<p>\u0418\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 m_* \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432\u0445\u043e\u0434\u043d\u044b\u043c \u0434\u043b\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043a\u043e\u043c\u0430\u043d\u0434 \u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0435\u0441\u043b\u0438 \u043a\u043e\u043c\u0430\u043d\u0434\u0430 \u043d\u0430 \u0437\u0430\u043f\u0438\u0441\u044c. \u041f\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 s_* \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432\u044b\u0432\u043e\u0434 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 \u0447\u0442\u0435\u043d\u0438\u044f \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438. \u0414\u0430\u043d\u043d\u044b\u0435 \u0447\u0438\u0442\u0430\u044e\u0442\u0441\u044f \u0441 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u0432 3 \u0442\u0430\u043a\u0442\u0430. <\/p>\n<p>\u041b\u043e\u0433\u0438\u043a\u0430 \u043c\u043e\u0434\u0443\u043b\u044f \u043f\u0440\u043e\u0441\u0442\u0430, \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u0437\u0430\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u0430\u0434\u0440\u0435\u0441 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0432\u043e \u043c\u043b\u0430\u0434\u0448\u0438\u0445 9 \u0440\u0430\u0437\u0440\u044f\u0434\u0430\u0445. \u0422\u0430\u043a \u0436\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u044e\u0442 \u0437\u0430\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f, \u0435\u0441\u043b\u0438 \u043f\u043e\u043c\u0435\u043d\u044f\u043b\u0441\u044f \u0442\u0438\u043f \u043a\u043e\u043c\u0430\u043d\u0434\u044b(\u0447\u0442\u0435\u043d\u0438\u0435&lt;=&gt;\u0437\u0430\u043f\u0438\u0441\u044c). \u041c\u043e\u0434\u0443\u043b\u044c \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u0435\u043d \u043a \u0441\u0438\u0433\u043d\u0430\u043b\u0443 m_valid, \u0435\u0441\u043b\u0438 \u043e\u043d \u0443\u043f\u0430\u043b, \u0442\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442 \u043a \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044e \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442 \u0437\u0430\u0440\u044f\u0434 \u0432 \u044f\u0447\u0435\u0439\u043a\u0430\u0445.<\/p>\n<p>\u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043e, \u0447\u0442\u043e \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u043e\u0442\u0430 \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b 133 \u041c\u0413\u0446, \u043d\u0430 \u043c\u043e\u0435\u0439 \u043e\u0442\u043b\u0430\u0434\u043a\u0435 \u043c\u043e\u0434\u0443\u043b\u044c \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 150 \u041c\u0413\u0446. \u041d\u043e \u044f \u043d\u0435 \u0441\u0442\u0430\u043b \u0438\u0441\u043f\u044b\u0442\u044b\u0432\u0430\u0442\u044c \u0441\u0443\u0434\u044c\u0431\u0443 \u0438 \u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0447\u0430\u0441\u0442\u043e\u0442\u0443 \u0432 100 \u041c\u0413\u0446 (\u043c\u043d\u0435 \u0442\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f).<\/p>\n<details class=\"spoiler\">\n<summary>\u0412\u043e\u0442 \u043a\u043e\u0434 \u043c\u043e\u0434\u0443\u043b\u044f: <\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"vhdl\">`timescale 1ns \/ 1ps  module ctrl_sdram_v2 #( parameter [2:0] CL = 'd3 ) (     input clk,  input rst,  \/\/user interface)  input [15:0] m_data, \/\/ valid if m_we==1  input [23:0] m_addr, \/\/2bit BANK, 13bit ROW, 9bit COLUMM  input m_we  , \/\/ 0 - read, 1 - write)  input m_valid,  output      m_ready,  output reg[15:0] s_data,  output reg    s_valid,  input      s_ready,\/\/ invalid ready. only s_valid     \/\/SDRAM interface  output reg sd_cke,  output sd_clk,  output sd_dqml,  output sd_dqmh,  output reg  sd_cas_n,  output reg sd_ras_n,  output reg sd_we_n,  output reg sd_cs_n,  output reg [14:0] sd_addr,  inout  [15:0] sd_data     );   reg [3:0] state_main = 'd0; reg [15:0] state_tri ; reg [15:0] sd_data_o ; wire [15:0] sd_data_i ;  reg [23:0] m_addr_set = 'd0; reg flg_first_cmd = 'd1; wire new_row_addr; reg [15:0] cnt_wait = 'd0; reg [15:0] cnt_wait_buf = 'd0; reg [10:0] cnt_refresh_sdram = 'd0; always@(posedge clk) begin if(rst) begin state_main &lt;= 'd0; m_addr_set &lt;= 'd0; flg_first_cmd &lt;= 'd1; end else begin case(state_main) 0: begin \/\/wait 100 us if(cnt_wait &gt;= 8000) state_main&lt;= 'd1; else cnt_wait &lt;= cnt_wait + 1; end 1: begin \/\/set NOP if(cnt_wait &gt;= 10000) begin  state_main&lt;= 'd2; cnt_wait &lt;= 'd0; end else cnt_wait &lt;= cnt_wait + 1; end 2: begin \/\/cmd PRECHARGE ALL if(cnt_wait &gt;= 'd1) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd3; end else cnt_wait &lt;= cnt_wait + 1'b1; end 3: begin \/\/ AUTO REFRESH 0 if(cnt_wait[14:0] &gt;= 'd6) begin  cnt_wait[14:0] &lt;= 'd0; if(cnt_wait[15]) begin state_main &lt;= 'd4; cnt_wait[15] &lt;= 'd0; end else cnt_wait[15] &lt;= 'd1; end else cnt_wait &lt;= cnt_wait + 1'b1; end 4: begin \/\/cmd LOAD MODE if(cnt_wait &gt;= 'd1) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end 5: begin \/\/IDLE state if(m_valid) begin state_main &lt;= 'd6; cnt_refresh_sdram &lt;= 'd0; end else begin if(&amp;cnt_refresh_sdram) begin state_main &lt;= 'd8; cnt_refresh_sdram &lt;= 'd0; end else cnt_refresh_sdram &lt;= cnt_refresh_sdram + 1; end end 6: begin \/\/ cmd ACTIVATE row if(cnt_wait &gt;= CL) begin  cnt_wait &lt;= 'd0; if(m_we) begin \/\/cmd WRITE state_main &lt;= 'd7; end else begin \/\/cmd READ state_main &lt;= 'd9; end m_addr_set &lt;= m_addr; flg_first_cmd &lt;= 'd1; end else cnt_wait &lt;= cnt_wait + 1'b1; end 7: begin \/\/WRITE m_addr_set &lt;= m_addr; if(flg_first_cmd) begin flg_first_cmd &lt;= 'd0; end else begin if(new_row_addr=='d1 || m_valid == 'd0 || m_ready == 'd0) begin\/\/goto precharge state_main &lt;= 'd8; end end end 8: begin \/\/cmd PRECHARGE after write if(cnt_wait &gt;= 'd3) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end 9: begin \/\/READ and reading data from SDRAM m_addr_set &lt;= m_addr; if(flg_first_cmd) begin flg_first_cmd &lt;= 'd0; end else begin if(new_row_addr=='d1 || m_valid == 'd0 || m_ready == 'd0) begin\/\/ state_main &lt;= 'd10; cnt_wait_buf &lt;= cnt_wait; end end cnt_wait &lt;= cnt_wait + 1'b1; end 10: begin \/\/reading data from SDRAM if(cnt_wait == cnt_wait_buf+CL) begin state_main &lt;= 'd11; cnt_wait &lt;= 'd0; end else cnt_wait &lt;= cnt_wait + 1; end 11: begin \/\/ cmd AUTO REFRESH after read if(cnt_wait &gt;= 'd3) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end endcase end end   assign new_row_addr = (m_addr_set[23:9] != m_addr[23:9]) ?  'd1 : 'd0;  assign m_ready = (state_main == 'd7 &amp;&amp; m_we == 'd1 &amp;&amp; new_row_addr == 'd0) ? 'd1 :    (state_main == 'd9 &amp;&amp; m_we == 'd0 &amp;&amp; new_row_addr == 'd0) ? 'd1 :   'd0;     always@(posedge clk) begin s_data &lt;= sd_data_i; s_valid &lt;= ((state_main == 'd9 || state_main == 'd10) &amp;&amp; cnt_wait &gt; CL) ? 'd1 : 'd0; end  assign sd_dqml=0; assign sd_dqmh=0;  always@(posedge clk) begin   state_tri &lt;= (state_main == 'd7) ? 16'd0 : 16'hFFFF;   sd_data_o &lt;= (state_main == 'd7) ? m_data : 'd0;   sd_cke&lt;= (state_main == 'd0) ? 'd0 : 'd1;   sd_cas_n&lt;=(state_main == 'd1) ? 'd1 : \/\/ INIT NOP (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd1 : \/\/PRECHARGE (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd0 : \/\/autorefresh (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd1 :\/\/nop (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : \/\/load mode (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd1 : \/\/nop (state_main == 'd5)  ? 'd1 : \/\/nop (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd1 : \/\/activate (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd1 : \/\/nop (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : \/\/WRITE (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1  : \/\/nop (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd1 : \/\/precharge after write (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd1 : \/\/nop (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : \/\/READ ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1 : \/\/ nop (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd1: \/\/'d0 : \/\/auto REFRESH(1) \/\/precharge after read (state_main == 'd11 &amp;&amp; cnt_wait!=0) ? 'd1 : \/\/ nop 'd1;  sd_ras_n&lt;=(state_main == 'd1) ? 'd1 :  (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd0 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd1 : (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd5)  ? 'd1 : (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd1  : (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1  : (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd1 : (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd1  : ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1 : (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd0: \/\/'d0 : (state_main == 'd11 &amp;&amp; cnt_wait!=0) ? 'd1 : 'd1;  sd_we_n&lt;=  (state_main == 'd1) ? 'd1 :  (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd1 : (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd5)  ? 'd1 : (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd1 : (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1  : (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd1 : (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd1  : ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1 : (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd0 :\/\/'d1 : (state_main == 'd11 &amp;&amp; cnt_wait!=0) ? 'd1 : 'd1;  sd_cs_n&lt;=(rst == 'd1) ?  'd1 :  (state_main == 'd1) ? 'd0 :  (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd0 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd0 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd0 : (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd0 : (state_main == 'd5)  ? 'd0 : (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd0 : (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd0  : (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd0 : (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd0 : (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd0: \/\/'d0 : (state_main == 'd11 &amp;&amp; cnt_wait!=0) ? 'd0 : 'd0;   sd_addr[14:13] &lt;= m_addr[23:22];  sd_addr[12:0]&lt;=  (state_main == 'd2 &amp;&amp; cnt_wait==0) ? {4'b0,1'b1,10'b0} :  \/\/[10] = 1 (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? {2'b00,3'b000,1'b1,2'b00,CL[2:0],1'b0,3'b000} :  \/\/BA[1:0]==0,A[12:10]==0,WRITE_BURST_MODE = 0,OP_MODE = 'd0, CL = 2, TYPE_BURST = 0, BURST_LENGTH = 1 (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? m_addr[21:9] : (state_main == 'd7) ? {5'd0,m_addr[8:0]} :  (state_main == 'd8 &amp;&amp; cnt_wait==0) ? {4'b0,1'b1,10'b0} :  \/\/[10] = 1 (state_main == 'd9) ? {7'd0,m_addr[8:0]} : (state_main == 'd11 &amp;&amp; cnt_wait==0) ? {4'b0,1'b1,10'b0} :  \/\/[10] = 1 'd0;  end    ODDR2 #( .DDR_ALIGNMENT(\"NONE\"), \/\/ Sets output alignment to \"NONE\", \"C0\" or \"C1\"  .INIT(1'b0),    \/\/ Sets initial state of the Q output to 1'b0 or 1'b1 .SRTYPE(\"SYNC\") \/\/ Specifies \"SYNC\" or \"ASYNC\" set\/reset ) ODDR2_inst ( .Q(sd_clk),   \/\/ 1-bit DDR output data .C0(clk),   \/\/ 1-bit clock input .C1(!clk),   \/\/ 1-bit clock input .CE(!rst), \/\/ 1-bit clock enable input .D0(1), \/\/ 1-bit data input (associated with C0) .D1(0), \/\/ 1-bit data input (associated with C1) .R(0),   \/\/ 1-bit reset input .S(0)    \/\/ 1-bit set input );   genvar i; generate for (i=0; i &lt; 16; i=i+1)  begin: tri_state OBUFT #( .DRIVE(12),   \/\/ Specify the output drive strength .IOSTANDARD(\"DEFAULT\"), \/\/ Specify the output I\/O standard .SLEW(\"SLOW\") \/\/ Specify the output slew rate ) OBUFT_inst ( .O(sd_data[i]),     \/\/ Buffer output (connect directly to top-level port) .I(sd_data_o[i]),     \/\/ Buffer input .T(state_tri[i])      \/\/ 3-state enable input  );   IBUF #( .IOSTANDARD(\"DEFAULT\")    \/\/ Specify the input I\/O standard )IBUF_inst ( .O(sd_data_i[i]),     \/\/ Buffer output .I(sd_data[i])      \/\/ Buffer input (connect directly to top-level port) ); end endgenerate  endmodule <\/code><\/pre>\n<\/p>\n<\/div>\n<\/details>\n<h3>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h3>\n<p>\u0421\u0442\u0430\u0442\u044c\u044f \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430\u0441\u044c \u0432\u0441\u0435\u043e\u0431\u044a\u0435\u043c\u043b\u044e\u0449\u0435\u0439 \u0438 \u0432\u0441\u0435\u043e\u0431\u044a\u044f\u0441\u043d\u044f\u044e\u0449\u0435\u0439, \u043d\u043e \u043d\u0430 <a href=\"http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html\" rel=\"noopener noreferrer nofollow\">\u044d\u0442\u043e\u043c \u0441\u0430\u0439\u0442\u0435<\/a> \u0435\u0441\u0442\u044c \u0440\u0443\u0441\u0441\u043a\u0438\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0430 \u0438 \u0441 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u043c\u0438 \u043e\u0442 \u0430\u0432\u0442\u043e\u0440\u0430. \u042f \u043e\u043f\u0438\u0440\u0430\u043b\u0441\u044f \u043d\u0430 \u043d\u0435\u0435, \u043a\u043e\u0433\u0434\u0430 \u043e\u0441\u0432\u0430\u0438\u0432\u0430\u043b \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b.<\/p>\n<details class=\"spoiler\">\n<summary>P.S.  \u043a\u0430\u043a \u044f \u0441\u043e\u0441\u0442\u044b\u043a\u043e\u0432\u0430\u043b \u0440\u0430\u0431\u043e\u0442\u0443 VGA \u043c\u043e\u0434\u0443\u043b\u044f \u0438 SDRAM \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430.<\/summary>\n<div class=\"spoiler__content\">\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e6a\/322\/e39\/e6a322e395806306a19da2b78464c897.png\" alt=\"\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u0441\u0445\u0435\u043c\u0430 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f VGA \u043c\u043e\u0434\u0443\u043b\u044f \u0441 \u043f\u0430\u043c\u044f\u0442\u044c\u044e.\" title=\"\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u0441\u0445\u0435\u043c\u0430 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f VGA \u043c\u043e\u0434\u0443\u043b\u044f \u0441 \u043f\u0430\u043c\u044f\u0442\u044c\u044e.\" width=\"837\" height=\"327\"><\/p>\n<div><figcaption>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u0441\u0445\u0435\u043c\u0430 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f VGA \u043c\u043e\u0434\u0443\u043b\u044f \u0441 \u043f\u0430\u043c\u044f\u0442\u044c\u044e.<\/figcaption><\/div>\n<\/figure>\n<p>\u0412 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0438\u043c\u0435\u043b\u043e\u0441\u044c \u0434\u0432\u0430 \u043a\u043b\u043e\u043a\u043e\u0432\u044b\u0445 \u0434\u043e\u043c\u0435\u043d\u0430, \u043d\u0430 100 \u041c\u0413\u0446 \u0438 \u043d\u0430 25 \u041c\u0413\u0446. \u0417\u0430 \u0441\u0447\u0435\u0442 \u0442\u043e\u0433\u043e \u0447\u0442\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043f\u0430\u043c\u044f\u0442\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 100 \u041c\u0413\u0446, \u043e\u043d \u0442\u0435\u043e\u0440\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043c\u043e\u0433 \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432 \u0441\u0435\u0431\u044f 3 \u043d\u043e\u0432\u044b\u0445 \u043a\u0430\u0434\u0440\u0430 \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c 1 \u043a\u0430\u0434\u0440 \u043e\u0442\u0440\u0438\u0441\u0443\u0435\u0442\u0441\u044f \u043d\u0430 \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0435. <\/p>\n<p>\u0410\u0432\u0442\u043e\u043c\u0430\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 \u0434\u0432\u0443\u0445 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u0445, \u043b\u0438\u0431\u043e \u043e\u043d \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u0442 \u043d\u043e\u0432\u044b\u0439 \u043a\u0430\u0434\u0440 \u043b\u0438\u0431\u043e \u043e\u043d \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0438\u043c\u0435\u044e\u0449\u0438\u0439\u0441\u044f \u043a\u0430\u0434\u0440 \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0439 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438. \u0420\u0435\u0436\u0438\u043c \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u044d\u0442\u043e \u0440\u0435\u0436\u0438\u043c \u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u043e\u0432\u043e\u0433\u043e \u043a\u0430\u0434\u0440\u0430 \u0432 \u043f\u0430\u043c\u044f\u0442\u044c, \u043a\u043e\u0433\u0434\u0430 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442 \u0441\u0438\u0433\u043d\u0430\u043b \u043e\u0442 \u0424\u0418\u0424\u041e \u043e \u0442\u043e\u043c \u0447\u0442\u043e \u043e\u043d\u043e \u043f\u043e\u0447\u0442\u0438 \u043f\u0443\u0441\u0442\u043e\u0435, \u0430\u0432\u0442\u043e\u043c\u0430\u0442 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0439 \u043e\u0431\u044a\u0435\u043c. \u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0441\u0438\u0433\u043d\u0430\u043b almost_empty \u043f\u043e\u0434\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u0433\u0434\u0430 \u0432 \u0424\u0418\u0424\u041e \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c 100 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439, \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u0430\u0432\u0442\u043e\u043c\u0430\u0442 \u0443\u0441\u043f\u0435\u043b \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u0442\u044c\u0441\u044f \u043d\u0430 \u0440\u0435\u0436\u0438\u043c \u0447\u0442\u0435\u043d\u0438\u044f \u0438 \u043c\u043e\u0434\u0443\u043b\u044c Ctrl_SDRAM \u0443\u0441\u043f\u0435\u043b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u0442\u044c \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0443\u044e \u043a\u043e\u043c\u0430\u043d\u0434\u0443. \u0410\u0432\u0442\u043e\u043c\u0430\u0442 \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 900 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u0438 \u0441\u043d\u043e\u0432\u0430 \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0440\u0435\u0436\u0438\u043c \u0437\u0430\u043f\u0438\u0441\u0438.<\/p>\n<p>\u0424\u0418\u0424\u041e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0434\u0432\u0443\u0445\u043a\u043b\u043e\u043a\u043e\u0432\u044b\u043c, \u0433\u043b\u0443\u0431\u0438\u043d\u043e\u0439 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 1000 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439. \u041d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 100 \u041c\u0413\u0446 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0437\u0430\u043f\u0438\u0441\u044c \u0432 \u043d\u0435\u0433\u043e, \u0430 \u043c\u043e\u0434\u0443\u043b\u044c VGA  \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442 \u043d\u0430 \u0441\u0432\u043e\u0435\u0439 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 \u0432 25 \u041c\u0413\u0446. \u0415\u0441\u043b\u0438 \u043f\u0440\u0438\u043a\u0438\u043d\u0443\u0442\u044c \u0432\u0440\u0435\u043c\u044f \u0447\u0435\u0440\u0435\u0437 \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0432\u043d\u043e\u0432\u044c \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0430 \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0442\u043e \u043e\u043d\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0430\u044f: 100 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 + 900 \u043d\u043e\u0432\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0432\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438 &#8212; \u0447\u0435\u0442\u0432\u0435\u0440\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0441\u043f\u0435\u044e\u0442 \u0432\u044b\u0447\u0438\u0442\u0430\u0442\u044c\u0441\u044f \u0437\u0430 \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0438\u043e\u0434, \u0432 \u043a\u043e\u043d\u0435\u0447\u043d\u043e\u043c \u0441\u0447\u0435\u0442\u0435 \u0438\u043c\u0435\u0435\u043c 750 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0432 \u0424\u0418\u0424\u041e. \u0412 \u0438\u0442\u043e\u0433\u0435 \u043c\u043e\u0434\u0443\u043b\u044c VG\u0410 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f 650 \u0442\u0430\u043a\u0442\u043e\u0432, \u0434\u043e \u0442\u043e\u0433\u043e \u043a\u0430\u043a \u043f\u043e\u0434\u043d\u0438\u043c\u0435\u0442\u0441\u044f \u0444\u043b\u0430\u0433 almost_empty, \u043f\u0435\u0440\u0435\u0432\u0435\u0434\u044f \u044d\u0442\u043e \u043d\u0430 100\u041c\u0413\u0446 \u043f\u043e\u043b\u0443\u0447\u0438\u043c 2600 \u0442\u0430\u043a\u0442\u043e\u0432 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 \u043f\u0430\u043c\u044f\u0442\u044c, \u044d\u0442\u043e\u0433\u043e \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e. \u0415\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0442\u0443\u0442 \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c \u0447\u0442\u043e VGA \u043c\u043e\u0434\u0443\u043b\u044c \u043d\u0435 \u0447\u0438\u0442\u0430\u0435\u0442 \u0438\u0437 \u0424\u0418\u0424\u041e \u0432 \u0442\u0435\u0445 \u043e\u0431\u043b\u0430\u0441\u0442\u044f\u0445 \u0433\u0434\u0435 \u043d\u0435 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430: \u043f\u043e\u0440\u044f\u0434\u043a\u0430 160 \u0442\u0430\u043a\u0442\u043e\u0432 \u0432 \u043a\u043e\u043d\u0446\u0435 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u0438 7200 \u0442\u0430\u043a\u0442\u043e\u0432 \u0432 \u043a\u043e\u043d\u0446\u0435 \u0444\u0440\u0435\u0439\u043c\u0430 \u043d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 25 \u041c\u0413\u0446, \u0430 \u044d\u0442\u043e \u0432 \u043e\u0431\u0449\u0435\u0439 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 336000 \u0442\u0430\u043a\u0442\u043e\u0432 \u043f\u0440\u043e\u0441\u0442\u043e\u044f \u043d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 100\u041c\u0413\u0446.<\/p>\n<\/div>\n<\/details>\n<\/div>\n<\/div>\n<p> <!----> <!----><\/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\/articles\/737384\/\"> https:\/\/habr.com\/ru\/articles\/737384\/<\/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 article-formatted-body_version-2\">\n<p>\u0412 <a href=\"https:\/\/habr.com\/ru\/articles\/736812\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435 \u043f\u0440\u043e VGA \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441<\/a> \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b, \u0447\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0432\u043d\u0435\u0448\u043d\u044e\u044e \u043f\u0430\u043c\u044f\u0442\u044c SDRAM &nbsp;\u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0444\u0440\u0435\u043c \u0431\u0443\u0444\u0435\u0440\u0430. \u0425\u043e\u0447\u0443 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0435\u0433\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0435\u0439, \u0445\u043e\u0442\u044f \u0431\u044b \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e, \u043a\u043e\u0433\u0434\u0430 \u044f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u043e\u0439 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0434\u0443\u043b\u044f \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438, \u0432\u0435\u0434\u044c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 IP-\u044f\u0434\u0440\u0430 \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 \u044d\u0442\u0443 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0443. \u0418, \u043a\u0430\u043a \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u0445\u043e\u0447\u0443 \u043a\u043e\u043c\u0443-\u043d\u0438\u0431\u0443\u0434\u044c \u043f\u043e\u043c\u043e\u0447\u044c \u0432 \u044d\u0442\u043e\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u0435.<\/p>\n<p>\u041e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u0430\u044f \u043f\u043b\u0430\u0442\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u0432\u0441\u0435 \u0442\u0430 \u0436\u0435 \u0441 \u041f\u041b\u0418\u0421 \u0441\u0435\u043c\u0435\u0439\u0441\u0442\u0432\u0430 Spartan6 xc6slx16. \u041d\u0430 \u0431\u043e\u0440\u0442\u0443 \u0442\u0430\u043a\u0436\u0435 \u0438\u043c\u0435\u0435\u0442\u0441\u044f \u043f\u0430\u043c\u044f\u0442\u044c SDRAM(MT48LC16M16A2) \u043e\u0431\u044a\u0451\u043c\u043e\u043c 32 \u041c\u0431\u0430\u0439\u0442\u0430.<\/p>\n<details class=\"spoiler\">\n<summary>\u0412\u043e\u0442 \u0444\u043e\u0442\u043e\u0433\u0440\u0430\u0444\u0438\u044f \u043e\u0442\u043b\u0430\u0434\u043e\u0447\u043d\u043e\u0439 \u043f\u043b\u0430\u0442\u044b:<\/summary>\n<div class=\"spoiler__content\">\n<figure class=\"full-width\"><\/figure>\n<\/p>\n<\/div>\n<\/details>\n<h3>\u0412\u0432\u043e\u0434\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435<\/h3>\n<p>\u0418 \u0442\u0430\u043a, \u0438\u0437 <a href=\"https:\/\/media-www.micron.com\/-\/media\/client\/global\/documents\/products\/data-sheet\/dram\/256mb_sdr.pdf\" rel=\"noopener noreferrer nofollow\">\u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0430<\/a> \u043d\u0430 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0443 MT48LC16M16A2, \u043e\u043d\u0430 \u0438\u043c\u0435\u0435\u0442 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0438\u0437 4 \u0431\u0430\u043d\u043e\u043a \u043f\u043e 4 \u043c\u043b\u043d \u044f\u0447\u0435\u0435\u043a \u0441 \u0440\u0430\u0437\u0440\u044f\u0434\u043d\u043e\u0441\u0442\u044c\u044e 16 \u0431\u0438\u0442 (4M \u044f\u0447\u0435\u0435\u043a x 16 x 4 \u0431\u0430\u043d\u043a\u0430). \u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u0442\u0443\u0442 \u0432\u0441\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e. <\/p>\n<p>\u0414\u043b\u044f \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u044d\u0442\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442 \u0438 \u0432\u0438\u0434\u0438\u043c \u0442\u0430\u043a\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443, \u043d\u0430\u0441 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0443\u0435\u0442 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0441\u0442\u043e\u043b\u0431\u0438\u043a:<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0418\u0437 \u043d\u0435\u0433\u043e \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c 13 \u0431\u0438\u0442 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u0442\u0440\u043e\u043a\u0430\u043c, 9 \u0431\u0438\u0442 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u0430\u043c \u0438 2 \u0431\u0438\u0442\u0430 \u2014 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0431\u0430\u043d\u043a\u0430\u043c; \u0432\u0441\u0435\u0433\u043e 24 \u0431\u0438\u0442\u0430 \u0434\u043b\u044f \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u043f\u043e \u0432\u0441\u0435\u043c\u0443 \u043e\u0431\u044a\u0451\u043c\u0443 \u043f\u0430\u043c\u044f\u0442\u0438. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u043d\u0435\u0445\u0438\u0442\u0440\u0443\u044e \u043c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u043a\u0443, \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u0431\u044a\u0451\u043c\u044b \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u0431\u0435\u0449\u0430\u044e\u0442 \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0435: 16*2^24 = 268435456 \u0431\u0438\u0442 (33554432 \u0431\u0430\u0439\u0442). <\/p>\n<p>\u0415\u0441\u043b\u0438 \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u0440\u0430\u0441\u043f\u0438\u043d\u043e\u0432\u043a\u0443 \u044d\u0442\u043e\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u043c, \u0447\u0442\u043e \u043f\u0438\u043d\u043e\u0432 \u043f\u043e\u0434 \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u044e \u0432\u0441\u0435\u0433\u043e 13 \u0431\u0438\u0442 + 2 \u0431\u0438\u0442\u0430 \u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u0438 \u0431\u0430\u043d\u043a\u043e\u0432. \u041d\u0430 \u0440\u0438\u0441\u0443\u043d\u043a\u0435 \u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0441\u0438\u0433\u043d\u0430\u043b\u044b \u04100-\u041012 \u044d\u0442\u043e \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430 \u0438 \u0412\u04100-\u0412\u04101 \u044d\u0442\u043e \u0448\u0438\u043d\u0430 \u0432\u044b\u0431\u043e\u0440\u0430 \u0431\u0430\u043d\u043a\u0430, \u043d\u0443 \u0438 \u043a\u0430\u043a \u0431\u044b \u0432\u0441\u0435\u2026 \u0413\u0434\u0435 \u0435\u0449\u0435 9 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430?<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043b\u0443\u0447\u0448\u0435 \u0438\u0437\u0443\u0447\u0438\u0442\u044c \u0432\u043e\u043f\u0440\u043e\u0441 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u0440\u0430\u0431\u043e\u0442\u044b SDRAM (\u043b\u0438\u0431\u043e \u043b\u0443\u0447\u0448\u0435 \u0437\u0430\u043f\u043e\u043c\u0438\u043d\u0430\u0442\u044c \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b \u043d\u0430 \u043f\u0430\u0440\u0430\u0445, \u043a\u0430\u043a \u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435[\u044f, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f, \u0432\u0441\u0435 \u0437\u0430\u0431\u044b\u043b]), \u0442\u043e \u0432\u044b\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u0432\u0430 \u0440\u0430\u0437\u0430. \u0412 \u043f\u0435\u0440\u0432\u044b\u0439 \u0440\u0430\u0437 \u043e\u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u0442\u0440\u043e\u043a\u0438, \u0432 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0432\u0441\u0435 13 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430; \u0430 \u0432\u043e \u0432\u0442\u043e\u0440\u043e\u0439 \u0440\u0430\u0437 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 (\u0442\u043e\u043b\u044c\u043a\u043e 9 \u0431\u0438\u0442 \u0430\u0434\u0440\u0435\u0441\u0430), \u043f\u043e \u0441\u0443\u0442\u0438, \u044f\u0447\u0435\u0439\u043a\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u044d\u0442\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u0415\u0449\u0435 \u0440\u0430\u0437: \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0432\u044b\u0431\u043e\u0440 \u0441\u0442\u0440\u043e\u043a\u0438 (N \u0442\u0430\u043a\u0442 \u043a\u043b\u043e\u043a\u0430), \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0431\u043e\u0440 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 (N+x \u0442\u0430\u043a\u0442 \u043a\u043b\u043e\u043a\u0430) \u0438 \u0438\u0445 \u043f\u0435\u0440\u0435\u0441\u0435\u0447\u0435\u043d\u0438\u0435 \u0434\u0430\u0441\u0442 \u043d\u0430\u043c \u044f\u0447\u0435\u0439\u043a\u0443 \u043f\u0430\u043c\u044f\u0442\u0438, \u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c \u043e \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u043c \u0431\u0430\u043d\u043a\u0435.<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0422\u0430\u043a \u0436\u0435 \u0432 \u0433\u043b\u0430\u0437\u0430 \u0431\u0440\u043e\u0441\u0430\u0435\u0442\u0441\u044f \u0448\u0438\u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 DQ0-DQ15. \u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e, \u043e\u043d\u0430 \u043e\u0434\u043d\u0430 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u2014 \u0438 \u0434\u043b\u044f \u0437\u0430\u043f\u0438\u0441\u0438, \u0438 \u0434\u043b\u044f \u0447\u0442\u0435\u043d\u0438\u044f. \u041c\u043d\u0435, \u043a\u0430\u043a \u0447\u0435\u043b\u043e\u0432\u0435\u043a\u0443 \u0447\u0430\u0441\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0435\u0433\u043e \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u044b BRAM \u0432 \u041f\u041b\u0418\u0421, \u043f\u043e\u0434\u043e\u0431\u043d\u0430\u044f \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0430 \u043f\u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u043a\u0440\u0430\u0439\u043d\u0435 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e\u0439. \u041d\u043e \u0435\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 \u044d\u0442\u043e \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043c\u043e\u0436\u043d\u043e \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u0430 \u2014 \u044d\u0442\u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u043e \u0440\u0430\u0441\u043f\u0430\u0438\u0432\u0430\u0435\u043c\u043e\u0435 \u043d\u0430 \u043f\u043b\u0430\u0442\u0435, \u0438 \u0435\u0441\u043b\u0438 \u0431\u044b \u0432\u0441\u0435 \u043f\u0438\u043d\u044b \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0440\u0430\u0437\u0432\u043e\u0434\u0438\u0442\u044c, \u0442\u043e \u044d\u0442\u043e \u0431\u044b\u043b \u0431\u044b \u0435\u0449\u0435 \u0442\u043e\u0442 \u0433\u0435\u043c\u043e\u0440\u0440\u043e\u0439, \u0430 \u043e\u043d \u043d\u0438\u043a\u043e\u043c\u0443 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d. \u041a \u0442\u043e\u043c\u0443 \u0436\u0435 \u0442\u0443\u0442 \u043e\u0434\u043d\u0430 \u0448\u0438\u043d\u0430 \u0430\u0434\u0440\u0435\u0441\u0430, \u0430 \u0441\u043b\u0443\u0447\u0430\u0438, \u043a\u043e\u0433\u0434\u0430 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043d\u0430\u0434\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u0438\u0442\u044c \u0447\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u0430\u0434\u0440\u0435\u0441\u0443 \u044f \u043d\u0435 \u0437\u043d\u0430\u044e.<\/p>\n<h3>\u0410\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0440\u0430\u0431\u043e\u0442\u044b<\/h3>\n<p>SDRAM \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043a\u043e\u043c\u0430\u043d\u0434, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0437\u0430\u0434\u0430\u0435\u0442 \u0440\u0435\u0436\u0438\u043c \u0438 \u0441\u0442\u0430\u0434\u0438\u0438 \u0440\u0430\u0431\u043e\u0442\u044b. \u0412\u043e\u0442 \u0441\u043f\u0438\u0441\u043e\u043a \u043a\u043e\u043c\u0430\u043d\u0434 \u0434\u043b\u044f \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b MT48LC16M16A2:<\/p>\n<figure class=\"full-width\">\n<div><figcaption>\u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0441 \u0441\u0430\u0439\u0442\u0430 <a href=\"https:\/\/%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B0%20%D1%81%20%D1%81%D0%B0%D0%B9%D1%82%D0%B0%20http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html\" rel=\"noopener noreferrer nofollow\">http:\/\/microsin.net\/adminstuff\/hardware\/sdr-sdram-mt48lc16m16a2.html<\/a>   <\/figcaption><\/div>\n<\/figure>\n<p>\u0423 \u0441\u0430\u043c\u043e\u0439 \u0436\u0435 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b \u043f\u043e\u043b\u043d\u043e \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u0440\u0435\u0436\u0438\u043c\u043e\u0432 \u0440\u0430\u0431\u043e\u0442\u044b, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<ul>\n<li>\n<p>\u0420\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0434\u043b\u0438\u043d\u044b \u043f\u0430\u043a\u0435\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0437\u0430 \u0440\u0430\u0437 \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c.<\/p>\n<\/li>\n<li>\n<p>\u0410\u0432\u0442\u043e \u043f\u0435\u0440\u0435\u0437\u0430\u0440\u044f\u0434\u043a\u0430 \u044f\u0447\u0435\u0435\u043a \u043f\u0430\u043c\u044f\u0442\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0443\u0447\u0430\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u0431\u0430\u043d\u043a\u043e\u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0437\u0430\u0440\u044f\u0434\u0430.<\/p>\n<\/li>\n<li>\n<p>\u0422\u0430\u043a \u0436\u0435 \u0438\u043c\u0435\u044e\u0442\u0441\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0430 \u043e\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f \u043a \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044e.<\/p>\n<\/li>\n<\/ul>\n<p>\u0414\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u0443\u043f\u0440\u043e\u0441\u0442\u0438\u0442\u044c \u0441\u0435\u0431\u0435 \u0436\u0438\u0437\u043d\u044c, \u044f \u043f\u0435\u0440\u0435\u0448\u0435\u043b \u0432 \u0440\u0435\u0436\u0438\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a \u043e\u0434\u043d\u043e\u0439 \u044f\u0447\u0435\u0439\u043a\u0435 \u0437\u0430 \u043e\u0434\u043d\u043e \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435. \u0422\u0430\u043a \u0436\u0435 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0441\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e\u043c, \u0447\u0442\u043e \u043f\u043e\u0441\u043b\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0447\u0442\u0435\u043d\u0438\u044f\/\u0437\u0430\u043f\u0438\u0441\u0438 \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u0447\u0442\u0435\u043d\u0438\u044f\/\u0437\u0430\u043f\u0438\u0441\u0438, \u0435\u0441\u043b\u0438 \u043d\u043e\u0432\u044b\u0439 \u0430\u0434\u0440\u0435\u0441 \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u044f \u043c\u043e\u0433 \u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e 512 \u0441\u043b\u043e\u0432 \u0431\u0435\u0437 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438, \u0437\u0430\u0442\u0435\u043c \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0441\u0441 &nbsp;\u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u044f\u0447\u0435\u0435\u043a \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0430\u0432\u0442\u043e\u043c\u0430\u0442 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442 \u0432 \u0440\u0435\u0436\u0438\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u043a\u043e\u043c\u0430\u043d\u0434\u044b. \u0412 \u0438\u0442\u043e\u0433\u0435 \u0443 \u043c\u0435\u043d\u044f \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0432\u043e\u0442 \u0442\u0430\u043a\u043e\u0439 \u043c\u043e\u0434\u0443\u043b\u044c:<\/p>\n<figure class=\"\"><\/figure>\n<p>\u0418\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 m_* \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432\u0445\u043e\u0434\u043d\u044b\u043c \u0434\u043b\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043a\u043e\u043c\u0430\u043d\u0434 \u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0435\u0441\u043b\u0438 \u043a\u043e\u043c\u0430\u043d\u0434\u0430 \u043d\u0430 \u0437\u0430\u043f\u0438\u0441\u044c. \u041f\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0443 s_* \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432\u044b\u0432\u043e\u0434 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 \u0447\u0442\u0435\u043d\u0438\u044f \u0438\u0437 \u043f\u0430\u043c\u044f\u0442\u0438. \u0414\u0430\u043d\u043d\u044b\u0435 \u0447\u0438\u0442\u0430\u044e\u0442\u0441\u044f \u0441 \u0437\u0430\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u0432 3 \u0442\u0430\u043a\u0442\u0430. <\/p>\n<p>\u041b\u043e\u0433\u0438\u043a\u0430 \u043c\u043e\u0434\u0443\u043b\u044f \u043f\u0440\u043e\u0441\u0442\u0430, \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u0437\u0430\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0434\u043e \u0442\u0435\u0445 \u043f\u043e\u0440, \u043f\u043e\u043a\u0430 \u0430\u0434\u0440\u0435\u0441 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0432\u043e \u043c\u043b\u0430\u0434\u0448\u0438\u0445 9 \u0440\u0430\u0437\u0440\u044f\u0434\u0430\u0445. \u0422\u0430\u043a \u0436\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u044e\u0442 \u0437\u0430\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f, \u0435\u0441\u043b\u0438 \u043f\u043e\u043c\u0435\u043d\u044f\u043b\u0441\u044f \u0442\u0438\u043f \u043a\u043e\u043c\u0430\u043d\u0434\u044b(\u0447\u0442\u0435\u043d\u0438\u0435&lt;=&gt;\u0437\u0430\u043f\u0438\u0441\u044c). \u041c\u043e\u0434\u0443\u043b\u044c \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u0435\u043d \u043a \u0441\u0438\u0433\u043d\u0430\u043b\u0443 m_valid, \u0435\u0441\u043b\u0438 \u043e\u043d \u0443\u043f\u0430\u043b, \u0442\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442 \u043a \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u044e \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442 \u0437\u0430\u0440\u044f\u0434 \u0432 \u044f\u0447\u0435\u0439\u043a\u0430\u0445.<\/p>\n<p>\u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0432 \u0434\u0430\u0442\u0430\u0448\u0438\u0442\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043e, \u0447\u0442\u043e \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0447\u0430\u0441\u0442\u043e\u0442\u0430 \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043c\u0438\u043a\u0440\u043e\u0441\u0445\u0435\u043c\u044b 133 \u041c\u0413\u0446, \u043d\u0430 \u043c\u043e\u0435\u0439 \u043e\u0442\u043b\u0430\u0434\u043a\u0435 \u043c\u043e\u0434\u0443\u043b\u044c \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043d\u0430 \u0447\u0430\u0441\u0442\u043e\u0442\u0435 150 \u041c\u0413\u0446. \u041d\u043e \u044f \u043d\u0435 \u0441\u0442\u0430\u043b \u0438\u0441\u043f\u044b\u0442\u044b\u0432\u0430\u0442\u044c \u0441\u0443\u0434\u044c\u0431\u0443 \u0438 \u043e\u0441\u0442\u0430\u0432\u0438\u043b \u0447\u0430\u0441\u0442\u043e\u0442\u0443 \u0432 100 \u041c\u0413\u0446 (\u043c\u043d\u0435 \u0442\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u0434\u043b\u044f \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f).<\/p>\n<details class=\"spoiler\">\n<summary>\u0412\u043e\u0442 \u043a\u043e\u0434 \u043c\u043e\u0434\u0443\u043b\u044f: <\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"vhdl\">`timescale 1ns \/ 1ps  module ctrl_sdram_v2 #( parameter [2:0] CL = 'd3 ) (     input clk,  input rst,  \/\/user interface)  input [15:0] m_data, \/\/ valid if m_we==1  input [23:0] m_addr, \/\/2bit BANK, 13bit ROW, 9bit COLUMM  input m_we  , \/\/ 0 - read, 1 - write)  input m_valid,  output      m_ready,  output reg[15:0] s_data,  output reg    s_valid,  input      s_ready,\/\/ invalid ready. only s_valid     \/\/SDRAM interface  output reg sd_cke,  output sd_clk,  output sd_dqml,  output sd_dqmh,  output reg  sd_cas_n,  output reg sd_ras_n,  output reg sd_we_n,  output reg sd_cs_n,  output reg [14:0] sd_addr,  inout  [15:0] sd_data     );   reg [3:0] state_main = 'd0; reg [15:0] state_tri ; reg [15:0] sd_data_o ; wire [15:0] sd_data_i ;  reg [23:0] m_addr_set = 'd0; reg flg_first_cmd = 'd1; wire new_row_addr; reg [15:0] cnt_wait = 'd0; reg [15:0] cnt_wait_buf = 'd0; reg [10:0] cnt_refresh_sdram = 'd0; always@(posedge clk) begin if(rst) begin state_main &lt;= 'd0; m_addr_set &lt;= 'd0; flg_first_cmd &lt;= 'd1; end else begin case(state_main) 0: begin \/\/wait 100 us if(cnt_wait &gt;= 8000) state_main&lt;= 'd1; else cnt_wait &lt;= cnt_wait + 1; end 1: begin \/\/set NOP if(cnt_wait &gt;= 10000) begin  state_main&lt;= 'd2; cnt_wait &lt;= 'd0; end else cnt_wait &lt;= cnt_wait + 1; end 2: begin \/\/cmd PRECHARGE ALL if(cnt_wait &gt;= 'd1) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd3; end else cnt_wait &lt;= cnt_wait + 1'b1; end 3: begin \/\/ AUTO REFRESH 0 if(cnt_wait[14:0] &gt;= 'd6) begin  cnt_wait[14:0] &lt;= 'd0; if(cnt_wait[15]) begin state_main &lt;= 'd4; cnt_wait[15] &lt;= 'd0; end else cnt_wait[15] &lt;= 'd1; end else cnt_wait &lt;= cnt_wait + 1'b1; end 4: begin \/\/cmd LOAD MODE if(cnt_wait &gt;= 'd1) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end 5: begin \/\/IDLE state if(m_valid) begin state_main &lt;= 'd6; cnt_refresh_sdram &lt;= 'd0; end else begin if(&amp;cnt_refresh_sdram) begin state_main &lt;= 'd8; cnt_refresh_sdram &lt;= 'd0; end else cnt_refresh_sdram &lt;= cnt_refresh_sdram + 1; end end 6: begin \/\/ cmd ACTIVATE row if(cnt_wait &gt;= CL) begin  cnt_wait &lt;= 'd0; if(m_we) begin \/\/cmd WRITE state_main &lt;= 'd7; end else begin \/\/cmd READ state_main &lt;= 'd9; end m_addr_set &lt;= m_addr; flg_first_cmd &lt;= 'd1; end else cnt_wait &lt;= cnt_wait + 1'b1; end 7: begin \/\/WRITE m_addr_set &lt;= m_addr; if(flg_first_cmd) begin flg_first_cmd &lt;= 'd0; end else begin if(new_row_addr=='d1 || m_valid == 'd0 || m_ready == 'd0) begin\/\/goto precharge state_main &lt;= 'd8; end end end 8: begin \/\/cmd PRECHARGE after write if(cnt_wait &gt;= 'd3) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end 9: begin \/\/READ and reading data from SDRAM m_addr_set &lt;= m_addr; if(flg_first_cmd) begin flg_first_cmd &lt;= 'd0; end else begin if(new_row_addr=='d1 || m_valid == 'd0 || m_ready == 'd0) begin\/\/ state_main &lt;= 'd10; cnt_wait_buf &lt;= cnt_wait; end end cnt_wait &lt;= cnt_wait + 1'b1; end 10: begin \/\/reading data from SDRAM if(cnt_wait == cnt_wait_buf+CL) begin state_main &lt;= 'd11; cnt_wait &lt;= 'd0; end else cnt_wait &lt;= cnt_wait + 1; end 11: begin \/\/ cmd AUTO REFRESH after read if(cnt_wait &gt;= 'd3) begin  cnt_wait &lt;= 'd0; state_main &lt;= 'd5; end else cnt_wait &lt;= cnt_wait + 1'b1; end endcase end end   assign new_row_addr = (m_addr_set[23:9] != m_addr[23:9]) ?  'd1 : 'd0;  assign m_ready = (state_main == 'd7 &amp;&amp; m_we == 'd1 &amp;&amp; new_row_addr == 'd0) ? 'd1 :    (state_main == 'd9 &amp;&amp; m_we == 'd0 &amp;&amp; new_row_addr == 'd0) ? 'd1 :   'd0;     always@(posedge clk) begin s_data &lt;= sd_data_i; s_valid &lt;= ((state_main == 'd9 || state_main == 'd10) &amp;&amp; cnt_wait &gt; CL) ? 'd1 : 'd0; end  assign sd_dqml=0; assign sd_dqmh=0;  always@(posedge clk) begin   state_tri &lt;= (state_main == 'd7) ? 16'd0 : 16'hFFFF;   sd_data_o &lt;= (state_main == 'd7) ? m_data : 'd0;   sd_cke&lt;= (state_main == 'd0) ? 'd0 : 'd1;   sd_cas_n&lt;=(state_main == 'd1) ? 'd1 : \/\/ INIT NOP (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd1 : \/\/PRECHARGE (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd0 : \/\/autorefresh (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd1 :\/\/nop (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : \/\/load mode (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd1 : \/\/nop (state_main == 'd5)  ? 'd1 : \/\/nop (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd1 : \/\/activate (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd1 : \/\/nop (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : \/\/WRITE (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1  : \/\/nop (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd1 : \/\/precharge after write (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd1 : \/\/nop (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd0  : \/\/READ ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1 : \/\/ nop (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd1: \/\/'d0 : \/\/auto REFRESH(1) \/\/precharge after read (state_main == 'd11 &amp;&amp; cnt_wait!=0) ? 'd1 : \/\/ nop 'd1;  sd_ras_n&lt;=(state_main == 'd1) ? 'd1 :  (state_main == 'd2 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd2 &amp;&amp; cnt_wait&gt;0)  ? 'd1 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]==0)  ? 'd0 : (state_main == 'd3 &amp;&amp; cnt_wait[14:0]!=0)  ? 'd1 : (state_main == 'd4 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd4 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd5)  ? 'd1 : (state_main == 'd6 &amp;&amp; cnt_wait==0)  ? 'd0 : (state_main == 'd6 &amp;&amp; cnt_wait!=0)  ? 'd1 : (state_main == 'd7 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd1  : (state_main == 'd7 &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1  : (state_main == 'd8 &amp;&amp; cnt_wait==0) ? 'd0 : (state_main == 'd8 &amp;&amp; cnt_wait!=0) ? 'd1 : (state_main == 'd9 &amp;&amp; m_valid=='d1 &amp;&amp; m_ready=='d1  ) ? 'd1  : ((state_main == 'd9 || state_main == 'd10) &amp;&amp; (m_valid=='d0 || m_ready=='d0)) ? 'd1 : (state_main == 'd11 &amp;&amp; cnt_wait==0) ? 'd0: \/\/'d0 : (state_main == 'd11 &amp;&amp;<\/code><\/pre>\n<\/div>\n<\/details>\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-347844","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/347844","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=347844"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/347844\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=347844"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=347844"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=347844"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}