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

 
 
 
Reply to this topicStart new topic
> ATmega8515, не пашет прогрмма шифрования
st_user
сообщение Apr 29 2007, 21:33
Сообщение #1





Группа: Новичок
Сообщений: 6
Регистрация: 29-04-07
Пользователь №: 27 409



Всем привет!

help.gif Стал я делать алгоритм шифрования TEA на контроллере ATmega8515 и столкнулся с тем, что он не работает sad.gif . Суть проблемы в том, что сам алгоритм шифрования использует 4-х байтные блоки. Для этого я взял тип unsigned long. Проверил этот тип sizeof'ом и убедился, что в компиляторе от IAR это действительно 4-х байтный тип. Стал шифровать. Но вот результат шифрования какой-то не правильный, т.к. он не верно расшифровывается обратно. Для чистоты эксперимента проверил тот же код на компьютере в Visual Studio, всё работает как часы. А вот на контроллере не работает. Вот я и думаю: почему? Может надо что-то включить где-то, может ещё что? Не пойму я!!!!

Вот для примера код шифрования:
Код
void encrypt(unsigned long* v, unsigned long* k)
{
    unsigned long v0=v[0], v1=v[1], sum=0, i;          
    unsigned long delta=0x9e3779b9;                    
    unsigned long k0=k[0], k1=k[1], k2=k[2], k3=k[3];  
    for (i=0; i < 32; i++)
    {                            
        sum += delta;
        v0 += ((v1<<4) + k0) ^ (v1 + sum) ^ ((v1>>5) + k1);
        v1 += ((v0<<4) + k2) ^ (v0 + sum) ^ ((v0>>5) + k3);  
    }
    v[0]=v0; v[1]=v1;
}
Go to the top of the page
 
+Quote Post
st_user
сообщение Apr 30 2007, 13:35
Сообщение #2





Группа: Новичок
Сообщений: 6
Регистрация: 29-04-07
Пользователь №: 27 409



А как компилятор IAR Atmel AVR C/EC++ Compiler V3.20C/W32 понимает символ ^? Как оператор XOR или как-то иначе?
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 30 2007, 14:36
Сообщение #3


Гуру
******

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



Цитата(st_user @ Apr 29 2007, 21:33) *
Для чистоты эксперимента проверил тот же код на компьютере в Visual Studio, всё работает как часы.

Ну тогда единственное это:
Код
sum=0UL;          
unsigned long delta=0x9e3779b9UL;


P.S.
К делу не относится, но сама 'delta' просто лишняя и 'i' незачем 32bit-ным на 8 битной платформе иметь.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
defunct
сообщение Apr 30 2007, 16:13
Сообщение #4


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Возможно здесь переполнение CSTACK.
Переменных у вас на 36 байт, а CSTACK небось по-умолчанию 32 байта.
Go to the top of the page
 
+Quote Post
st_user
сообщение Apr 30 2007, 18:21
Сообщение #5





Группа: Новичок
Сообщений: 6
Регистрация: 29-04-07
Пользователь №: 27 409



Цитата(defunct @ Apr 30 2007, 17:13) *
Возможно здесь переполнение CSTACK.
Переменных у вас на 36 байт, а CSTACK небось по-умолчанию 32 байта.

Большое спасибо a14.gif Действительно, переполнение стека было, поправил, работает smile.gif
Где там нужно плюсик в рейтинг поставить, я готов.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 18th July 2025 - 12:53
Рейтинг@Mail.ru


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