Перейти к содержанию
    

Многопроцессорная система с сопряжением через ПЛИС

Уважемые коллеги!

Проектрирую многопроцессорную систему (4 телекоммуникационных 2-х ядерных процессора).

Встал вопрос о сопряжении их между собой.

Из интерфейсов у процессоров есть по 4 линк-порта.

Приняла решение соединить их через ПЛИС FPGA.

Раньше такого не делала. Считаю что так будет лучше, чем соединять их другим образом.

Хотелось бы узнать ваши соображения и рассуждения по сопряжению процессоров через ПЛИС.

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

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Телепаты становись!!!! :biggrin:

 

Проектрирую многопроцессорную систему (4 телекоммуникационных 2-х ядерных процессора).

 

Название???

 

Из интерфейсов у процессоров есть по 4 линк-порта.

 

Краткое описание сигналов?????

 

А вообще то так

- Какую хотим архитектуру (раделяемую память или соединение через UART)

- Что хотим по скорости

- Ну и самое главное а обеспечивае ли выбранный проц подходящий инерфейс

 

Не хочу углубляться в технические подробности, давайте просто порассуждаем.

:cranky:

 

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

engineer09

Без хотя бы краткого пояснения задачи сказать что дельное, IMHO, сложно.

На мой взгляд, самый простой способ - обмен через FIFO внутри FPGA (при наличии внешней шины адреса/данных).

Это самый простой способ, но не самый эффективный и скоростной, поскольку процессор должен будет "прокачивать" через свои регистры все данные.

Если есть LPORT, то можно внутри FPGA разбирать последовательность и коммутировать сообщения каждому абоненту.

Это сложнее, зато можно использовать режим DMA.

Если большие потоки данных идут от внешнего интерфейса одного процессора к внешнему интерфейсу другого (к примеру, маршрутизация IP-пакетов), то тут лучше применить что-то типа AMBA (как в Leon3). Это значительно сложнее, но и значительно эффективнее.

Соглашаюсь с уважаемым klop - сложно что-то порекомендовать, если не ясна задача устройства.

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

А задача скорее всего не ясна и самому разработчику, поэтому ей хочется "просто" порассуждать... заодно и задачу сформулировать :)

А поскольку "раньше никогда такого никогда не делала", то наверное и неизвестно, что такое FPGA...

Ну для начала уважаемая engineer09, что за процессоры собираетесь использовать?

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Дела какие, подумаешь, "задача, процессоры". Сразу к стенке ставят.

 

Можно соединить линк-порты с ПЛИС, не забыв проверить однонаправленные, выделенно-клоковые и банко-несовместимо-непомещаюшиеся сигналы.

 

Ничего страшного при этом не случится, кроме усложнения, удорожания и роста задержки.

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Обычно в самих процессорах уже присутствует механизм наращиваемости в многопроцессорную систему. Думаю проще этим и воспользоваться:)

А ПЛИС использовать для других задач (если таковые есть).

 

P.S.: Название процессоров? ПЛИС? И (повторю предыдущие реплики:)) зачем это нужно?

P.P.S.: Если Вы хотите "просто порассуждать", обратитесь в программу "Пycть гoвopят" :)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

+1.

 

Надо посмотреть, как выбранные процессоры по замыслу фирмы-разработчика объединяются в многопроцессорную систему. И не изобретать велосипед.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Очень рада, что мой вопрос вызвал неподдельный интерес)

Итак, по-порядку.

1. Система предназначена под реализацию OFDM-сигнала для WiMAX или LTE (полоса 10МГц, БПФ на 1024 точки).

2. Выбран процессор пр-ва НПЦ "Элвис" NVCom-01 http://www.multicore.ru/mc/data_sheets/NVC...rief_070509.pdf

3. Память отдельная для каждого процессора

4. Каждый процессор имеет по 4 многофункциональных порта MFBSP (I2S/ SPI/ SHARC LPORT/ GPIO) с DMA.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

engineer09

Планируете реализовать радиомодем с поддержкой стандартов WiMAX или LTE?

На форуме обсуждались реализации - там одного БПФ на 1024 точки мало (IMHO, далеко не самая затратная по вычислительным ресурсам задача).

Поддержка интерфейсов пользователя уже определена? Какие сервисы будут доступны?

IMHO, лучше сначала модель на высокоуровневом языке "обкатать" прежде чем схему проектировать.

NVCom-01 - не самый удобный СнК, лучше что-нибудь поновее (более шустрое, менее жрущее).

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

4. Каждый процессор имеет по 4 многофункциональных порта MFBSP (I2S/ SPI/ SHARC LPORT/ GPIO) с DMA.

А у Analog devices нет готового коммутатора для LPORT?

 

Но вообще зачем вам процессор, предназначенный для GPS под OFDM? Возьмите MC-0226, у него есть PCI. Посадите на стандартный PCI коммутатор и все.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Очень рада, что мой вопрос вызвал неподдельный интерес)

Итак, по-порядку.

1. Система предназначена под реализацию OFDM-сигнала для WiMAX или LTE (полоса 10МГц, БПФ на 1024 точки).

2. Выбран процессор пр-ва НПЦ "Элвис" NVCom-01 http://www.multicore.ru/mc/data_sheets/NVC...rief_070509.pdf

3. Память отдельная для каждого процессора

4. Каждый процессор имеет по 4 многофункциональных порта MFBSP (I2S/ SPI/ SHARC LPORT/ GPIO) с DMA.

А зачем вам вообще процессоры?

Поставьте большой ПЛИС типа Virtex6, Kintex7, Stratix5,

памяти к нему побольше DDR2...3.

Потоковое Фурье на 1024 точки (правда целочисленное 16...32 бита) будет грызть как заяц морковку.

И таких Фурье числогрызок можно поставить 10-20 штук в параллель.

Ну и накрайняк можно создать многопроцессорную систему с Линухом или RTOS прямо внутри ПЛИС.

 

P.S. Я исхожу из того, что на задаче целочисленного Фурье, один современный ПЛИС типа XC6VLX240T по суммарной производительности

порвёт несколько TMS320C64XX, как тузик грелку.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

А у Analog devices нет готового коммутатора для LPORT?

 

Но вообще зачем вам процессор, предназначенный для GPS под OFDM? Возьмите MC-0226, у него есть PCI. Посадите на стандартный PCI коммутатор и все.

 

'DmitryR', какой PCI коммутатор посоветуете?

Был сделан выбор в пользу плис еще и потому, что это позволит гибко конфигурить устройство.

Какие будут задержки на psi при обработке одновременно 4-х потоков?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

 

В данном случае процессор используется не в военных а в чисто учебно-научных разработках)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...