Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Virtex-4 вывод данных через JTAG
Форум разработчиков электроники ELECTRONIX.ru > Программируемая логика ПЛИС (FPGA,CPLD, PLD) > Работаем с ПЛИС, области применения, выбор
Almaz1988
Добрый вечер!
Имеется плата с Virtex-4 на борту (xc4vfx60 ).
Также на плате расположена 12-битная 60 Msps микросхема АЦП
с параллельным интерфейсом и микросхема SRAM.
Поставили задачу написать ПО для тестирования платы, а именно
считывать данные с АЦП и складывать в SRAM. Затем нужно производить
вычитывание этих выборок либо с ПЛИС либо с SRAM на ПК через JTAG
(через программатор Platform USB Cable)в объеме около 8 КБ. Далее эти
данные планируется загонять в Matlab для оценки соответствия считанных
данных тому сигналу, который в качестве пробного подается на вход платы.
Как проще и быстрее всего сделать это?
На ум приходит только поднять MicroBlaze, который будет считывать
данные в ОЗУ, а его UART переназначить в XMD-консоль (коммандой
read_uart) и таким образом выдавать выборку АЦП в ПК.
Но есть подозрение, что это несколько замороченный способ и есть
варианты попроще.
Посоветуйте пожалуйста другие варианты?
iosifk
Цитата(Almaz1988 @ Apr 5 2016, 21:34) *
На ум приходит только поднять MicroBlaze, который будет считывать
данные в ОЗУ, а его UART переназначить в XMD-консоль (коммандой
read_uart) и таким образом выдавать выборку АЦП в ПК.

Да можно и автоматом обойтись...
Хоть через UART-USB, хоть через JTAG... Только при JTAG на хосте придется ставить софт для работы JTAG...
Bad0512
Цитата(Almaz1988 @ Apr 6 2016, 00:34) *
Посоветуйте пожалуйста другие варианты?

Тупо вкорячить чипскоп и захватывать данные с АЦП им. Вопрос как потом перетащить данные из чипскопа в матлаб. Но пути наверняка есть, надо читать доки на чипскоп.
_Anatoliy
Цитата(Bad0512 @ Apr 6 2016, 06:19) *
Тупо вкорячить чипскоп и захватывать данные с АЦП им. Вопрос как потом перетащить данные из чипскопа в матлаб. Но пути наверняка есть, надо читать доки на чипскоп.

Так из чипскопа данные элементарно сохраняются в файл который подхватит матлаб. Сам так делал.
Almaz1988
Цитата(Bad0512 @ Apr 6 2016, 06:19) *
Тупо вкорячить чипскоп и захватывать данные с АЦП им.

Цитата(_Anatoliy @ Apr 6 2016, 07:37) *
Так из чипскопа данные элементарно сохраняются в файл который подхватит матлаб.
Сам так делал.

Спасибо за совет. Отложил MicroBlze в сторону. Начал с ChipScope. Запустил пробный
проект с отладкой.
Все по мануалам: http://www.xilinx.com/support/documentatio...73-zynq-ctt.pdf
Все работает - при срабатывании триггера Chipscope отрисовывает мне состояние всех
регистров/переменных системы. А как быть если мне нужно вычитывать массивы данных
по 8 КБ? Мне нужно для этого создать переменную-массив размером 8192 байта?
И как сохранить массив данных в файл?
Судя по данному документу:
http://www.xilinx.com/support/documentatio...cores_ug029.pdf
в ChipScope должно быть меню System Monitor > Setup Logging, но я его не вижу.
Только лишь: Trigger Setup, Waveform, Listing, Bus Plot и Window.
_Anatoliy
Я сохранял через File/Export/ascii и т.д. Пробуйте,точнее сказать не могу - к чипскопу нет возможности добраться.
yes
> А как быть если мне нужно вычитывать массивы данных
по 8 КБ?

по-моему самое простое решение - считывать ножки, которые подключены к АЦП - то есть буфер памяти чипскоп сделает сам - закажите ему размер выборки 8К
Almaz1988
Цитата(_Anatoliy @ Apr 6 2016, 15:30) *
Я сохранял через File/Export/ascii и т.д. Пробуйте,точнее сказать не могу - к чипскопу нет возможности добраться.

Да, именно так. Спасибо)

Цитата(yes @ Apr 6 2016, 15:54) *
> А как быть если мне нужно вычитывать массивы данных
по 8 КБ?

по-моему самое простое решение - считывать ножки, которые подключены к АЦП - то есть буфер памяти чипскоп сделает сам - закажите ему размер выборки 8К

Да, действительно, в настройках корки Chipscope axi monitor можно задать количество семплов выборки. Спасибо за подсказку!
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.