Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 18.06.2013, 21:07
Stamerlan Stamerlan вне форума
Прохожий
 
Регистрация: 18.06.2013
Сообщения: 5
Версия Delphi: Delphi XE3
Репутация: 10
По умолчанию XTEA2

Здравствуйте!!!

Помогите пожалуйста перевести код с С на Delphi:

Код:
#define XTEA2_BLOCKSIZE 16

static unsigned __int32 rol(unsigned __int32 base, unsigned __int32 shift)
{
	unsigned __int32 res;
    /* only 5 bits of shift are significant*/
    shift &= 0x1F;
    res = (base << shift) | (base >> (32 - shift));
    return res;
}

void xtea2_decipher(unsigned int num_rounds, unsigned __int32 *v, unsigned __int32 const *k) {
    unsigned int i;
    unsigned long a, b, c, d, t, delta=0x9E3779B9, sum=delta*num_rounds;
    d = v[3];
    c = v[2] ^ k[3];
    b = v[1];
    a = v[0] ^ k[2];
    for (i = 0; i < num_rounds; i++) {
		t = d; d = c; c = b; b = a; a = t;
        c -= ((d << 4) ^ (d >> 5)) + (b ^ sum) + rol(k[(sum >> 11) & 3], d);
        sum -= delta;
        a -= ((b << 4) ^ (b >> 5)) + (d ^ sum) + rol(k[sum & 3], b);
	}
    v[0] = a;
    v[1] = b - k[0];
    v[2] = c;
    v[3] = d - k[1];
}

void XTEA2Decode(BYTE *Addr, DWORD_PTR Size, BYTE *key, DWORD dwEncMode)
{
	int block_length, key_length, blocks_number;
	unsigned __int32 *crypto_block_begin;
	unsigned __int32 *crypto_block_end;
	block_length = 4;
	key_length = 16;
	crypto_block_begin = (unsigned __int32 *)Addr;
	blocks_number = (int)(Size >> 4);
	crypto_block_end = (unsigned __int32 *)(Addr + (blocks_number << 4));

	while (crypto_block_begin < crypto_block_end)
	{
		xtea2_decipher(16, crypto_block_begin, (unsigned __int32 *)key);

		crypto_block_begin += block_length;
	}
}

Вот что у меня получилось:
Код:
unit DecryptXTEA2;

interface

uses HashImpl;

const
  XTEA2_BLOCKSIZE = 16;

type
  TLongWordArray = array [0..3] of LongWord;
  PLongWordArray = ^TLongWordArray;

procedure xtea2_decipher(num_rounds, v, k: PLongWord);
procedure XTEA2Decode(Buffer: PByte; Size: Integer; Key: PByte; Mode: TEncMode);
function rotl(base:LongWord; shift:LongWord): LongWord;

implementation

function rotl(base:LongWord; shift:LongWord): LongWord;
begin
  shift := shift and $1F;
  result := (base shl shift) or (base shr (32-shift));
end;

procedure xtea2_decipher(num_rounds, v, k: PLongWord);
var
  i : LongWord;
  a, b, c, d, t, delta, sum : longword;
begin
  delta := $9E3779B9;
  sum := delta*LongInt(num_rounds);
  d := PLongWordArray(v)[3];
  c := PLongWordArray(v)[2] xor PLongWordArray(k)[3];
  b := PLongWordArray(v)[1];
  a := PLongWordArray(v)[0] xor PLongWordArray(k)[2];
  for i := 0 to LongWord(num_rounds)-1 do
  begin
    t := d; d := c; c := b; b := a; a := t;
    c := c - ((d shl 4) xor (d shr 5)) + (b xor sum) +
      rotl(PLongWordArray(k)[(sum shr 11) and 3], d);
    sum := sum - delta;
    a := a - ((b shl 4) xor (b shr 5)) + (d xor sum) +
      rotl(PLongWordArray(k)[sum and 3], b);
  end;
  PLongWordArray(v)[0] := a;
  PLongWordArray(v)[1] := b - PLongWordArray(k)[0];
  PLongWordArray(v)[2] := c;
  PLongWordArray(v)[3] := d - PLongWordArray(k)[1];
