реклама на сайте
подробности

 
 
> LPC2148+FPGA как?, Использование SSP
khach
сообщение Feb 21 2006, 13:11
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 3 439
Регистрация: 29-12-04
Пользователь №: 1 741



Вот даже незнаю, где спросить, тут или в ПЛИсах...
Суть проблемы - сопрячь LPC2148 c ПЛИСой (мелкий 3 Спартан) с максимальным быстродействием. В связи с отсутствием внешенй шины напрашиваеться применение SSP в качестве интерфейса. А теперь вопрос- требуется реализация на Veriloge или VHDL последовательного порта, макимально совместимого с филипсовским SSP ( с применением фифо и прочих фич). Обычный SPI, корки котророго уже найденны, слишком тормозит. Может кто встречал уже пример подобной реализации, а то обидно- скоростной интерфейс "гуляет".
Заодно выслушаю рекомендации по загрузке Спартана с АРМа ( как лучше хранить конфигурационный файл). Имеет ли смысл для этого добавить сериальный датафлеш в проект? Или хранить все внутри 2148 ( памяти жалко, но конфигурашка влазит), или грузить все по USB при старте устройства?

И как лучше развести jtagи - делать два раздельных? Если с АРМом все более-менее понятно, то с Хилинксом не очень- наверняка понадобиться хардверная отладка на этапе разработки (Сhipscope). Можно ли Чипскоп "протуннелировать" сквозь работающий USB АРМа ( прикинуться мульитдевайсом)?
Были ли проекты "клонирования" чипскопа с разборкой "по-косточкам" его протокола?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Igor657
сообщение Mar 20 2006, 15:55
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 21
Регистрация: 7-12-05
Пользователь №: 11 941



У меня LPC2138 + Cyclone 2 (Altera)
От использования SSP отказался, т.к. его выводы расположены неудачно.
А Вам в процессе приема-передачи еще нужно что-то делать ?
Если нет, то самодельный SPI (дерганье ножками у LPС) не намного медленнее чем аппаратный.

Оcновные плюсы SSP :
Hазгружать FIFO можно в обработчике прерывания, тем самым убрав передачу в фон.
Max clk = 1/2 pclk

Конфигурацию храню LPC.
Quartus генерирует ttf файл, которым удобно инициализировать const массив

const unsigned char PLD_cfg1[] = {
#include "cfg303_1.ttf"
};

в файле 3-х значные числа через запятую
для экономии можно написать простенький архиватор

У Xilinx должно быть нечто подобное

Кстати, если проблем с нехваткой ног нет, то можно параллельную шину организовать.


Удачи !
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 19th August 2025 - 20:43
Рейтинг@Mail.ru


Страница сгенерированна за 0.02053 секунд с 7
ELECTRONIX ©2004-2016