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

 
 
> LPC23xx. Опубликован новый errata, с багами Flash и MAM
Andy Mozzhevilov
сообщение Jun 26 2007, 10:06
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



а я уже успел пройтись по этим граблям.
Спасибо тебе Филипс за наше счастливое детство :-)


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
4 страниц V   1 2 3 > »   
Start new topic
Ответов (1 - 56)
Andy Mozzhevilov
сообщение Jun 27 2007, 05:11
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Andy Mozzhevilov @ Jun 26 2007, 16:06) *
а я уже успел пройтись по этим граблям.
Спасибо тебе Филипс за наше счастливое детство :-)


А неужели никто не сталкивался с этой проблемой MAM?
У меня выглядит это так в большинстве случаев.
Запускаю прогу, и она падает в data или prefetch abort.
Начинаю выяснять, откуда упала, нахожу адрес, ставлю до этого адреса брейкпоинт.
Запускаю снова, прога останавливает на брейкпоинте.
Дальше- если сделать RUN, то падаем в аборт.
Если пройти участок кода в отладчике пошагово, то все выполняется верно.
Поведение зависит, от того, что там неверно извлекается из флэш. Может упасть в аборт,
может просто неверно провести какие-то операции.
Так вот, вчера несколько походил по эти граблям, экспериментально и интуитивно начал играть с
настройками MAM. Помогло. Потом скачал свежую errata. Там рекомендовано делать MAMCR=1.
Сделал, был счастлив до сегодня. Сегодня получил и с MAMCR=1 аналогичные глюки.
Ушел на MAM=0, глюки исчезли. Но с MAM=0 это же не жизнь совсем, когда ядро на 60МГц молотит.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
Abo
сообщение Jun 27 2007, 05:25
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 101
Регистрация: 9-01-06
Пользователь №: 12 967



Цитата(Andy Mozzhevilov @ Jun 27 2007, 09:11) *
Сделал, был счастлив до сегодня. Сегодня получил и с MAMCR=1 аналогичные глюки.
Ушел на MAM=0, глюки исчезли. Но с MAM=0 это же не жизнь совсем, когда ядро на 60МГц молотит.


Столкнулся с тем же поведением.
Понижал тактовую аж до 42МГц. Помогало, но не всегда.
Решил померять напряжение питания ядра которое дает внутренний стабилизатор на ноге процессора - оно оказалось 1,5В, если запустить на частоте 60МГц.

На плате сделан отдельный источник 1,8В, подключил его. Проц стал работать стабильнее, мог работать даже на частоте 60МГц. Но все равно, нет нет да и выпрыгнет в аборт.

Вобщем затрахался я с этим чудом вражеской техники и решил отложить пока на пару месяцев в надежде на то что в будущем прояснится.

Но все же терзают меня смутные сомнения, что руки кривые. Ведь у starterkit.ru работает же.
Да и кейловская борда тоже по отзывам вроде фунциклирует.

Вобщем, ступор какой то.
Может вместе чего нароем?
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jun 27 2007, 05:45
Сообщение #4


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Abo @ Jun 27 2007, 11:25) *
Столкнулся с тем же поведением.
Понижал тактовую аж до 42МГц. Помогало, но не всегда.
Решил померять напряжение питания ядра которое дает внутренний стабилизатор на ноге процессора - оно оказалось 1,5В, если запустить на частоте 60МГц.

На плате сделан отдельный источник 1,8В, подключил его. Проц стал работать стабильнее, мог работать даже на частоте 60МГц. Но все равно, нет нет да и выпрыгнет в аборт.

Аборт аборту рознь. Нужно разбитаться в каждом конкретном случае.
В моем случае достаточно стабильно глючило и одинаково в пределах варианта сборки проекта.
Видимо, как карта ляжет. Также сборка проекта глючила на разных камнях одинаково.

Цитата
Вобщем затрахался я с этим чудом вражеской техники и решил отложить пока на пару месяцев в надежде на то что в будущем прояснится.

Но все же терзают меня смутные сомнения, что руки кривые. Ведь у starterkit.ru работает же.
Да и кейловская борда тоже по отзывам вроде фунциклирует.

Вобщем, ступор какой то.
Может вместе чего нароем?

Для начала нужно учесть известные баги, того же МАМ, а потом дальше разбираться.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
OVladimir
сообщение Jun 28 2007, 14:34
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 40
Регистрация: 10-01-07
Из: Вильнюс
Пользователь №: 24 290



