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

 
 
 
Reply to this topicStart new topic
> Кривой сигнал TDO в JTAG Zynq 7000
Gerret
сообщение Dec 17 2013, 15:36
Сообщение #1





Группа: Участник
Сообщений: 13
Регистрация: 3-04-07
Пользователь №: 26 736



Приветствую, господа форумчане.

Если тема такая была, ткните пожалуйста носом, не смог найти...

Для начала немного о системе:

1) Использован модуль Trenz TE0720.
2) JTAG к нему подключен на прямую.
3) Программатор Digilent HS2 rev. A

Вот так выглядит сигнал TDO при программировании логической части Zynq:

Прикрепленное изображение
Прикрепленное изображение
Прикрепленное изображение



Логика прошивается нормально и даже начинает работать, но при попытке запустить программу на исполнение из SDK, получаю вот такую ошибку:
Код
INFO  : Processor reset is completed for ps7_cortexa9_0
INFO  : PS initialization will be done as it is not done before.
INFO  : Running PS initialization....
ERROR : Unexpected error while launching program. java.lang.RuntimeException: Error while running ps7_init method.
Cannot write to target


    Cannot access JTAG-DP: invalid ACK value (0x00, expected=0x02)
    Error Address = 0xf8000b50


    at com.xilinx.sdk.targetmanager.internal.TM.run_ps7_init(Unknown Source)
    at com.xilinx.sdk.targetmanager.internal.TM.runPs7Init(Unknown Source)


И ПЛИС перезапускается "забывая" прописанную перед этим логическую структуру.

Подскажите, где может быть засада!
Go to the top of the page
 
+Quote Post
Victor®
сообщение Dec 17 2013, 15:43
Сообщение #2


Lazy
******

Группа: Свой
Сообщений: 2 070
Регистрация: 21-06-04
Из: Ukraine
Пользователь №: 76



Цитата(Gerret @ Dec 17 2013, 18:36) *
Подскажите, где может быть засада!


Первая засада в щупах осциллографа. Земля у них "длинная".


--------------------
"Everything should be made as simple as possible, but not simpler." - Albert Einstein
Go to the top of the page
 
+Quote Post
rloc
сообщение Dec 17 2013, 16:42
Сообщение #3


Узкополосный широкополосник
******

Группа: Свой
Сообщений: 2 316
Регистрация: 13-12-04
Из: Moscow
Пользователь №: 1 462



Цитата(Victor® @ Dec 17 2013, 19:43) *
Первая засада в щупах осциллографа. Земля у них "длинная".

Причем засада в щупах отражается только на фронтах, в виде всплесков. А "пила" в середине - это HS2 переводит буфера в третье состояние, а подтягивающие резисторы заряжают входную емкость, когда данных нет. Убедиться в этом можно подключив второй канал на CLK - тактов в этот момент нет. Подозреваю, что не подключен выход GPIO2 на RESET Zync.

Updated.
Ха, а у HS2 нет GPIOx, только у SMT2.
Go to the top of the page
 
+Quote Post
Gerret
сообщение Dec 17 2013, 19:01
Сообщение #4





Группа: Участник
Сообщений: 13
Регистрация: 3-04-07
Пользователь №: 26 736



По поводу фронтов - согласен, земля длинная, но это на передачу не может влиять, а вот пила - интереснее. Нет подтягивающих резисторов на TDO... По этому и задаю вопрос, может кто видел такое? Такты завтра посмотрю.
Go to the top of the page
 
+Quote Post
rloc
сообщение Dec 17 2013, 19:16
Сообщение #5


Узкополосный широкополосник
******

Группа: Свой
Сообщений: 2 316
Регистрация: 13-12-04
Из: Moscow
Пользователь №: 1 462



Сами приводили ссылку на документацию:

Цитата
The IEEE 1149.7-2009 specification requires any device that functions as a Debug and Test System (DTS) to provide a pull-up bias on the TMS and TDO pins. In order to meet this requirement, the JTAG-HS2 features weak pull-ups (100K ohm) on the TMS, TDI, TDO, and TCK signals.
Go to the top of the page
 
