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

 
 
> Кто из нас сошел с ума - IAR или я?
Kitsok
сообщение Nov 22 2006, 00:13
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 211
Регистрация: 9-11-06
Пользователь №: 22 136



Итак, вот что имеем на входе:
Код
static __arm __irq void vADC_ISR(void)
{

  unsigned portCHAR sr =0;
  unsigned portCHAR i = 0;
  AT91_REG * ADDR;
  
  // Read status register
  sr = a_pADC->ADC_SR;
  
  sBUTTONS[7]=sr;
   for (i=0;i<8;i++)
   {
     ADDR = AT91C_ADC_CDR0 + (4*i);
    
     if ( (sr >> i) & 0x01)
      {
        // Bit is set, put data to array
        sADC_RAW[i] = *(ADDR);
      }
   }
  // Start new conversion
  a_pADC->ADC_CR = 0x2;
  
  /* End the interrupt in the AIC. */  
  AT91C_BASE_AIC->AIC_EOICR = 0;
}



Обратите внимание на переменную ADDR, я слева буду писать значение i, а справа - значение ADDR, полученное при отладке через JTAG:

i=0 ADDR=0xFFFD8030
i=1 ADDR=0xFFFD8040
i=2 ADDR=0xFFFD8050
ну и так далее.

Слушайте, может я умом тронулся, но вроде бы 0xFFFD8030 + 4 == 0xFFFD8034, или я чего-то недопонимаю? Контроллер - SAM7S256

Уж не знаю, почему так, но почему-то с адресом как с обычным числом работать нельзя.
Тупое ADDR= AT91C_ADC_CDR0 + i; заработало. Компиляцкий компилятор перестал умножать на 4....

Сообщение отредактировал Kitsok - Nov 22 2006, 00:20
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
zltigo
сообщение Nov 22 2006, 00:27
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Kitsok @ Nov 21 2006, 23:13) *
может я умом тронулся,

Думаем, что такое указатель, почему при определении указателя задается размер объекта на который он указывает ну и дальше совсем просто - как "правильно" должно измениться значение указателя при его наращивании - на "единицу", или на размер объекта на который он указывает?

P.S.
И еще, к вопросу не относящееся - использовать умножение на степень двойки это моветон, хотя компиляторы и творят чудеса.
P.P.S.
И будьте проще:
Код
  for (i=0;i<8;i++)
   {
     if ( (sr >> i) & 0x01)
      {
        // Bit is set, put data to array
        sADC_RAW[i] = AT91C_ADC_CDR0[i];
      }
   }


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 21:19
Рейтинг@Mail.ru


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