У меня LPC2364 тоже выпрыгивал в дата аборт (48МГц), не стал глубоко копать, "отключил" МАМ и повысил до 64 МГц, с тех пор ни разу не видел дата аборт (звучит странно, но на 48МГц без МАМ "прыжки" наблюдались).
А вообще NXP как-то нам сказали что эту семью пока не будут продавать из-за множества ошибок (может это они только нам не будут).
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jul 5 2007, 14:10
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Jun 27 2007, 08:11) *
А неужели никто не сталкивался с этой проблемой MAM?

Эту проблему они запихнули во все errata! Поскольку остальные чипы используются уже много лет, то пожалуй глюк действительно редчайший. В многочисленных проектах на 2124-2138-2148-2294 чипах необоснованных падений не наблюдал ни разу. Скорее всего и у Вас причина не MAM 2.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
sensor_ua
сообщение Jul 6 2007, 03:27
Сообщение #7


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

Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387



На днях запускал плату на LPC2378 - тоже какие-то падения и т.п. как-будто были. Осмотрелся и нашёл - кварц в конфиге в 4 раза отличалсяот реального, джампер на RTCK не стоял, ну и какое-то прерывание от часов не запрещалwink.gif)) Ах, да, и поначалу версия Сеггера была слишком старая, которая просто не знала о 23-й серии 8-D, ну и кайла 3-11-го ещё не было...


--------------------
aka Vit
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 6 2007, 04:36
Сообщение #8


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(zltigo @ Jul 5 2007, 20:10) *
Эту проблему они запихнули во все errata! Поскольку остальные чипы используются уже много лет, то пожалуй глюк действительно редчайший. В многочисленных проектах на 2124-2138-2148-2294 чипах необоснованных падений не наблюдал ни разу. Скорее всего и у Вас причина не MAM 2.


Заметьте, что для 2124-2138-2148-2294 и для 23xx проблема, описанная с МАМ
разная. Для 21-22 рекомендуется work-around - включить MAMCR = 2
(оно так и сделано у меня в тех проектах и проблем я не наблюдаю). Причем проблему они относят к ревизиям силикона вплоть до B.
Может у меня datasheet старый:
Date:June 16, 2006
Document Release:
Version 1.6
Device Affected:LPC2138

В 23xx наоборот, рекомендуется частично включить MAM, MAMCR = 1.
Но у меня и с MAMCR = 1 глюки продолжались, пока не перевел его на MAMCR = 0.
В этом уверен, объяснения другого найти не могу. После MAMCR = 0 больше
аналогичных глюков не наблюдал.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jul 6 2007, 07:22
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Jul 6 2007, 07:36) *
Может у меня datasheet старый:
Date:June 16, 2006

Естественно, Вы же писали, что в новый errata внесли, а я ответил, что они на все чипы в новые
errata это внесли.
V1.2 для 2378 от 7 июня,
V1.5 для 2148 от 8 июня,
и
V1.7 для 2138 от 8 июня:

Цитата
Under certain conditions in MAM Mode 2 code execution out of internal Flash can fail.
Introduction: The MAM block maximizes the performance of the ARM processor when it is running code in Flash memory. It includes three 128-bit buffers called the Prefetch Buffer, the Branch Trail Buffer and the data buffer. It can operate in 3 modes; Mode 0 (MAM off), Mode 1 (MAM partially enabled) and Mode 2 (MAM fully enabled).
Problem:Under certain conditions when the MAM is fully enabled (Mode 2) code execution from internal Flash can fail. The conditions under which the problem can occur is dependent on the code itself along with its positioning within the Flash memory.
Workaround: If the above problem is encountered then Mode 2 should not be used. Instead, partially enable the MAM using Mode 1.


Совпадают полностью, до последней буквы.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 6 2007, 07:31
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(zltigo @ Jul 6 2007, 13:22) *
Естественно, Вы же писали, что в новый errata внесли, а я ответил, что они на все чипы в новые
errata это внесли.
V1.2 для 2378 от 7 июня,
V1.5 для 2148 от 8 июня,
и
V1.7 для 2138 от 8 июня:
Совпадают полностью, до последней буквы.


Мля. На сайте NXP на видном месте лежит только старый. Поиском находится тоже только 1.6
Можно ссылку или сюда выложить?


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jul 6 2007, 07:37
Сообщение #11


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Jul 6 2007, 10:31) *
Можно ссылку или сюда выложить?