+Quote Post
Gerret
сообщение Dec 18 2013, 06:11
Сообщение #6





Группа: Участник
Сообщений: 13
Регистрация: 3-04-07
Пользователь №: 26 736



Проверил по поводу отсутствия клоков во время "пилы", к сожалению они там есть:

Прикрепленное изображение

Прикрепленное изображение

Прикрепленное изображение

и какой уровень воспринимает JTAG в этих местах - совершенно не понятно... И не понятно, от чего такое получается, тот же программатор на покупной отладочной плате от Xilinx дает вполне нормальные сигналы без этих извращений.
Go to the top of the page
 
+Quote Post
Victor®
сообщение Dec 20 2013, 11:08
Сообщение #7


Lazy
******

Группа: Свой
Сообщений: 2 070
Регистрация: 21-06-04
Из: Ukraine
Пользователь №: 76



Цитата(Gerret @ Dec 18 2013, 09:11) *
Проверил по поводу отсутствия клоков во время "пилы", к сожалению они там есть:

Прикрепленное изображение

Прикрепленное изображение

Прикрепленное изображение

и какой уровень воспринимает JTAG в этих местах - совершенно не понятно... И не понятно, от чего такое получается, тот же программатор на покупной отладочной плате от Xilinx дает вполне нормальные сигналы без этих извращений.


Как-то так нехорошо наводится TCK на TDO судя по диаграмам.
Сравните схему со схемой фирменной отладки.


--------------------
"Everything should be made as simple as possible, but not simpler." - Albert Einstein
Go to the top of the page
 
+Quote Post
Raven
сообщение Dec 20 2013, 11:46
Сообщение #8


Местный
***

Группа: Свой
Сообщений: 491
Регистрация: 16-01-05
Из: Санкт-Петербург
Пользователь №: 1 987



Думаю, что вы не на том сосредоточились. Сосуществование активных тактов TCK и Z-state TDO - дело нормальное, такое будет встречаться, если : 1) TAP находится не в одном из двух состояний, когда он только и имеет право активно драйвить TDO (Shift-IR, Shift-DR); 2) с помощью TCK и TMS происходит перевод TAP'а из одного состояния в другое.

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

К тому же - раз через этот же интерфейс конфигурирование FPGA прошло хорошо, вряд ли есть проблемы на аппаратном уровне. Для начала я бы проверил, правильно ли сконфигурирована программная часть доступа к ARM TAP'у, там ли он ищется в цепочке согласно настройкам и т.д. Если есть теоретическая возможность установить контакт с этим TAP'ом (со штатными тулами, или через другие) без привязки к загрузке FPGA, или вообще как-то иначе - попробовал бы это.

Если все же подозреваете аппаратную проблему при доступе к ARM TAP'у - тогда нужно отслеживать и разглядывать опять-таки именно эти транзакции, а не конфигурирование FPGA, причем с начала, и трекая изменение состояния TAP'а (а значит, надо все входные сигналы протоколировать, а не только TCK).
Go to the top of the page
 
+Quote Post
_4afc_
сообщение Dec 20 2013, 13:23
Сообщение #9


Профессионал
*****

Группа: Свой
Сообщений: 1 262
Регистрация: 13-10-05
Из: Санкт-Петербург
Пользователь №: 9 565



Цитата(Gerret @ Dec 17 2013, 18:36) *
Для начала немного о системе:
1) Использован модуль Trenz TE0720.
2) JTAG к нему подключен на прямую.
3) Программатор Digilent HS2 rev. A


А разве можно напрямую подключить Digilent HS2 к Trenz TE0720?
По моему у них разъёмы не совпадают. Покажите фото как вы это сделали...

Была та же проблема на TDO с Spartan6 и HS1 - решилась укорочением переходника с 15см до 1см.


Go to the top of the page
 
+Quote Post

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

 


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


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