|
Обработка команд по UART |
|
|
2 страниц
1 2 >
|
 |
Ответов
(1 - 24)
|
Aug 21 2012, 16:06
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(d7d1cd @ Aug 21 2012, 18:53)  По прерыванию я заполняю буфер приема байтами. В конце приема будет 2 байта контрольной суммы. Вопрос в том, как определить, что по UART полностью передана вся команда. Все команды будут разной длины. Нужно определить длину команды (по заголовку например) и затем принять нужное число байт. Потом сверить сумму. Цитата(d7d1cd @ Aug 21 2012, 18:53)  Подскажите как решается подобная проблема. Хорошо бы знать формат команды.
|
|
|
|
|
Aug 21 2012, 16:39
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(demiurg_spb @ Aug 21 2012, 20:32)  Своё изобретать ИМХО последнее дело. Есть сотни уже придуманных до Вас протоколов, а некоторые из них являются чуть-ли не стандартами де-факто в некоторых отраслях, как например MODBUS в некоторых промышленных системах. Имеено MODBUS и подразумевает таймаут в конце передачи пакета. Мне интересно как эту задержку на 5 мс реализовать программно.
|
|
|
|
|
Aug 21 2012, 16:52
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(_Артём_ @ Aug 21 2012, 20:49)  Не нужно её пытаться программно организовывать - у вас МК будет 5 мс NOP-ы исполнять? А если 500 мс потребуется? Тогда как "подождать" 5 мс?
|
|
|
|
|
Aug 21 2012, 17:05
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(demiurg_spb @ Aug 21 2012, 21:01)  таймером:-) Ну или можно передать 4 байта в уарт с отключенным передатчиком драйвера RS485, если такой имеется. Как это можно сделать таймером?
|
|
|
|
|
Aug 21 2012, 17:08
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Понятно, что надо запустить функцию StartTimeouTimer(). А ее реализацию можно привести? Код void StartTimeouTimer() { //???????????????????????????????????????????????? }
Сообщение отредактировал d7d1cd - Aug 21 2012, 17:33
|
|
|
|
|
Aug 22 2012, 02:40
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(_Артём_ @ Aug 21 2012, 21:41)  Нет, пока нельзя: вы же не привели тип МК и источник и частоту тактирования. Приведёте, может кто и подскажет. Хотя что там сложного: запустить тактирование и разрешить прерывание по совпадению или переполнению. МК MSP430F149, тактирование от внешнего кварца частотой 8 МГц.
|
|
|
|
|
Aug 22 2012, 20:20
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 24-01-12
Пользователь №: 69 858

|
Цитата(vasta @ Aug 22 2012, 19:18)  ТАм какой-то регистр есть CCR или типа того, ставите в нем сколько надо и разрешаете прерывание - вот вам и 5мс. Правда непонятно, зачем вам внешние 8МГц, там же внутренний кварц такого порядка. Обычно снаружи вешают 32к, как раз чтобы не заморачиваться с милисекундами Только вот со стабильностью частоты жопа начинается... Например я обычно ставлю кварц 7.3728 MHz . Удобно задавать скорость UART. А вот зачем ему 5мс загадка.... там всё можно по другому сделать... я ему в личку отписал с примерами, думаю разберется..
|
|
|
|
|
Aug 23 2012, 04:34
|
Частый гость
 
Группа: Участник
Сообщений: 183
Регистрация: 3-02-09
Из: Нск
Пользователь №: 44 325

|
Цитата(hash20 @ Aug 23 2012, 03:20)  Только вот со стабильностью частоты жопа начинается.... Ну, жопа периодически перекалибровывается, так что не проблема)
|
|
|
|
|
Aug 24 2012, 08:11
|
Профессионал
    
Группа: Свой
Сообщений: 1 719
Регистрация: 13-09-05
Из: Novosibirsk
Пользователь №: 8 528

|
Цитата(d7d1cd @ Aug 23 2012, 21:58)  Думаю, что при таком способе, вероятность ошибочной передачи 2-х байт ничтожно мала. Да и "ждать" ничего не надо... Если предположить, что вероятность искажения бита постоянна и не зависит от его местоположения в пакете... то получится что будет только хуже, так как ошибка в 2 байтах всё равно не будет обнаружена, а если ошибка в другом месте, то пакет с верными байтами данных будет отброшен. Чем длинне пакет, тем выше вероятность что в нём будет хотя бы одна ошибка. Если лень считать 16-битную CRC для пакета, то подсчитывайте просто сумму всех байт пакета в 16-битной переменной и добавляйте в хвост пакета эти два байта контрольной суммы, или хотя бы один (младший) байт. По крайней мере обнаружите на приёме одиночные и практически все двойные ошибки, а бОльшего и не надо, при нормальном канале.
--------------------
Russia est omnis divisa in partes octo.
|
|
|
|
|
Aug 24 2012, 11:28
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 24-01-12
Пользователь №: 69 858

|
самый оптимальный вариант [2 старт байта] - [пакет] - [сrc] - [2 стоп байта]
d7d1cd я же тебе в личку почти готовый проект скинул, зачем велосипед изобретаеш (да ещё и 3ех колесный)
нахрена пароль гонять в каждом пакете, если в серъезных проектах - то такой пароль взломается за несколько десятков засниференных пакетов...
если интересует восстановление ошибок в принятом пакете, почитай про код хемминга (вроде как не сложно реализовывается)
|
|
|
|
|
Aug 24 2012, 12:01
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(hash20 @ Aug 24 2012, 14:28)  самый оптимальный вариант [2 старт байта] - [пакет] - [сrc] - [2 стоп байта] Самый-не самый оптимальный, на всяко гораздо лучше чем, то что d7d1cd описал. Цитата(hash20 @ Aug 24 2012, 14:28)  нахрена пароль гонять в каждом пакете, если в серъезных проектах - то такой пароль взломается за несколько десятков засниференных пакетов... Так его зашифровать можно. Цитата(hash20 @ Aug 24 2012, 14:28)  зачем велосипед изобретаеш (да ещё и 3ех колесный) Где-то так конечно, но трёхколёсный велосипед устойчивей гораздо, чем наши несамоизобретённые двухколёсные (для d7d1cd конечно).
|
|
|
|
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0
|
|
|