Все документы на все чипы берутся тут:
http://www.standardics.nxp.com/products/mc...1&zoom=none


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 6 2007, 07:59
Сообщение #12


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(zltigo @ Jul 6 2007, 13:37) *
Все документы на все чипы берутся тут:


Спасибо за ссылку.
Теперь внимательно изучаем смысл документа.
Эти м...ки при попытке коррекции фичи MAM.1 в ревизии A и B наваляли дохрена так,
что получили фичу MAM.2 в ревизиях C и D.
Если для обхода MAM.1 рекомендовалось включить MAMCR = 2,
то теперь для обхода MAM.2 рекомендуются включить MAMCR = 1,
хотя реально на 2368 у меня и при MAMCR = 1 наблюдались глюки.
то есть реально надо сделать MAMCR = 0.
При этих условиях будет действовать MAM.1 в ревизиях A и B.
MAM.1 судя по описанию достаточно редкая фишка, и лечится наоборот
включением MAM на полную. А вот чтобы наступить на MAM.2 мне, много времени
не понадобилось.
Получаем ситуацию:
Если в проектах на ревизиях A и B юзается MAMCR=2 (а он юзается) а также возможно и MAMCR=1,
то при установке чипов ревизий C и D в те проекты мы огребаем по полной.
Выключая MAM по багу MAM.2 мы теряем в скорости выполения раз до 4-5, это существенно и
в некоторых проектах может быть критичным. То есть использование C и D ревизий в них
становится невозможным, а A и B не уверен что выпускаются, да и как их заказывать.
Мля, трындец. Это серьезно.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
3.14
сообщение Jul 6 2007, 10:23
Сообщение #13


Их либе дих ...
******

Группа: СуперМодераторы
Сообщений: 2 010
Регистрация: 6-09-04
Из: Russia, Izhevsk
Пользователь №: 609



Не понял, в еррате от 7 июня нет упоминания о B C D ревизиях ...


--------------------
Усы, борода и кеды - вот мои документы :)
Go to the top of the page
 
+Quote Post
sensor_ua
сообщение Jul 6 2007, 10:24
Сообщение #14


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

Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387



Просьба ткнуть в расшифровку версионности. А то таких букв, как A, B, C, D, указанных явно, в маркировке не попадалось


--------------------
aka Vit
Go to the top of the page
 
+Quote Post
3.14
сообщение Jul 6 2007, 10:32
Сообщение #15


Их либе дих ...
******

Группа: СуперМодераторы
Сообщений: 2 010
Регистрация: 6-09-04
Из: Russia, Izhevsk
Пользователь №: 609



Смотрите третью страницу ...


--------------------
Усы, борода и кеды - вот мои документы :)
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 6 2007, 10:36
Сообщение #16


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(3.14 @ Jul 6 2007, 16:23) *
Не понял, в еррате от 7 июня нет упоминания о B C D ревизиях ...

Ревизии B C D относятся к LPC2138 (ну и все прочие 213x),
Date:June 8 2007
Document Release:Version 1.7
Device Affected:LPC2138

плюс все прочие семейства LPC видимо имеют свою errata на этот счет.
В этом то и заключается особая дерьмоватость ситуации.
Если 2368 чип свеженький, и в новые проекты массово вряд ли у кого то не идет,
то все остальные то трудятся уже давненько. И что теперь с теми проектами делать?


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
3.14
сообщение Jul 6 2007, 10:44
Сообщение #17


Их либе дих ...
******

Группа: СуперМодераторы
Сообщений: 2 010
Регистрация: 6-09-04
Из: Russia, Izhevsk
Пользователь №: 609



Я поумал Вы про LPC23хх ...
Зачем что-то делать со старывми проектами, которые давно трудятся?


--------------------
Усы, борода и кеды - вот мои документы :)
Go to the top of the page
 
+Quote Post
sensor_ua
сообщение Jul 6 2007, 10:50
Сообщение #18


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

Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387



У меня 2378-е с ревизией Y - надпись не попадает в формат со стр.3 -
ZSG0646-Y
Как бы узнать какая эррата на них распространяется?wink.gif)


--------------------
aka Vit
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 6 2007, 10:56
Сообщение #19


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(3.14 @ Jul 6 2007, 16:44) *
Я поумал Вы про LPC23хх ...
Зачем что-то делать со старывми проектами, которые давно трудятся?


