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

 
 
> SIM900: кривая реализация I2C для Embedded AT
HDL
сообщение Sep 16 2013, 12:12
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 21
Регистрация: 16-09-13
Пользователь №: 78 342



Печально, но %сабж%.
Вызов транзакции по I2C шине, например такой (взят из примера):
ebdat15_07I2C_PUT_DATA(pTransfer);
из обработчика событий в EAT приложении зависает, если устройство с заданным I2C адресом не ответило ACK-ом на SLA-R/W. Модем висит несколько секунд до самого ребута по вотчдогу.
Зависание происходит на втором по счету обращении, если на первое получен NACK, причем наличие ACK на втором обращении ни на что не влияет.
Прошивку дизасмил, нашел и рассмотрел почти все процедуры и2ц, но патч придумать сходу не удалось.

Скажите, насколько реально добиться от китайцев соответствующего фикса? Как и куда обращаться?
Может кто-нибудь сталкивался с этой проблемой?
На форуме ничего такого не обсуждалось? (Поиском не нашел.)

Спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Romashki
сообщение Sep 18 2013, 09:43
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 209
Регистрация: 5-12-10
Пользователь №: 61 419



"...А если выключать инты ..." это как?
Go to the top of the page
 
+Quote Post
HDL
сообщение Sep 20 2013, 20:18
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 21
Регистрация: 16-09-13
Пользователь №: 78 342



Цитата(Romashki @ Sep 18 2013, 12:43) *
"...А если выключать инты ..." это как?

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

Провел некоторые эксперименты.
Задача: сформировать сигналы на ГПИО из пользовательской процедуры с заданными программными задержками, определить:
- факт вклинивания в процедуру вызовов ядра (по изменению задержек),
- кол-во тактов проца на одну итерацию цикла задержки.
В качестве измерителя использовал альтерный ТАР с частотой сэмплирования 3,125МГц.

Код рабочей процедуры:
Код
ebdat6_04WriteGpio(PIN, TRUE);
fl_wait(1);
ebdat6_04WriteGpio(PIN, FALSE);
fl_wait(1);
ebdat6_04WriteGpio(PIN, TRUE);
fl_wait(10);
ebdat6_04WriteGpio(PIN, FALSE);
fl_wait(10);
ebdat6_04WriteGpio(PIN, TRUE);
fl_wait(100);
ebdat6_04WriteGpio(PIN, FALSE);
fl_wait(100);
ebdat6_04WriteGpio(PIN, TRUE);
fl_wait(1000);
ebdat6_04WriteGpio(PIN, FALSE);
fl_wait(1000);
ebdat6_04WriteGpio(PIN, TRUE);


Код задержкера:
С:
Код
void fl_wait(int n)
{
    volatile v;
    while (n--) v;
}

Дизасм:
Код
ROM:904005C4 fl_wait                        ; CODE XREF: fl_entry+112j
ROM:904005C4                 SUBS    R0, R0, #1
ROM:904005C6                 BCS     fl_wait
ROM:904005C8                 BX      LR


Снятый график:
http://i.snag.gy/QvNTY.jpg
Актуален сигнал SDA (названия сигналов остались от предыдущих экспериментов).

Картинку наблюдал визуально в режиме Autorun analysis в течение примерно 5 минут. При этом звонил на модем, принимал и отправлял СМС.

Резалты:
Кол-во итераций: 1, 10, 100, 1000
Задержка в отсчетах 3,125МГц: 16, 39, 256, 2416.
Средняя задержка на итерацию в отсчетах 3,125МГц: 2.4
Средняя задержка на итерацию в тактах 156МГц: 120 (!!!)

Выводы:
- все задержки имеют постоянную величину и не прыгают рандомно,
- количество тактов на 2 команды тхумба 120, что зашкаливает мое понимание этой жизни, если конечно ядро не сбрасывает частоту АРМа при входе в ЕАТ процедуры (как раз для экономии батарейки).

Еще поснимал логи работы китайского встроенного I2C:
работает чотко по двум сценариям:

ebdat15_07I2C_GET_DATA():
START
SLA-W
Send DATA (pTransfer->txDataSize bytes)
RSTART
SLA-R
Receive DATA (pTransfer->rxDataSize bytes)
STOP

Ну и ebdat15_07I2C_PUT_DATA() - наоборот.

Т.е. для кастомного сценария обмена по шине не пригодно.

Сообщение отредактировал HDL - Sep 20 2013, 20:19
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- HDL   SIM900: кривая реализация I2C для Embedded AT   Sep 16 2013, 12:12
- - Romashki   Я пробовал с пиком по I2C "общаться" (на...   Sep 17 2013, 06:05
|- - HDL   Цитата(Romashki @ Sep 17 2013, 09:05) Нап...   Sep 17 2013, 12:04
|- - Frolov Kirill   Софтовый I2C будет сильно греть CPU и жрать батаре...   Sep 18 2013, 11:33
- - HDL   UPDATE Иногда (редко, но факт) все-таки происходят...   Sep 21 2013, 01:48
- - CADiLO   >>>Следовательно, такие протоколы как 1-w...   Sep 23 2013, 06:44
- - HDL   О, спасибо, почитаю.   Sep 23 2013, 12:23
- - Romashki   Подскажите, где можно скачать эти документы: -RTK-...   Oct 1 2013, 13:54
|- - HDL   Цитата(Romashki @ Oct 1 2013, 16:54) Подс...   Oct 12 2013, 01:18
- - CADiLO   Наверно у нас Гугли разные Поэтому гугль > ки...   Oct 1 2013, 14:04
|- - HardEgor   Вообще I2C тактируемый протокол и для слэйвов можн...   Oct 1 2013, 15:55
- - Romashki   Подскажите, кто нибудь проверял в ЕАТ скоростя по ...   Oct 12 2013, 08:01
- - HDL   А покажи пожалуйста свой код - соберу и проверю у ...   Oct 12 2013, 10:57
- - Romashki   ebdat7_00EnterDebugMode(); ebdat9_03SetModemdata...   Oct 12 2013, 12:11
- - Romashki   Разобрался! У меня на этом порту стоит ADM485 ...   Oct 13 2013, 05:44
|- - GeGeL   Цитата(Romashki @ Oct 13 2013, 08:44) У м...   Oct 13 2013, 19:44
- - HDL   Да, собсно в коде инициализации я ниче такого и не...   Oct 13 2013, 13:44
- - Romashki   В принципе можно поставить adm с автоопределением ...   Oct 14 2013, 05:36


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

 


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


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