|
<AT+CIICR> + <RING> + <SIM300C> = ГЛЮК, Модем странно себя ведёт |
|
|
|
Nov 4 2008, 18:18
|
Участник

Группа: Новичок
Сообщений: 37
Регистрация: 15-10-08
Из: Одесса, Украина
Пользователь №: 40 978

|
В своем посте " Краткий курс по TCP/IP" я писал про три чудо команды AT+CSTT, AT+CIICR, AT+CIFSF и про глючно работающую AT+CIPSHUT. На горьком опыте убедился, что одна из чудо команд так же имеет особенность. Заметил, что если после посылки AT+CIICR поступает входящий звонок, то модем: 1) в упор отказывается присылать ответ на AT+CIICR, пока есть входящий звонок 2) пока есть входящий звонок - лезут сообщения RING, а любые команды посылаемые модему игнорируются. Получается, что если кто-то дозвонился после посылки команды AT+CIICR и до приёма ответа на эту команду - то надо ждать пока на той стороне положат трубку. На нашей стороне нельзя ни отклонить ни принять звонок. Отдалённо я понимаю, что эти модемы не мультизадачны, но должен же быть какой-то выход из этой ситуации? Может хотя бы можно поставить ограничение на количество RING, после которых, если трубка не снимается, то модем сам выполняет ATH. Это конечно не решает проблему, но хотя бы сокращает время "зависания" модема. Для лучшего понимания приведу лог. Лог реальный! CTRL+C, CTRL+V из окна терминала (кроме коментов кончено): AT+CSTT="WWW.UMC.UA" OK AT+CIICR RING RING //в этот момент посылаю ATH первый разRING //в этот момент посылаю ATH второй разRING RING RING NO CARRIER //положил на другой стороне трубку+PDP: DEACT //модем ожил и вспомнил, что выполняет команду CIICRATH //получаю эхо на посланную первый раз ATHERROR //ответ на первый ATHATH //получаю эхо на посланную второй раз ATHOK //ответ на второй ATH
Сообщение отредактировал david_off - Nov 4 2008, 19:00
|
|
|
|
|
 |
Ответов
|
Nov 5 2008, 21:51
|

Просто Che
    
Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881

|
Есть парочка соображений: - конечно, SIM300 являет собой GPRS mobile station class B, которая не обязана уметь одновременно работать с GPRS и голосовой связью. Но все-таки разруливание задач в нем явно сделано криво и многие вещи на совести разработчиков. Все же поглядите на версию ПО вашего экземпляра модема, может она старая, и есть новее с кучей исправлений; - кроме применяемой вами группы команд, в SIM300 есть и другие варианты выполнения того же самого. Поглядите здесь. Я сам применяю первый вариант, там по сути две команды, первая из которых, AT+CIPCSGP, из модема не вылазит (настраивает параметры в самом модеме). А вторая, AT+CIPSTART, автоматически обеспечивает все действия, необходимые для подключения. Может быть такой вариант будет менее глючным; - ещё я не совсем понял стремление разрулить эту ситуацию в модеме как можно быстрее. Почему нельзя просто подождать окончания звонков и установить тайм-аут ожидания корректного ответа на предыдущую команду побольше (минуты две)? Или у вас задача требует скоростных решений? А то любая модемная связь в плане быстроты соединений оч-ч-чень нетороплива.
|
|
|
|
|
Nov 6 2008, 17:04
|
Участник

Группа: Новичок
Сообщений: 37
Регистрация: 15-10-08
Из: Одесса, Украина
Пользователь №: 40 978