И правда зачем? Я бы и не притронулся.
Я пытался объяснить выше суть проблемы.
Короче, во всех ревизиях LPC с добавленной проблемой MAM.2
нельзя исключать ситуации, когда старая работающая программа
в старых проектах на старых чипах перестанет работать.





Кстати, почитал свой архив форума на lpc2000@yahoogroups.com
Там эту проблему начали обсуждать в начале мая.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jul 7 2007, 07:55
Сообщение #20


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Jul 6 2007, 10:59) *
что получили фичу MAM.2 в ревизиях C и D.
Если для обхода MAM.1 рекомендовалось включить MAMCR = 2,
то теперь для обхода MAM.2 рекомендуются включить MAMCR = 1,

Да,уж.... Хотя по MAM.1 может MAMCR=2 как-то всуе помянуто smile.gif.
А MAM.2 это нет слов sad.gif
Девайсы которые сейчас в отладке на 2138 практически все ревизии 'C' - проблем с падением не наблюдал. Пока в процесе работы буду так испытывать, ну а вообще придется разные bootloader-ы сделать и убрать переинициализацию из основной программы, но потеря производительности это тоскливо очень.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Цырен
сообщение Jul 10 2007, 08:49
Сообщение #21


Частый гость
**

Группа: Validating
Сообщений: 184
Регистрация: 26-06-07
Из: Санкт-Петербург
Пользователь №: 28 714



Недавно собрали плату на LPC2364 с ревизией Y. Дата выпуска микроконтроллера - 1-я неделя этого года. Сначала не мог всосать почему мой код виснет в стартапе... Потом подробно наблюдал ассемблерный код...виснет в бесконечном цикле в обработчике data abort! Так собственно вопрос: что же мне настройку MAMRC делать еще до инициализации стэков? Ведь проц входит в состояние DataAbort еще до того, как начнется функция настройки системной периферии. 07.gif
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 10 2007, 08:55
Сообщение #22


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Цырен @ Jul 10 2007, 14:49) *
Недавно собрали плату на LPC2364 с ревизией Y. Дата выпуска микроконтроллера - 1-я неделя этого года. Сначала не мог всосать почему мой код виснет в стартапе... Потом подробно наблюдал ассемблерный код...виснет в бесконечном цикле в обработчике data abort! Так собственно вопрос: что же мне настройку MAMRC делать еще до инициализации стэков? Ведь проц входит в состояние DataAbort еще до того, как начнется функция настройки системной периферии. 07.gif


Все критические настройки можно сделать в low_level_init
Но по ресету MAM выключается. Вряд ли у вас ситуация, связанная с багом MAM.
Посмотрите, откуда он падает в исключение, дальше дело техники найти причину.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jul 10 2007, 10:10
Сообщение #23


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Jul 10 2007, 11:55) *
Все критические настройки можно сделать в low_level_init

Это уже для вызова стек должен быть.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jul 10 2007, 10:15
Сообщение #24


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(zltigo @ Jul 10 2007, 16:10) *
Это уже для вызова стек должен быть.


Да, стек есть, но это ничему не мешает.
Потом стек юзается уже в самой low_level_init() если она так написана.
Если ее написать на асме, то можно обойтись без использования стека, но это, имхо,
не нужно, в контексте MAM.2


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
Цырен
сообщение Jul 10 2007, 10:54
Сообщение #25


Частый гость
**

Группа: Validating
Сообщений: 184
Регистрация: 26-06-07
Из: Санкт-Петербург
Пользователь №: 28 714



Эту проблему я подробно описал здесь http://electronix.ru/forum/index.php?showt...970&hl=2364
Go to the top of the page
 
+Quote Post
HARMHARM
сообщение Sep 11 2007, 17:48
Сообщение #26


читатель даташитов
****

Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999



Пролистывал LPC23xx/24xx Example Software для Keil, и наткнулся на фразу:
Цитата
(1) Due to the MAM fix and User Manual Update, CCO divider with
the odd number for CCLK is no longer allowed. Update PLL setting
example accordingly.

В errata для LPC2368 такое описание бага MAM.1:
Цитата
MAM.1: Under certain conditions in MAM Mode 2 code execution out of internal Flash can fail.Introduction: The MAM block maximizes the performance of the ARM processor when it is running code in Flash memory. It includes three 128-bit buffers called the Prefetch Buffer, the Branch Trail Buffer and the data buffer. It can operate in 3 modes; Mode 0 (MAM off), Mode 1 (MAM partially enabled) and Mode 2 (MAM fully enabled).Problem:Under certain conditions when the MAM is fully enabled (Mode 2) code execution from internal Flash can fail. The conditions under which the problem can occur is dependent on the code itself along with its positioning within the Flash memory. Workaround: If the above problem is encountered then Mode 2 should not be used. Instead, partially enable the MAM using Mode 1.