end;

procedure XTEA2Decode(Buffer: PByte; Size: Integer; Key: PByte; Mode: TEncMode);
const
  ENCMODE_BlockSize = XTEA2_BLOCKSIZE;
var
  block_length, key_length, blocks_number : integer;
  crypto_block_begin, crypto_block_end : PLongWord;
begin
  block_length := 4;
  key_length := 16;
  crypto_block_begin := PLongWord(Buffer);
  blocks_number := Size shr 4;
  crypto_block_end := PLongWord(Buffer + (blocks_number shl 4));

  while LongWord(crypto_block_begin) < LongWord(crypto_block_end) do
  begin
    xtea2_decipher(PLongWord(16), PLongWord(crypto_block_begin), PLongWord(Key));
    Inc(crypto_block_begin, block_length);
  end;
end;


end.

Подскажите что я делаю не так? Когда прошелся отладчиком то увидел что на строке:
Код:
c := c - ((d shl 4) xor (d shr 5)) + (b xor sum) +
      rotl(PLongWordArray(k)[(sum shr 11) and 3], d);
переменная c принимает не правильное значение (не такое как в реализации на С)

Последний раз редактировалось Stamerlan, 19.06.2013 в 10:35.
Ответить с цитированием
  #2  
Старый 18.06.2013, 21:10
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

Код:
result := (value shl shift) or (value shr 32-shift);
Попробуй так:
Код:
result := (value shl shift) or (value shr (32-shift));
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj
Ответить с цитированием
Этот пользователь сказал Спасибо PhoeniX за это полезное сообщение:
Stamerlan (19.06.2013)
  #3  
Старый 18.06.2013, 21:25
Stamerlan Stamerlan вне форума
Прохожий
 
Регистрация: 18.06.2013
Сообщения: 5
Версия Delphi: Delphi XE3
Репутация: 10
По умолчанию

Да, действительно значение изменилось, но все равно не то видимо у меня несколько ошибок
Ответить с цитированием
  #4  
Старый 18.06.2013, 21:34
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

Значения a, b, c, d, sum, k[] на этом этапе совпадают с "эталонными" (из оригинального кода)?
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj
Ответить с цитированием
Этот пользователь сказал Спасибо PhoeniX за это полезное сообщение:
Stamerlan (19.06.2013)
  #5  
Старый 19.06.2013, 09:39
icWasya icWasya вне форума
Местный
 
Регистрация: 09.11.2010
Сообщения: 499
Репутация: 10
По умолчанию

А если объявить так, как в сишной программе
Код:
function rol(base:LongWord; shift:LongWord) :LongWord;
Может быть путаница с беззнакивыми и знаковыми числами.
Ответить с цитированием
Этот пользователь сказал Спасибо icWasya за это полезное сообщение:
Stamerlan (19.06.2013)
  #6  
Старый 19.06.2013, 10:31
Stamerlan Stamerlan вне форума
Прохожий
 
Регистрация: 18.06.2013
Сообщения: 5
Версия Delphi: Delphi XE3
Репутация: 10
По умолчанию

Цитата:
Сообщение от PhoeniX
Значения a, b, c, d, sum, k[] на этом этапе совпадают с "эталонными" (из оригинального кода)?
Да, если расшифровывать одну и ту же строку одинаковым ключем, то с принимает неверное значение.

Код:
function rol(base:LongWord; shift:LongWord) :LongWord;
Я попробовал заменить, но с так и осталось с прежним значением.

UPD: не хватало скобочек в выражениях при с и а. Надо было написать с := c - (... + ... + ...), а у меня было c := c - ... + ... + ...
Всем спасибо!

Последний раз редактировалось Stamerlan, 19.06.2013 в 10:58.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 19:48.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter