|
Обработка команд по UART |
|
|
|
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 конечно).
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|