Не значит ли это, что проблемы с MAM возникали при установке нечетного CCO divider, и про этот баг можно забыть? У кого-нибудь получалось достоверно воспроизвести этот глюк с выпадением в Data Abort? Может быть, стоит провести эксперимент с MAM=2 и нечетным CCOdiv...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Sep 11 2007, 19:28
Сообщение #27


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(HARMHARM @ Sep 11 2007, 20:48) *
при установке нечетного CCO divider

Не совсем однозначно можно понять, что кейловцы называют "CCO Divider", но у меня "делитель" записываемый в PLLCFG '1', что с другой строны соответствует делению на 2. Множитель соответственно '3' = 4. Проблем, как уже писал, не наблюдал и не наблюдаю.
Действительно интересно, какие множитель/делитель у тех у кого они есть.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Sep 12 2007, 03:03
Сообщение #28


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(zltigo @ Sep 12 2007, 01:28) *
Не совсем однозначно можно понять, что кейловцы называют "CCO Divider", но у меня "делитель" записываемый в PLLCFG '1', что с другой строны соответствует делению на 2. Множитель соответственно '3' = 4. Проблем, как уже писал, не наблюдал и не наблюдаю.
Действительно интересно, какие множитель/делитель у тех у кого они есть.


у меня
Код
        PLLCFG = (72-1) | ((5-1) << 16);   /* FCCO = 288 MHz */


то есть в делитель записано значение 4, что соответствует делению на 5.
сейчас нет под рукой плат тех устройств, скоро должны подойти, обязательно попробую.


Есть более новая errata от 20 июля, там действительно говорится о том, что нельзя использовать четное значение для регистра CCLKSEL.
У меня сделано
Код
        CCLKCFG = (5-1);                  /* Set clock divider */

то есть как раз четное.
но в erreta филипсовцы не связали этот баг с МАМ, а добавили его в баг Flash.1
Но проверить все же стоит


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Sep 12 2007, 06:20
Сообщение #29


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Sep 12 2007, 06:03) *
Но проверить все же стоит

Ждем.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
HARMHARM
сообщение Sep 12 2007, 09:01
Сообщение #30


читатель даташитов
****

Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999



Цитата
У меня сделано
Код
        CCLKCFG = (5-1);                  /* Set clock divider */

А это то значение, при котором возникали проблемы, или новое - найденное путем проб и ошибок?
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Sep 12 2007, 09:57
Сообщение #31


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(HARMHARM @ Sep 12 2007, 15:01) *
А это то значение, при котором возникали проблемы, или новое - найденное путем проб и ошибок?

это пока то, с которым были проблемы



Цитата(Andy Mozzhevilov @ Sep 12 2007, 15:04) *
это пока то, с которым были проблемы


взял устройство на 2368, пока так вот влоб при включении МАМ свалить в аборт его не удалось,
видимо раз на раз не приходится и зависит как там карта в памяти ляжет.
Соответственно нет смысла и пробовать менять делитель тактовой.
Как буду работать в следующий раз с этим устройством, включу МАМ по полной, и как начнет глючить, буду экспериментировать с делителем.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
HARMHARM
сообщение Sep 19 2007, 11:30
Сообщение #32


читатель даташитов
****

Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999



Цитата(Andy Mozzhevilov @ Sep 12 2007, 12:57) *
это пока то, с которым были проблемы
взял устройство на 2368, пока так вот влоб при включении МАМ свалить в аборт его не удалось,
видимо раз на раз не приходится и зависит как там карта в памяти ляжет.
Соответственно нет смысла и пробовать менять делитель тактовой.
Как буду работать в следующий раз с этим устройством, включу МАМ по полной, и как начнет глючить, буду экспериментировать с делителем.

В конференции lpc2000 на yahoo.com накопал тестовый проект для издевательств над MAM (под GCC), прилагаю.
* Ошибся, файл прибит.

Сообщение отредактировал HARMHARM - Sep 20 2007, 07:21
Go to the top of the page
 
