Red Pike (shifr) - Red Pike (cipher)

Qizil Pike a tasniflangan Birlashgan Qirollik tomonidan foydalanish uchun tavsiya etilgan hukumat shifrlash algoritmi Milliy sog'liqni saqlash xizmati tomonidan GCHQ, lekin "uchun keng ko'lamli dasturlar uchun mo'ljallangan Britaniya hukumati " [1]. Red Pike haqida ko'pchilik ma'lum emas, faqat u blok shifr 64-bit bilan blok hajmi va 64-bit kalit uzunligi. Shifrning akademik tadqiqotiga ko'ra quyida keltirilgan va tomonidan qog'ozda keltirilgan Ross Anderson va Markus Kun, u "xuddi shunday asosiy operatsiyalardan foydalanadi RC5 "(add, XOR va chap smenada) va" qidiruv jadvallari yo'q, deyarli kalit jadvali yo'q va faqat beshta kod satrini talab qiladi ";" har bir bit bitning ta'siri tez sur'atlarda pasayadi "va" har bir shifrlash tartibni o'z ichiga oladi 100 ta operatsiya ".

Red Pike maxfiy (maxfiy emas) hukumat aloqa tizimlarida foydalanish uchun tasdiqlangan Britaniya hukumat pudratchilariga dasturiy ta'minot shaklida taqdim etiladi. GCHQ shuningdek Rambutan xuddi shu segment uchun kriptotizim.

Red Pike Britaniyaning shifrlash algoritmi ekanligini hisobga olsak, uning nomi ma'lum bir narsaga tegishli bo'lishi mumkin g'arbiy ingliz ko'llar okrugiga qulab tushdi.

Taxmin qilingan manba kodi

2014 yil fevral oyida Red Pike uchun taxmin qilingan manba kodi quyidagicha joylashtirilgan Cypherpunk pochta ro'yxati.[1]

 / * Red Pike shifrining manba kodi * /  # shu jumladan <stdint.h>  typedef uint32_t so'z;  #STIFIN CONST 0x9E3779B9 # 16-turni aniqlang  # ROTL (X, R) (((X) << ((R) & 31)) | ((X) >> (32 - ((R) & 31))))) ni aniqlang # ROTR (X, R) (((X) >> ((R) & 31)) | ((X) << (32 - ((R) & 31)))) ni aniqlang  bekor shifrlash(so'z * x, konst so'z * k) {   imzosiz int men;   so'z rk0 = k[0];   so'z rk1 = k[1];    uchun (men = 0; men < DAVRALAR; men++)   {     rk0 += CONST;     rk1 -= CONST;      x[0] ^= rk0;     x[0] += x[1];     x[0] = ROTL(x[0], x[1]);      x[1] = ROTR(x[1], x[0]);     x[1] -= x[0];     x[1] ^= rk1;   }    rk0 = x[0]; x[0] = x[1]; x[1] = rk0; }  bekor parolni ochish(so'z * x, konst so'z * k) {   so'z dk[2] =   {     k[1] - CONST * (DAVRALAR + 1),     k[0] + CONST * (DAVRALAR + 1)   };    shifrlash(x, dk); }

Shuningdek qarang

Adabiyotlar

  1. ^ "Red Pike shifr", Red Pike shifrlari, Cypherpunk pochta ro'yxati, Gmane
  • S Mitchell, S Merfi, F Piper, P Wild. (1996). Red Pike - baholash. Kodlar va shifrlar Ltd 2/10/96.
  • Anderson va Kunning qog'ozi, unda parchalar keltirilgan (Mitchell va boshq., 1996). Boshqa versiyasi Anderson, Ross; Kuh, Markus (1997). "Tamperga chidamli qurilmalarga arzon narxlardagi hujumlar" (pdf). Xavfsizlik protokollari, 5-Xalqaro seminar. 125-136-betlar.
  • "NHSnet bilan shifrlash va tegishli xizmatlardan foydalanish"