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

 
 
> Ошибка компилятора? (ARM), data abort..
overloaded
сообщение Dec 27 2008, 21:44
Сообщение #1


Участник
*

Группа: Свой
Сообщений: 73
Регистрация: 17-10-07
Из: Киев
Пользователь №: 31 422



есть функция и вызов. В неопределенном месте (после вызова функции) процессор стабильно вылетает в data abort.

Код
void do_crc_8(unsigned char byte, unsigned char *crc8)
{
unsigned char ctmp = (*crc8^byte);  
*crc8 = crc_table[ctmp];
}


void write_AVR()
{    
  unsigned char crc8;
....      
  crc8=0;  
  
  for(itmp=0; itmp < sizeof(struct FHW_outs); itmp++)  
  {    
      while(!(AT91C_BASE_US1->US_CSR &AT91C_US_TXRDY));
      AT91C_BASE_US1->US_THR=buf[itmp];
      
      do_crc_8(buf[itmp], &crc8);// <<<----------------------------------------------!!!!
  }  
...
}


После небольшой перемены проблема исчезла. В чем юмор я понять к сожалению не могу =)
Кстати, на IAR AVR эта-же функция в таком-же (первоначальном) виде работает нормально.
ИМХО бред какойто ) Что-то здесь не чисто =)
Код
unsigned char do_crc_8(unsigned char byte, unsigned char crc8)
{
unsigned char ctmp = (crc8^byte);  
return (crc_table[ctmp]);
}


и вызов:

      crc8 = do_crc_8(buf[itmp], crc8);
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
sergeeff
сообщение Dec 28 2008, 01:54
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007



Размер buf[]? sizeof(struct FHW_outs) равен ли sizeof(buf)?
Go to the top of the page
 
+Quote Post
overloaded
сообщение Dec 29 2008, 19:27
Сообщение #3


Участник
*

Группа: Свой
Сообщений: 73
Регистрация: 17-10-07
Из: Киев
Пользователь №: 31 422



Цитата(sergeeff @ Dec 28 2008, 05:54) *
Размер buf[]? sizeof(struct FHW_outs) равен ли sizeof(buf)?


Не равен, на 2 байта больше =)

volatile unsigned char buf[sizeof(struct FHW_outs)+1];

Код не полный, но в другом месте касаемо buf[] есть только копирование из и в структуру
при выключенных прерываниях через memcpy. Раземер естественно через тот-же
sizeof(struct FHW_outs). Еще думал на константную таблицу const unsigned char crc_table[256]
т.к. интересным моментом было и то, что вылетало в аборт только с индексом 255:

void do_crc_8(unsigned char byte, unsigned char *crc8)
{
*crc8 = crc_table[255];
}

Но оказалось что таблица не при чем...
Go to the top of the page
 
+Quote Post
overloaded
сообщение Jan 9 2009, 19:05
Сообщение #4


Участник
*

Группа: Свой
Сообщений: 73
Регистрация: 17-10-07
Из: Киев
Пользователь №: 31 422



Хм.. Дописал немного кода, снова начало глючить там-же. Посмотрел куда указывает аборт - кто-то портит код в прерывании, вынесенном в __ramfunc. Если из озу убрать, то дата аборта нет.
Портит типа такого(всегда в примерно разных местах в пределах + - 10):
Код
Нормальный:
    ADC_buf3[ADC_buf7_count] = ADC_DATA_3;
  00000328  E59F10F8  LDR          R1, [PC, #+248]         ; [0x428] =ADC_buf7_count (0x201464)
  0000032C  E5911000  LDR          R1, [R1, #+0]
  00000330  E3A02004  MOV          R2, #0x4
  00000334  E59F3108  LDR          R3, [PC, #+264]         ; [0x444] =ADC_buf3 (0x201310)
  00000338  E0213192  MLA          R1, R2, R1, R3
  0000033C  E59F2104  LDR          R2, [PC, #+260]         ; [0x448] =ADC_CDR3 (0xFFFD803C)
  00000340  E5922000  LDR          R2, [R2, #+0]
  00000344  E5812000  STR          R2, [R1, #+0]

Порченный:
    ADC_buf3[ADC_buf7_count] = ADC_DATA_3;
  00201508  E59F10F8  LDR          R1, [PC, #+248]         ; [0x201608] =ADC_buf7_count (0x201464)
  0020150C  E5911000  LDR          R1, [R1, #+0]
  00201510  E3A02004  MOV          R2, #0x4
  00201514  E59F3108  LDR          R3, [PC, #+264]         ; [0x201624] =ADC_buf3 (0x201310)
!!! 00201518  FFFFFFFF  SWINV        0xFFFFFF            
  0020151C  E59F2104  LDR          R2, [PC, #+260]         ; [0x201628] =ADC_CDR3 (0xFFFD803C)
  00201520  E5922000  LDR          R2, [R2, #+0]
  00201524  E5812000  STR          R2, [R1, #+0]


Дело почти однозначно в этой ф-и(про которую выше говорил) т.к. когда ее комментирую все работает долго и без глюков. Думаю, что-то с расположением таблици.. Код в прерывании портится не непосредственно этой функцией.. Где-то дальше, не смог найти где.
Какие могут быть нюансы с таблицей?

const unsigned char crc_table[256] = {
0x00,0x5E,0xBC,0xE2,0x61,0x3F,0xDD,0x83 ...

Или если не таблица, куда снова копать?..
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 20:54
Рейтинг@Mail.ru


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