+Quote Post
zltigo
сообщение Sep 19 2007, 14:47
Сообщение #33


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(HARMHARM @ Sep 19 2007, 14:30) *
тестовый проект для издевательств над MAM (под GCC), прилагаю.

Не знаю, не знаю, над чем или кем этот "Hello World" издевается. Ссылку на сообщение дайте.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
HARMHARM
сообщение Sep 20 2007, 07:20
Сообщение #34


читатель даташитов
****

Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999



Похоже я ошибся, файл прибил. Ссылка.
Go to the top of the page
 
+Quote Post
Velund
сообщение Sep 23 2007, 13:28
Сообщение #35


Знающий
****

Группа: Свой
Сообщений: 693
Регистрация: 19-11-04
Пользователь №: 1 177



А кто нибудь с ревизией А чипов LPC2368 уже имел дело?
Go to the top of the page
 
+Quote Post
zltigo
сообщение Oct 26 2007, 07:31
Сообщение #36


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Sep 12 2007, 12:57) *
Как буду работать в следующий раз с этим устройством, включу МАМ по полной, и как начнет глючить, буду экспериментировать с делителем.

Ну так чем все это кончилось/продолжилось? У меня проблема так и не проявилась.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
shahr
сообщение Oct 26 2007, 07:54
Сообщение #37


Частый гость
**

Группа: Участник
Сообщений: 128
Регистрация: 6-06-06
Из: Москва
Пользователь №: 17 793



Цитата(zltigo @ Oct 26 2007, 11:31) *
Ну так чем все это кончилось/продолжилось? У меня проблема так и не проявилась.


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


--------------------
wbw
shahr
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Oct 26 2007, 08:42
Сообщение #38


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



На LPC2134 с ревизией С пока проблем не наблюдаем.
На LPC2364 отлаживаю тестовый проектик с USB, пока не проявляется.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Oct 26 2007, 09:36
Сообщение #39


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(shahr @ Oct 26 2007, 10:54) *
можно забыть.

Да-уж. "Посоветовали". Напомню, что поминаемый баг описан ДЛЯ ВСЕХ СВЕЖИХ РЕВИЗИЙ LPC2000 и является свежеприобретенным для, например, LPC213x/4x. Я должен в свою очередь производителям своего оборудования посоветовать "забыть", выкинуть наработанное, дождаться (уже с некоторым трепетом ожидая новых проблем) новых ревизий при этом призывая своих заказчиков "забыть" о своем существовании. А куда денут поставщики "неправильные" ревизии? Выкинут в мусорник и "забудут"? Нет, будут продолжать распихивать. В общем "забыть" может позволить себе только NXP - он большой, ему можно. Очень хотелось бы получить от NXP вместо "Under certain conditions..l" что-то более конкретное о возникновении проблемы и соответственно менее "радикальное" решение проблемы, нежели не пользоваться MAM 2, особенно хорошо смотрящимся в сочетании с предыдущим советом не пользоваться MAM 0 и MAM 1 smile.gif и невозможностью определить ревизию чипа иначе, чем рассматривая литеры на корпусе.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Alechek
сообщение Oct 26 2007, 17:18
Сообщение #40


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



Я вот одного не понял, ну Data Abort, ну не получилось с первого раза флешину считать..
Разве нельзя выйти из Обработчика и продолжить работу дальше? Со второй попытки то должно считаться!
Go to the top of the page
 
+Quote Post
zltigo
сообщение Oct 26 2007, 17:25
Сообщение #41


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Alechek @ Oct 26 2007, 20:18) *
Со второй попытки то должно считаться!

Да? Со второй?
Это кто Вам сообщил условия возникновения и степень повторяемости эффекта smile.gif?
Да и Data Abort тут совсем случаен, ибо последствия :
Код
code execution from internal Flash can fail.

вообще не предсказуемы.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Alechek
сообщение Oct 27 2007, 10:02
Сообщение #42


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



Да, тут я не прав. Data Abort скорей всего случайность.
Вполне может быть и Undefined Instruction.
Я поначалу на этот баг тоже наступал. Правда это было Полтора года назад. JTAG у меня не было, но выяснил, что программа падала после того, как я поторогаю МАМ.
Все устаканилось лишь после того, как я прописал его инициализацию в cstartup.s79, причем сначала устанавливал режим 0, Потом тайминг (3) и режим работы 2.
Точно уже не помню, но вроде если вначале не ставить режим 0, то программа падала.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Oct 27 2007, 11:32
Сообщение #43


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Alechek @ Oct 27 2007, 13:02) *
Правда это было Полтора года назад...