|
Цитата(Baser @ Nov 6 2008, 01:51)  поглядите на версию ПО вашего экземпляра модема, может она старая, и есть новее с кучей исправлений; Прошивка 12 - самая новая из доставаемых. Теоритически есть 14, но это пока только теория. Цитата(Baser @ Nov 6 2008, 01:51)  - кроме применяемой вами группы команд, в SIM300 есть и другие варианты выполнения того же самого. Спасибо, попробую. Может действительно дело упростится Цитата(Baser @ Nov 6 2008, 01:51)  - Почему нельзя просто подождать окончания звонков и установить тайм-аут ожидания корректного ответа на предыдущую команду побольше (минуты две)? Отвечу вопросом на вопрос. А почему бы не побробывать сделать побыстрее? Опишу слегка конфигурацию системы и может тогда станет понятно зачем ускорять. Задача на один модуль собрать инфу о разных объектах. У меня в системе один из модулей (на котором замечено зависание) является "типа основным". Он пытается обзвонить все вторичные модули и узнать их IP адреса. Если вторичный заметил слет GPRS, то сам может позвонить на главный и инициировать обновление своего IP. Все вторичные настраивают себя как сервера. Когда на основной модуль приходят IP от от "вторичных модулей, то тот начинает у них сдаивать инфу о состояние их систем (через GPRS). Опрос одним всех, вместо сливания всеми на один сделано для того, что бы на главный модуль не валилась куча пакетов от кучи вторичных. TCP/IP глючный в модуле SIM300C c 12 прошивкой. 100% замечено, что данные TCP пакета могут вывалится из порта раньше, чем поступит сообщение REMOTE IP:xxx. Т.е не получается в сплошном потоке корректно обрабатывать пакеты. Про этот баг даже сами китайцы писали Когда же один опрашивает всех, то он может и подождать пару сек, пока там гарантированно вылезет REMOTE IP... Так вот, в системе есть тонкое место, когда в районе пропало питание, разрядились все УПС а потом дали элекричество, то потом практически все начнут одновременно ломится на главное устройство. И чем раньше закончится ломление = обновится список IP на главном, тем раньше продолжится нормальная работа.
|
|
|
|
|
Nov 7 2008, 09:36
|
Участник

Группа: Новичок
Сообщений: 37
Регистрация: 15-10-08
Из: Одесса, Украина
Пользователь №: 40 978

|
Цитата(Baser @ Nov 7 2008, 00:37)  В моих применениях CSD не используется А позвольте поинтересоваться, как вы пользуясь GPRS узнаёте IP адреса удалённых точек? Может я как-то нерацио анально сделал? Сначала сам думал о приобретении статических IP - оказалось что оператор не может это сделать. Потом думал пользоваться DynDNS и в главном модуле пользовать сервис DNS. Но так и не понял, как со вторичных мудулей посылать запросы на сервер DynDNS для обновления их IP. Если вы подскажите как разрулить с DynDNS, то буду признателен. Мне кажется это будет более красивое решение обновления IP, чем через CSD.
Сообщение отредактировал david_off - Nov 7 2008, 09:37
|
|
|
|
|
Nov 7 2008, 21:32
|

Просто Che
    
Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881

|
Цитата(david_off @ Nov 7 2008, 11:36)  А позвольте поинтересоваться, как вы пользуясь GPRS узнаёте IP адреса удалённых точек? Может я как-то нерациоанально сделал? Не зная глобальных требований к вашей системе, сложно сказать, насколько у вас рационально все сделано. Если главным требованием было сделать так, чтобы устройство, на которое собирается вся информация, было бы мобильным, плюс недопустимы никакие промежуточные стационарные станции (сервер) - тогда у вас все логично. Я таких систем не строил, у нас все по классической схеме клиент-сервер: мобильные устройства - клиенты; сервер - стационарный интернет-сервер со статическим реальным адресом, может находиться в любой точке света. Инициировать обмен может только клиент. В редких случаях сервер может пнуть клиента по SMS, чтобы тот вышел на связь. Но это больше как резервный канал, ибо SMS довольно дорогая вещь при массовом применении.
|
|
|
|
Сообщений в этой теме
david_off <AT+CIICR> + <RING> + <SIM300C> = ГЛЮК Nov 4 2008, 18:18 david_off Тихо сам с собой веду беседу...
Нашёл регистр S7. ... Nov 4 2008, 19:29 @Ark Цитата(david_off @ Nov 4 2008, 22:29) Есл... Nov 4 2008, 21:52  david_off Цитата(@Ark @ Nov 5 2008, 01:52) Попробуй... Nov 4 2008, 22:18   @Ark Цитата(david_off @ Nov 5 2008, 01:18) Я ж... Nov 4 2008, 22:35    david_off Проверил ваше предложение. Пришёл к выводу, что пр... Nov 5 2008, 09:18 megaboy ЦитатаВ редких случаях сервер может пнуть клиента ... Nov 10 2008, 00:01 Baser Цитата(megaboy @ Nov 10 2008, 02:01) хм..... Nov 10 2008, 13:52
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|