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

 
 
> at90can128, Прерывания от MOB
SasaVitebsk
сообщение Dec 20 2007, 19:06
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



Доброго времени суток.
Написал программу по работе с CAN. Задача довольно простая. Необходимо отлавливать сообщения поступающими по двум IDT. Для этого зарезервировал два MOB. Вроде инициализация правильная. Вроде всё настроил верно. Смотрю по JTAG и вроде всё нормально.

Проблемы в том, что с передающего устройства всё валит непрерывно. Причём поступает много различных сообщений, а мне надо отфильтровать только два.

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

Сам CAN узел сложноват, и не всё мне понятно. Например непонятно сбрасывается ли прерывание автоматом при входе в прерывание. Там ведь груповое прерывание. Может надо какие-то пляски ритуальные совершить?

Конечно, в оригинале было бы замечательно посмотреть инициализацию при аналогичной задаче. Или проверить мою. Я могу выложить.

ЗЫ: В библиотеке такого нет. Спецы - отзовитесь.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
SasaVitebsk
сообщение Dec 23 2007, 11:36
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



Настораживает вот эта выдержка из даташита по CANCDMOB.

• Bit 7:6 – CONMOB1:0: Configuration of Message Object
These bits set the communication to be performed (no initial value after RESET).
•00 - disable.
•01 - enable transmission.
•10 - enable reception.
•11 - enable frame buffer reception
These bits are not cleared once the communication is performed. The user must rewrite
the configuration to enable a new communication.
•This operation is necessary to be able to reset the BXOK flag.
•This operation also set the corresponding bit in the CANEN registers.

А также вот такие выдержки из библиотек
Код
#define CONMOB_MSK  ((1<<CONMOB1)|(1<<CONMOB0))                          //! MaSK for CONfiguration MOb

#define DISABLE_MOB       ( CANCDMOB &= (~CONMOB_MSK) )

#define Can_config_rx()        { DISABLE_MOB; CANCDMOB |= (MOB_Rx_ENA  << CONMOB); }


GM прокоментируй пожалуйста. Я так понял, что мне в прерывании надо каждый раз обязательно делать Can_config_rx() или я неверно перевёл? Мой английский хромает на все 5 ног.
Go to the top of the page
 
+Quote Post
=GM=
сообщение Dec 23 2007, 17:44
Сообщение #3


Ambidexter
*****

Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282



Цитата(SasaVitebsk @ Dec 23 2007, 11:36) *
These bits are not cleared once the communication is performed. The user must rewrite the configuration to enable a new communication

Вольный перевод такой. Эти биты не очищаются после передачи пакета. Программа пользователя должна перезаписать конфигурацию для нового обмена.
Смысл тут такой, принят пакет в почтовый ящик, дальнейший приём запрещён, поскольку программа должна принятое прочитать, и после прочтения принять некое решение, скажем, разрешить приём нового пакета

Цитата(SasaVitebsk @ Dec 23 2007, 11:36) *
А также вот такие выдержки из библиотек
Код
#define CONMOB_MSK  ((1<<CONMOB1)|(1<<CONMOB0))    //! MaSK for CONfiguration MOb
#define DISABLE_MOB       ( CANCDMOB &= (~CONMOB_MSK) )
#define Can_config_rx()
{
DISABLE_MOB; CANCDMOB |= (MOB_Rx_ENA  << CONMOB);
}

Первые две строчки можно заменить одной
#define DISABLE_MOB (CANCDMOB=(0<<CONMOB1)|(0<<CONMOB0)) или по-рабоче-крестьянски CANCDMOB=0х08
В последней запрещается ящик, затем реконфигурируется, MOB_Rx_ENA=10 – разрешить приём
Цитата(SasaVitebsk @ Dec 23 2007, 11:36) *
GM прокомментируй пожалуйста. Я так понял, что мне в прерывании надо каждый раз обязательно делать Can_config_rx() или я неверно перевёл? Мой английский хромает на все 5 ног

Ну да, надо показать кан-модулю, что пакет считан, можно принимать дальше, для этого надо переписать биты <7-6> регистра CANCDMOB, а также поля IDE и DLC, которые заменяются принятыми битами. По-моему, проще написать CANCDMOB=0х88, да и всё, чем писать побитно.

Логика в запрещении приёма есть, поскольку, если не запрещать приём, то пакет может быть переписан и, следовательно, потерян, зачем тогда его было вообще передавать?


--------------------
Делай сразу хорошо, плохо само получится
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 3rd September 2025 - 10:29
Рейтинг@Mail.ru


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