Полтора года назад этого бага не было. Совсем не было. Это баг появившийся летом этого года, видимо при коррекции старого, почти безобидного бага лечащегося инициализацией MAM до момента доступа к RAM.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Alechek
сообщение Oct 29 2007, 06:38
Сообщение #44


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



С каких пор этот баг является для 214х свежеприобретенным?
считаю что он все-таки свежеобнаруженный.

LPC2148 Erratasheet 1.6
Код
Functional Problem Short Description                 Errata occurs in device revision
MAM.1              Incorrect read of data from SRAM                   -
MAM.2              Code execution failure can occur with MAM Mode 2   -, A
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Oct 29 2007, 06:59
Сообщение #45


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Alechek @ Oct 29 2007, 11:38) *
С каких пор этот баг является для 214х свежеприобретенным?
считаю что он все-таки свежеобнаруженный.

LPC2148 Erratasheet 1.6
Код
Functional Problem Short Description                 Errata occurs in device revision
MAM.1              Incorrect read of data from SRAM                   -
MAM.2              Code execution failure can occur with MAM Mode 2   -, A


Этот баг явно добавлен при коррекции бага МАМ.1
Явно это прослеживается во всех errata на все LPC.
Потом филипки подправили errata так, что типа "ой, этот баг был и везде в других ревизиях, просто не обнаруживался".
Чушь. Для МАМ.1 и для МАМ.2 даны взаимоисключающие workaround. То есть все прошлые ревизии вообще не должны были работать. А для серии 213х - это ревизии "-", "А", "В". И выпускались они неверное пару лет, а то и более. И вот ведь совпадение, никто этого бага не заметил на них.
А где-то в начале этого года вдруг обнаружился, и на ревизиях именно с коррекцией бага МАМ.1.
В буржуйсной конфе по LPC этот вопрос усилинно муссировался где-то в мае.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Oct 29 2007, 07:05
Сообщение #46


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Andy Mozzhevilov @ Oct 29 2007, 09:59) *
Потом филипки подправили errata так, что типа "ой, этот баг был и везде в других ревизиях, просто не обнаруживался".

Моя память тоже говорит мне именно о таком развитии событий - надо взглянуть на предыдущий V1.5.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
ГУ-49А
сообщение Feb 22 2008, 18:28
Сообщение #47


Участник
*

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



Цитата(3.14 @ Nov 24 2006, 13:31) *
Изучаю доку на LPC23XX.
Не понятно с досупом к флешке.
Смутило меня следующее :Насколько я понимаю, во избежание циклов ожидания надо иметь один такт доступа до флешки (128 бит) к четырем тактам ядра, тогда зачем усложнять ... мксаимальная частота 72М -> указывать MAMTIM=4 и в путь, и зачем задается по умолчанию MAMTIM=7 ?


Чтоб новую тему не заводить, напишу здесь. Недавно столкнулся со "знаменитым" глюком MAM'а на одном из своих LPC2103 (MAM=2, MAMTIM=3, частота 70 MHz (10x7)). При чтении из флеша (простой ldr) прошивка падала, в строго определённые моменты времени (в другие моменты времени читалось оттуда нормально). Причём, при небольшом изменении кода (последовательности выполнения нескольких команд, не влияющей на вычисления) проблема исчезала (естественно, при отключении MAM тоже всё работало), воспроизводимость 100%. Дык вот, вместо того, чтобы традиционно снизить частоту, уменьшить MAM до 1 или вовсе его отключить, я попробовал увеличивать MAMTIM. Сначала до 4-х. Глюк исчез, но, как оказалось, не полностью: он вылез в другом месте кода. И только когда я установил MAMTIM=5, всё заработало как надо! Так что большие значения MAMTIM иногда приносят пользу. Вот такая история...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 19:21
Сообщение #48


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(ГУ-49А @ Feb 22 2008, 21:28) *
(MAM=2, MAMTIM=3, частота 70 MHz (10x7))

Остальные настройки, например PLL? Проверить при четных делителях частоты с PLL сможете?


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
StupidGuru
сообщение Feb 22 2008, 19:30
Сообщение #49





Группа: Новичок
Сообщений: 3
Регистрация: 22-02-08
Пользователь №: 35 298



