Fpga4Fun: fpga4fun.com — Pong Game

fpga4fun.com… fpga4fun.com — where FPGAs are fun. Реформал.

Основные сведения:

Рейтинг:

Адрес:

http://fpga4fun.com

О сайте:

Анализ данных fpga4fun.com показал, что у этого домена средний рейтинг Alexa и это обычный ресурс со средним уровнем посещаемости. Лидирующую позицию по доле трафика занимает США (54,4%), а владельцем домена является Contact Privacy Inc. Customer 7151571251.

Заголовок:

fpga4fun.com — where FPGAs are fun

Мета-описание:

FPGA tutorials: what are FPGAs, and how they work. Feb 2016 — Connect an SD card to your FPGA Feb 20…

Рейтинг Alexa

352 939

Посетителей в день

Нет данных

Просмотров в день

Нет данных

Статус:

Онлайн

Дата последней проверки:

Наиболее популярные страницы домена:

  • fpga4fun. com — Serial interface 5 — How to use the RS-232 transmitter and receiver

    Serial interface 5 — How to use the RS-232 transmitter and receiver This design allows controlling a few FPGA pins from your PC (through your PC’s serial port). It create 8 outputs on the FPGA (port n…

  • fpga4fun.com — where FPGAs are fun

    FPGA tutorials: what are FPGAs, and how they work. Feb 2016 — Connect an SD card to your FPGA Feb 2014 — An update to the music demo file Sept 2013 — Fun with HDMI May 2013 — The art of counting

Другие домены этого хостинг-провайдера (Amazon Technologies Inc.):

priv1.edbtopstconverter.com

direct.recklesspursuit.com

opera.com

goodreads.com

psychologytoday. com

nist.gov

Географическое распределение аудитории для fpga4fun.com:

СтранаДоля посетителейРейтинг по стране
США54,4%161 301

Информация о домене:

Возраст домена:

19 лет

Владелец:

Contact Privacy Inc. Customer 7151571251

Регистратор:

Google LLC

Поисковые фразы:

Ключевое слово% трафика
fpga4fun1.90%

Другие домены, которые могут быть вам интересны:

getstartuptools.com

geigercounter.org

dem.fiu.edu

apogeeresults.com

searchengineoptimism. com

Контроллер SDRAM на FPGA | xilinx

Несмотря на то, что современные FPGA содержат внутренние блоки памяти (BRAM), количество этой доступной памяти всегда на порядки меньше, чем может быть с выделенными внешними микросхемами. Так что не сюрприз, что многие разработчики FPGA подключают некоторые типы памяти к своим проектам. В частности, микросхемы SDRAM очень популярны, так как они достаточно быстрые, имеют большую емкость и недорогие. К сожалению, управлять динамической памятью не так же просто, как статической, так что для этого часто используется контроллер SDRAM.

Для нашего контроллера мы будем подключать возможно самую простую их доступных SDRAM: Micron MT48LC1M16A1 16Mb SDRAM. Нашей тестовой системой будет Xylo-E, Xylo-EM и Xylo-LM (Xilinx или Altera FPGA с памятью от 16Mb до 256Mb SDRAM).

Обсуждение поделено на 3 части (это перевод статьи [1]). В первой будет введение про память, используемую с FPGA. Затем мы покажем, как сделать контроллер 16Mb SDRAM. И в конце будет показана продвинутая память DDR SDRAM.

[От статики к динамике]

Представим себе, что нужно подключить 16Mb память к FPGA.

16Mb означает, что в памяти хранится 16 миллионов бит (или, если быть точным, 16777216 бит). Очень редко биты адресуются индивидуально, обычно они обрабатываются порциями по 8 или 16 (мы называем эти порции словами). Так что если наша память 16Mb организована как 1M слов по 16 бит, то понадобится 20-разрядная шина адреса и 16-разрядная шина данных, плюс сигналы разрешения записи (write enable, WE) и разрешения чтения (read enable, RE).

Реальные микросхемы памяти также имели бы сигнал выборки CS (chip select), и если память синхронная, еще и тактовый сигнал (на картинке для ясности эти сигналы опущены).

Стоит сделать оговорку, что если память находится внутри FPGA (так называемая блочная память BRAM), то она конечно совсем другая — нет BRAM такого размера. Просто предположим, что такая память 16Mb BRAM существует.

Как Вы можете видеть, это все еще один блок памяти, но здесь 2 адресные шины, это так называемая двухпортовая память (dual port memory BRAM), которая присутствует на современных кристаллах FPGA. Такая память позволяет двум агентам получить доступ к массиву памяти одновременно. Обычно один агент записывает в память, в то время как другой агент читает. Таким образом, у памяти есть независимые шины адреса и данных для каждого агента. Рисунок выше показывает, что шины первого (записывающего) агента находятся сверху, и шины второго (читающего) снизу. Более продвинутые BRAM позволяют каждому агенту и читать и записывать, но чаще всего используется архитектура, показанная выше. Также BRAM обычно используются синхронно, так что каждый агент предоставляет сигнал тактов (не показан на рисунке).

Показанная до сих пор память статическая, это означает, что данные в ней хранятся до тех пор, пока подано питание. Также статическую память можно рассматривать как линейный массив слов. Вы просто предоставляете адрес, чтобы получить доступ к соответствующим данным, никакой дополнительной сложности. Платить за это приходится высокой стоимостью каждого бита, которая намного больше, чем у динамической памяти (SDRAM).

Динамическая память. Перейдем к SDRAM, которая является динамической памятью (dynamic, отсюда появилась «D» в аббревиатуре SDRAM). И в динамической памяти мы больше не увидим линейную организацию слов, вместо этого память организована как матрица слов со строками и столбцами (row, column).

Рисунок выше показывает 12 бит на строку и 8 бит на столбец, и всего получается 20 бит адреса.

Здесь есть одно усложнение: чтобы повысить быстродействие, каждая память делится на одинаковые по размеру куски, которые называются «банками». Это потому что операции с динамической памятью медленные, и делением памяти на банки позволяет работать с одним из банком, ожидая готовности к работе другого банка.

Если в нашей памяти 16Mb SDRAM есть 2 банка, то в каждом будет 8Mb.

Когда осуществляется доступ к SDRAM, FPGA выбирает банк (bank, 1 бит), строку (row, теперь это только 11 бит) и столбец (column 8 бит), всего получается 20 бит. Но этот процесс занимает 2 шага: сначала row+bank, затем column:

• FPGA выбирает банк, и активирует одну из его строк. Затем FPGA ждет несколько тактов (для того, чтобы строка стала готова к работе).
• Теперь строка активна, и FPGA может осуществить доступ (на чтение и/или запись) к любым нужным данным, просто предоставив адрес столбца.
• Как только FPGA завершила работу со строкой, она должна закрыть её перед открытием новой.

Для лучшей производительности пользователь (т. е. FPGA) хотел бы избежать слишком частого открытия и закрытия строк, вместо этого максимально часто, насколько это возможно, работая со строками, и чередовать операции в разных банках, чтобы не терять такты на ожидание. Большинство микросхем SDRAM в действительности имеют 4 или 8 банков, и каждый банк не зависим друг от друга, так что может иметь свою собственную активную строку.

Выводы SDRAM. Если мы посмотрим на выводы реальной микросхемы SDRAM, то увидим кое-что новое.

Обновление данных. SDRAM является динамической памятью: её содержимое нуждается в периодическом обновлении, потому что значение каждого бита памяти (0 или 1) содержится в маленьком конденсаторе, у которого заряд со временем снижается из-за токов утечек. Однако скорость разряда конденсатора достаточно низкая, чтобы допускать периодические операции чтения и записи обратно (так называемая операция обновления, refresh). Когда эти операции обновления делаются через определенные периоды времени, производитель гарантирует, что данные не будут потеряны.

Доступны два механизма обновления:

• FPGA использует команду «auto-refresh»: обновление осуществляется периодической отправкой в SDRAM этой команды.
• FPGA достаточно часто осуществляет доступ к каждой строке: открытие строки приводит в действие специальную схему усилителей (sense amplifiers) в SDRAM, чтобы получить копию всех зарядов конденсаторов строки. Тогда когда строка закрывается, значения, прочитанные ранее, копируются обратно в конденсаторы, обновляя данные во время этого процесса.

Почему нужен контроллер памяти? Микросхемы динамической памяти более сложные для доступа, чем статические. У нас есть строки, столбцы, банки, и циклы обновления, и обо всем этом нужно заботиться. Но SDRAM востребованы благодаря их достаточно высокой скорости и низкой стоимости в пересчете на бит.

Таким образом, нам нужен способ доступа к SDRAM, достаточно простой, как доступ к статической памяти. Это именно та причина, по которой делают контроллеры памяти. Они функционируют как слой трансляции: с одной стороны они предоставляют простой для пользователя интерфейс к памяти, и с другой стороны делают всю грязную работу по управлению сигналами микросхемы SDRAM, в том числе функции обновления.

[Простой контроллер SDRAM]

У нашего контроллера SDRAM будут следующие свойства:

• Простой в использовании: SDRAM будет выглядеть как статическая память (или все равно максимально близко к этому, насколько возможно).
• Быстрый: SDRAM используется в пакетном режиме (burst mode), если Вы предоставите следующие друг за другом адреса.
• Простой: без планировщика, в любой момент времени активен только один банк.
• Мощный: SDRAM появляется как простая двухпортовая память (т. е. с одним агентом записи и одним агентом чтения).

Последнее свойство свойство контроллера самое необычное. SDRAM это память с одним портом, но FPGA значительно выигрывают от доступа к двухпортовой памяти (наподобие BRAM), так что это полезное свойство мы оставим.

Сигналы контроллера. Вот упрощенный вид на наш контроллер SDRAM.

Первые 3 сигнала слева используются для агента записи (запрос записи «write request», за которым идет адрес записи «write address» и записываемые данные «write data»). Ниже идут 3 сигнала для агента чтения. Справа сигналы, которыми контролер управляет SDRAM. Для рассмотрения в перспективе ниже показана типовая система FPGA с использованием нашего контроллера SDRAM.

Контроллер представляет SDRAM для использования как двухпортовую память. Но SDRAM в реальности память однопортовая, поэтому нашему контроллеру нужен какой-то трюк для обработки двух запросов. Если 2 запроса поступили одновременно, то либо один из агентов приостанавливается, или их запросы записываются и выполняются позже. Наш контроллер выбирает первую стратегию. Для этого добавлены сигналы предоставления доступа «grant»: агент может выставить запрос в любое время, но контроллер решает, предоставлять доступ или нет. Если запрос запрещен, нужно его удерживать, и доступ будет предоставлен по возможности.

Еще одна сложность с SDRAM происходит от факта, что данные, возвращаемые в ответ на запрос чтения, поступают с задержкой (это называется CAS latency в даташитах на SDRAM). Контроллер также может добавлять несколько тактов задержки. Так что даже когда контроллер может предоставить разрешение на запрос чтения, соответствующие данные становятся доступными только через фиксированное количество тактов. Для удобства добавлен сигнал достоверности данных «data valid», который выставляется тогда, когда данные действительно доступны.

Машина состояний. Сердцем нашего контроллера SDRAM является машина состояний. Контроллер ждет запроса (чтения read или записи write), открывает соответствующий банк/строку (bank/row), выдает команды чтения ли записи (столько, сколько активный агент запрашивает в активной строке), и в конце закрывает строку.

По этой схеме в любой момент времени активен только один банк. Продвинутые контроллеры SDRAM позволяли бы одновременную активность нескольким банкам, но здесь мы решили упростить задачу.

Закрытие и открытие строки занимает некоторое время. Например, даташит на SDRAM дает следующие значения:

tRCD = 20ns (от состояния активности до чтения/записи)
tRP = 21ns (от состояния precharge до активности)

Таким образом, если мы будем работать с SDRAM на частоте 100 МГц, то период тактов окажется 10ns, и нужно добавить несколько пустых тактов (так называемых NOP) в машину состояний. Также нужны циклы восстановления, если агент чтения не гарантирует регулярного открытия каждой строки.

Машина состояний становится немного сложнее.

И наконец, может понадобиться подстроить количество тактов NOP. Например, на частоте 100MHz с временем tRP = 21ns, возможно будет достаточным применить 2 такта NOP после precharge (дает нам 30ns перед следующей активацией).

Инициализация. У SDRAM есть некоторые программируемые настройки (наподобие CAS latency), для этого есть регистр MODE, который нужно инициализировать при включении питания. Для этой цели существует команда LOAD MODE. В контроллер должна быть добавлена инициализация SDRAM, или отдельный шаг перед тем, как контроллер запустится.

Код контроллера показан ниже. Чтобы получить самые лучшие интервалы времени IO, все сигналы управления SDRAM сделаны без какой-либо комбинаторной логики вне FPGA.

always @(posedge clk)  // машина состояний
case(state)
   2'h0: begin
      // Это запрос чтения или записи?
      if(RdReq | WrReq) begin
         SDRAM_CMD <= SDRAM_CMD_ACTIVE;   // если так, то открытие
         SDRAM_BA <= Addr[19];            // этого банка
         SDRAM_A <= Addr[18:8];           // этой строки
         SDRAM_DQM <= 2'b11;
         state <= 2'h2;
      end
      else
      begin
         SDRAM_CMD <= SDRAM_CMD_NOP;      // иначе продолжится состояние ожидания
         SDRAM_BA <= 0;
         SDRAM_A <= 0;
         SDRAM_DQM <= 2'b11;
         state <= 2'h0;
      end
   end
   2'h2: begin
      SDRAM_CMD <= ReadSelected ? SDRAM_CMD_READ : SDRAM_CMD_WRITE;
      SDRAM_BA <= AddrR[19];
      SDRAM_A[9:0] <= {2'b00, AddrR[7:0]};   // столбец
      SDRAM_A[10] <= 1'b0;                   // без auto-precharge
      SDRAM_DQM <= 2'b00;
      state <= (ReadSelected ? RdReq : WrReq) & SameRowAndBank ? 2'h2 : 2'h3;
   end
   2'h3: begin
      // закрыть строку, когда завершилась работа с ней:
      SDRAM_CMD <= SDRAM_CMD_PRECHARGE;
      SDRAM_BA <= 0;
      // precharge всех банков:
      SDRAM_A <= 11'b100_0000_0000;
      SDRAM_DQM <= 2'b11;
      state <= 2'h0;
   end
endcase

Полный демонстрационный код можно скачать по ссылке []. Он функционален, но поскольку он обучающий, то максимально упрощен, и из него удалены не обязательные функции. См. комментарии в коде, описывающие ограничения и требования.

Пример использования. SDRAM часто используется в видеоадаптерах, где память нужна для сохранения графики. Это работает примерно так: процессор компьютера посылает данные графики в видеокарту. Видеокарта использует SDRAM для сохранения данные, и контроллер в карте периодически читает память, чтобы послать данные на дисплей. Поскольку чтение периодическое, в течение этого процесса данные, находящиеся в SDRAM, обновляются автоматически (специальный refresh не требуется).

Подобная базовая система была создана на плате Xylo-EM как часть проверки правильности работы контроллера. Тот факт, что контроллер SDRAM сделан двухпортовым, значительно упростил дизайн (PC/FX2 это агент записи, а видеоконтроллер это агент чтения).

[SDRAM DDR — борьба за скорость]

Когда производители памяти пытались найти способы повысить скорость SDRAM, была представлена память DDR SDRAM. DDR означает «double data rate», т. е. двойная скорость доступа.

Ячейки DDR SDRAM подобны обычной (single data rate) SDRAM (все еще есть банки и строки, которые нужно открывать). Ускорение происходит с повышением частоты тактов, удлинением периодов пакета, и доступ к двум битам за 1 такт (отсюда и пошло имя DDR). Это потребовало очень жесткой организации интервалов времени на сигналах данных, чтобы обеспечить надежное перемещение данных.

[Ссылки]

1. FPGA SDRAM controller site:fpga4fun.com.

[Xylo-SDR] заказ на fpga4fun.com, еще один Xylo байтит пыль.

Re: [Xylo-SDR] fpga4fun.com заказывайте, еще один Xylo байтит пыль.
[Дата Предыдущая][Дата Следующая][Предыдущая Тема][Следующая Тема][Указатель Даты][Указатель Темы]
  • К : Обсуждение Xylo-SDR
  • Тема : Re: [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
  • От : Филип Ковингтон [email protected]>
  • Дата : Пт, 9 декабря 2005 г. 15:58:17 -0500
  • Доставлено в : [email protected]
  • Ключ-подпись домена : a=rsa-sha1; д=днс; с=нетвс; с=бета; д=gmail.com; h = получено: идентификатор сообщения: дата: от: до: тема: в ответе на: MIME-версия: тип контента: кодирование передачи контента: расположение контента: ссылки; b=Fe1gdrmxCGrzV1a65Ha/r+Ogrr8Y3WnCN8heJjwc56MRLajCYGWKZwZzT6zRCKVwsB55ycWUEAAQF/ZKSqhQjCbIQji2LIw/YhsJY6X6uSPMhMK5PudN94ASGojR4CB6a/4FAfO9gfdG6bFyBuKhyvFQ0myf/8Is2ppAbWp8+G8=
  • В ответ на : <6.2.3.4.0.20051209144711.01c81518@localhost>
  • Список-архив :
  • List-help :
  • Идентификатор списка : Обсуждение Xylo-SDR
  • Список сообщений :
  • Подписка на список : ae5k.us/listinfo.cgi/xylo-sdr-ae5k.us>,
  • Список-отказ от подписки : ,
  • Ссылки : <[email protected]> <007b01c5fcda$d08dc830$6401a8c0@athlon> <6.2.3.4.0.20051209144711.01c81518@localhost>
  • Ответить на : Обсуждение Xylo-SDR

 Поздравляю... Сесил!
Вам будет очень весело с Xylo.
73 де Фил N8VB
09.12.05 KD5NWA  написал:
>
> Еще одна игрушка на подходе! :-П
>
> Эрик, думаю, я потеряю свой статус "скрытника". :'(
>
>
> В 10:08 09.12.2005 вы писали:
> >Сесилио,
> >
> >Ваш заказ готов и отправлен сегодня.
> >
> >Пожалуйста, загрузите файлы Xylo здесь:
> >СНиП
> >
> >Повеселитесь с доской!
> >Жан
>
>
>
> Сесил Байона
> KD5NWA
> www.qrpradio.com
>
> «С Богом в качестве свидетеля, клянусь, я думал, что индюки могут летать».  --
> Артур К. "Большой парень" Карлсон
>
>
> _______________________________________________
> Список рассылки Xylo-SDR
> Отправить сообщение: [email protected]
> Справка по подписке: http://lists.ae5k.us/listinfo.cgi/xylo-sdr-ae5k.us
> Веб-страница Xylo-SDR: http://xylo-sdr.ae5k.us
> Страницы форума: http://www.hamsdr.com/hamsdrforum/
>
 

  • Ссылки :
    • [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
      • От кого: KD5NWA
  • Предыдущий по дате: [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
  • Далее по дате: Re: [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
  • Предыдущая по теме: [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
  • Далее по теме: Re: [Xylo-SDR] заказ fpga4fun.com, еще один Xylo байтит пыль.
  • Индекс(ы):
    • Дата
    • Резьба

fpga4fun.com — fpga4fun.com — Добро пожаловать

fpga4fun.com — Добро пожаловать

www.fpga4fun.com/

Fpga4fun.com размещен в США / Лансинг . Fpga4fun.com не использует протокол HTTPS. Количество используемых технологий: 2 . Первые технологии: CSS, HTML, Количество используемых javascripts: 0 . Количество используемых инструментов аналитики: 0 . Количество используемых плагинов, модулей: 0 . Его тип сервера: Апач .

Веб-решения, используемые на Fpga4fun.com

Технология

Количество вхождений: 2

  •  CSS
  •  HTML

Факторы, влияющие на коэффициент конверсии

HTTPS (SSL) — Fpga4fun.

com

Отсутствует протокол HTTPS.

О домене

Длина доменного имени 12
Дефисы Домен не содержит дефисов!
Доменное имя с буквами хинди: फ़ प ग अ ४ फ़ उ ञ . च ओ म
Доменное имя с буквами иврита: ף פּ ג (а) 4 ף (у) נ . ק(с) (ο) מ
Доменное имя с кириллическими буквами: φ п г а 4 φ у н . ц о м
Доменное имя с арабскими буквами: ف (p) غ ا 4 ف (u) ن . (с) (о) №
Доменное имя с греческими буквами: φ π γ α 4 φ υ ν . χ ο μ
Доменное имя с китайскими буквами: 艾弗 屁 吉 诶 4 艾弗 伊吾 艾娜 .西 哦 艾马
Домен без согласных: fpg4fn. cm
Домен без гласных: а4у.о
Позиции в алфавите: ф 6 стр 16 g 7 a 1 f 6 u 21 n 14 . в 3 о 15 м 13
Шаблон доменного имени:
V : Гласная, C : Согласная, N : Число
C C C V N C V C . КВК

Используемые метатеги и их значения на Fpga4fun.com

Количество вхождений: 0

Сервер/хостинг

Информация о сервере

  • IP: 67.227.167.152
  • Широта: 42,73
  • Долгота: -84,64
  • Страна: США
  • Город: Лансинг
  • Кодировка IPV4 (Ip2long): 1138993048
  • Двоичный IP-адрес: 1000011111000111010011110011000
  • Восьмеричный IP-адрес: 10370723630
  • Шестнадцатеричный IP-адрес: 43e3a798
  • Тип сервера: Apache

Обратный поиск IP — fpga4fun.

com
  • 1. Odishajobs.co.in
  • 2. Nairn.ukhotelguides.com
  • 3. Fixwindows7errors.com
  • 4. Amfmreception.com
  • 5. Drivererrormov . Quoteyquotes.com
  • 8. Cheapepeeks.com
  • 9. Ocshoters.com
  • 10. H3oguy.com
  • 11. Revealthat.com
  • 12. Leethal.net
  • 13. Wise-web.org
  • 14. carterscouponcode.net
  • 15. leethalknits.com
  • 16. Shooty.rocks
  • 17. Lenknee.com
  • 18. Sosamartialarts.com
  • 19. Ilersoft.net
  • 20. Landmarkworldintl.com
  • 21. A1Kitchenexhaustcleaning.com
  • 22.
  • 23. xkorpion.net
  • 24. Haworthslandscaping.com
  • 25. Шарангдхарбалай.орг
  • 26. Justsms.us
  • 27. Perfectinfodesk.com
  • 28. SlotPlayerguide.com
  • 29.0065

    Основные DNS-серверы

    • ns259.fastwebhost.com
    • ns260.fastwebhost.com
    • fpga4fun.com

    Цель

    • devnull. sourcedns.com

    Общие опечатки

    Список наиболее распространенных опечаток в доменных именах, о которых вы должны знать

    www.pga4fun.com, www.fqpga4fun.com, www.qpga4fun.com, www.fpga4fun.com, www.pga4fun.com, www.fapga4fun.com, www.apga4fun.com, www.fypga4fun.com, www. ypga4fun.com, www.ftpga4fun.com, www.tpga4fun.com, www.fgpga4fun.com, www.gpga4fun.com, www.fbpga4fun.com, www.bpga4fun.com, www.fwpga4fun.com, www.wpga4fun. com, www.fspga4fun.com, www.spga4fun.com, www.fdpga4fun.com, www.dpga4fun.com, www.frpga4fun.com, www.rpga4fun.com, www.f3pga4fun.com, www.3pga4fun.com, www.f4pga4fun.com, www.4pga4fun.com, www.fga4fun.com, www.fpiga4fun.com, www.figa4fun.com, www.fpkga4fun.com, www.fkga4fun.com, www.fpuga4fun.com, www. fuga4fun.com, www.fpjga4fun.com, www.fjga4fun.com, www.fplga4fun.com, www.flga4fun.com, www.fpa4fun.com, www.fpgsa4fun.com, www.fpsa4fun.com, www.fpgxa4fun. com, www.fpxa4fun.com, www.fpgya4fun.com, www.fpya4fun.com, www. fpgha4fun.com, www.fpha4fun.com, www.fpgna4fun.com, www.fpna4fun.com, www.fpgca4fun.com, www.fpca4fun.com, www.fpgda4fun.com, www.fpda4fun.com, www.fpgea4fun.com, www.fpe a4fun.com, www.fpgra4fun.com, www.fpra4fun.com, www.fpgta4fun.com, www.fpta4fun.com, www.fpgba4fun.com, www.fpba4fun.com, www.fpgva4fun.com, www.fpva4fun. com, www.fpg4fun.com, www.fpgao4fun.com, www.fpgo4fun.com, www.fpgap4fun.com, www.fpgp4fun.com, www.fpga94fun.com, www.fpg94fun.com, www.fpga4fun.com, www.fpg4fun.com, www.fpgai4fun.com, www.fpgi4fun.com, www.fpgau4fun.com, www.fpgu4fun.com, www.fpgafun. com, www.fpga4wfun.com, www.fpgawfun.com, www.fpga4qfun.com, www.fpgaqfun.com, www.fpga4tfun.com, www.fpgatfun.com, www.fpga4efun.com, www.fpgaefun.com, www.fpga4rfun.com, www.fpgarfun.com, www.fpga42fun.com, www.fpga2fun.com, www.fpga4un.com, www.fpga4fqun.com, www.fpga4qun.com, www.fpga4fun.com, www. fpga4un.com, www.fpga4faun.com, www.fpga4aun.com, www.fpga4fyun.com, www.fpga4yun.com, www.fpga4ftun.com, www.fpga4tun.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *