43 lines
1.1 KiB
Forth
43 lines
1.1 KiB
Forth
|
0 value ii 0 value jj
|
||
|
0 value KeyAddr 0 value KeyLen
|
||
|
create SArray 256 allot \ state array of 256 bytes
|
||
|
: KeyArray KeyLen mod KeyAddr ;
|
||
|
|
||
|
: get_byte + c@ ;
|
||
|
: set_byte + c! ;
|
||
|
: as_byte 255 and ;
|
||
|
: reset_ij 0 TO ii 0 TO jj ;
|
||
|
: i_update 1 + as_byte TO ii ;
|
||
|
: j_update ii SArray get_byte + as_byte TO jj ;
|
||
|
: swap_s_ij
|
||
|
jj SArray get_byte
|
||
|
ii SArray get_byte jj SArray set_byte
|
||
|
ii SArray set_byte
|
||
|
;
|
||
|
|
||
|
: rc4_init ( KeyAddr KeyLen -- )
|
||
|
256 min TO KeyLen TO KeyAddr
|
||
|
256 0 DO i i SArray set_byte LOOP
|
||
|
reset_ij
|
||
|
BEGIN
|
||
|
ii KeyArray get_byte jj + j_update
|
||
|
swap_s_ij
|
||
|
ii 255 < WHILE
|
||
|
ii i_update
|
||
|
REPEAT
|
||
|
reset_ij
|
||
|
;
|
||
|
: rc4_byte
|
||
|
ii i_update jj j_update
|
||
|
swap_s_ij
|
||
|
ii SArray get_byte jj SArray get_byte + as_byte SArray get_byte xor
|
||
|
;
|
||
|
|
||
|
hex
|
||
|
create AKey 61 c, 8A c, 63 c, D2 c, FB c,
|
||
|
\ create AKey 97 c, 8A c, 99 c, D2 c, FB c,
|
||
|
: test cr 0 DO rc4_byte . LOOP cr ;
|
||
|
AKey 5 rc4_init
|
||
|
2C F9 4C EE DC 5 test \ output should be: F1 38 29 C9 DE
|
||
|
|