Цитата(ГУ-49А)
Недавно столкнулся со "знаменитым" глюком MAM'а на одном из своих LPC2103 (MAM=2, MAMTIM=3, частота 70 MHz (10x7)).
А разве так можно? 70 МГц / 3 = 23, о скорость флэша вроде всего 20 МГц.
Go to the top of the page
 
+Quote Post
ГУ-49А
сообщение Feb 22 2008, 19:57
Сообщение #50


Участник
*

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



Цитата(zltigo @ Feb 22 2008, 21:21) *
Остальные настройки, например PLL? Проверить при четных делителях частоты с PLL сможете?


А у меня и так чётный: MSEL=6, PSEL=1 (т.е. div=2), кварц 10 МГц. На других значениях, к сожалению, не пробовал (но, кажется, пробовал вообще без PLL - всё работало).

Цитата(StupidGuru @ Feb 22 2008, 21:30) *
А разве так можно? 70 МГц / 3 = 23, о скорость флэша вроде всего 20 МГц.


Цитата из manual для 2103: "while in systems with system clock faster than 40 MHz, 3 CCLKs are proposed.", т.е. если следовать "букве закона", то можно. И, в общем-то, на простых задачах работает, похоже, на пределе. А вот при MAMTIM=5 никаких проблем вообще не замечено. Вообще, есть чувство, что где-то что-то иногда не успевает...
Go to the top of the page
 
+Quote Post
brag
сообщение Feb 22 2008, 20:02
Сообщение #51


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

Группа: Свой
Сообщений: 1 047
Регистрация: 2-12-06
Из: Kyiv, Ukraine
Пользователь №: 23 046



сижу,читаю,и вспомнил,что когда-то,года 3 на зад у меня были непонятные prefetch і data abortы в LPC2106... Видимо тоже на это натыкался..не помню конкретно,что делал, помню, только, что были пляски с бубном,типа втыкал куда-то(не помню куда) инструкцции типа, mov r0,r0
Помню точно,что мам был 2 и частота 75мгц(немного оверклокнул)
Go to the top of the page
 
+Quote Post
StupidGuru
сообщение Feb 22 2008, 20:09
Сообщение #52





Группа: Новичок
Сообщений: 3
Регистрация: 22-02-08
Пользователь №: 35 298



Цитата(ГУ-49А)
Цитата из manual для 2103: "while in systems with system clock faster than 40 MHz, 3 CCLKs are proposed.",
Ну дык! У них же документация постоянно кривая, а точнее древняя, унаследованная от предшественников типа LPC2104..6 или LPC213x, у которых рабочая частота была официально ограничена 60 МГц. Поэтому там стоит циферка 3. А на самом деле должна быть 4. Так что это не бага. А вот почему на 4-ех тоже глючит, а на 5 уже нет - это вопрос интересный.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 20:53
Сообщение #53


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(StupidGuru @ Feb 22 2008, 23:09) *
Ну дык! У них же документация постоянно кривая...

Тем не меннее для всех, в том числе и 72MHz моделей в документации уже много лет указывается всего 3ws и работает, хотя с точки зрения "здравого смысла" продолжая ряд ws должно быть 4ws после 60 MHz. Это если 50ns FLASH, а если, например 45ns или чуть поменее?


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
brag
сообщение Feb 22 2008, 21:02
Сообщение #54


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

Группа: Свой
Сообщений: 1 047
Регистрация: 2-12-06
Из: Kyiv, Ukraine
Пользователь №: 23 046



ну если учитывать,что все(почти) можно разогнать, то должно и на 3 работать.. я не помню уже, у меня вроде даже на 2 заводилось на 60мгц.давно дело было
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 21:11
Сообщение #55


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(brag @ Feb 23 2008, 00:02) *
ну если учитывать,что все(почти) можно разогнать

Ну явно разгонять это последнее дело. Не стоит.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
meister
сообщение Feb 22 2008, 21:24
Сообщение #56


Местный
***

Группа: Участник
Сообщений: 219
Регистрация: 20-11-07
Пользователь №: 32 484



Цитата(zltigo @ Feb 22 2008, 23:53) *
Это если 50ns FLASH, а если, например 45ns или чуть поменее?


Где можно посмотреть время доступа к флэш? В даташите и юзермануале нету.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 22:31
Сообщение #57


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(meister @ Feb 23 2008, 00:24) *
Где можно посмотреть время доступа к флэш? В даташите и юзермануале нету.

Нету,но ws для диапазона рабочих частот документированы. Вариант верить, или нет smile.gif


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post

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

 


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


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