کد افزونگی چرخشی
کد افزونگی دورهای (به انگلیسی: Cyclic redundancy check) (سیآرسی) تابع درهمسازی غیرایمنی است که جهت تشخیص تغییرات تصادفی بر روی دادهها خام طراحی شدهاست. این تابع عموماً در شبکههای مخابراتی دیجیتال و وسایل ذخیرهسازی دادهها از جمله دیسک سخت مورد استفاده قرار میگیرد. یک دستگاه دارای قابلیت سیآرسی، یک توالی کوتاه و با طول ثابت را، به نام کد سیآرسی (یا فقط سیآرسی)، برای هر بلاک از دادهها محاسبه نموده و آن را همراه با دادهها ذخیره یا ارسال میکند. زمانی که یک بلاک دریافت یا خوانده میشود دستگاه محاسبه را تکرار میکند؛ در صورت مغایرت با کد محاسبه شده قبلی مشخص میشود که این بلاک دارای خطای داده است و در این حالت دستگاه ممکن است عملی را جهت اصلاح خطا از جمله خواندن یا درخواست ارسال مجدد بلاک انجام دهد. اصطلاح سیآرسی میتواند به کد اعتبارسنج یا تابع تولید کد اطلاق شود. CRCها به جهت پیادهسازی ساده در سختافزار دودویی، سادگی تحلیل ریاضی آنها و عملکرد خوب در تشخیص خطاهای معمول حاصل از اختلال در کانالهای انتقال دارای محبوبیت زیادی هستند. سیآرسی توسط W. Wesley Peterson اختراع و در مقاله ۱۹۶۱ وی منتشر شد. سیآرسی ۳۲ بیتی (CRC32) پیشنهادی مؤسسه مهندسین الکتریک و الکترونیک (IEEE)، که در اترنت و سایر جاها استفاده شدهاست، در کنفرانس مخابراتی سال ۱۹۷۵ ظاهر شد.
مقدمه
سیآرسی یک کد تشخیص خطا است. محاسبه آن شبیه عمل تقسیم اعشاری است که خارج قسمت حذف میشود و باقیمانده به عنوان نتیجه در نظر گرفته میشود، با این تفاوت مهم که محاسبات آن محاسبات بدون رقم نقلی از یک میدان محدود است. اعلام یک سیآرسی خاص با مشخص کردن مقسوم علیه و سایر مشخصات آن انجام میشود.
اگرچه CRCها میتوانند با استفاده از هر میدان محدودی ساخته شوند، همه CRCهای پرکاربرد از میدان محدود GF(2) بهره میبرند. این میدانی از دو عنصر، عموماً به نام ۰ و ۱، است که به راحتی با معماری کامپیوتر سازگار است.
یک دلیل مهم برای محبوبیت CRCها برای تشخیص تغییرات تصادفی دادهها اطمینان از کیفیت آنها است. نوعاً، یک سیآرسی nبیتی، که برای یک بلاک داده با طول دلخواه محاسبه شدهاست، هر حوزه خطای با طول کمتر از n بیت (به عبارت دیگر، هر تغییری که محدوده آن بیش از n بیت مجاور از دادهها نباشد) و کسری معادل با ۱–۲ از سایر حوزههای خطایی با طول بیش از n بیت را تشخیص میدهد. خطاها در هیچیک از کانالهای انتقال و رسانههای ذخیرهسازی مغناطیسی دارای توزیع تصادفی نیستند و در نتیجه فایده خواص CRCها را نسبت به سایر روشهای تشخیص خطا از جمله کدهای چندگانه زوجیت بیشتر میکنند.
سادهترین سامانه تشخیص خطا، بیت زوجیت، در واقع یک سیآرسی عادی است که از مقسوم علیه دوبیتی ۱۱ استفاده میکند.
CRCها و تمامیت دادهها
CRCها، به خودی خود، راهکار مناسبی برای حفاظت در مقابل تغییرات عمدی روی داده نیستند (مثلاً در برنامههای اعتبارسنجی)، چون مبانی ساده ریاضیات آنها باعث میشود که بتوان هر تغییر دلخواه را روی دادهها طوری اعمال کرد که سیآرسی دادهها تغییر نکند.
اغلب این فرض غلط وجود دارد که وقتی پیامی به همراه سیآرسی آن از یک کانال آزاد دریافت میشود و سیآرسی دریافتی با سیآرسی محاسبه شده مطابقت میکند پس پیام ممکن نیست در حین دریافت تغییر کرده باشد. این درست نیست چون هر دوی آنها میتوانند تغییر کرده باشند، به طوری که سیآرسی جدید با پیام جدید مطابقت کند؛ بنابراین CRCها میتوانند جهت بررسی درستی دادهها استفاده شوند ولی نه برای اطمینان از تمامیت آن.
ایجاد پیامهای دیگری که همان سیآرسی را ایجاد کنند کار سادهای است، خصوصاً پیامهایی که بسیار شبیه پیام اصلی هستند. طبق طراحی پیامی که بسیار شبیه پیام اصلی است (و تفاوت آن تنها در یک الگوی تداخل تصادفی است) سیآرسی کاملاً متفاوتی خواهد داشت و بنابراین تشخیص داده خواهد شد.
در مقابل، یک راه مؤثر برای محافظت پیامها در برابر تغییرات عمدی استفاده از کدهای اعتبار سنجی پیام همچون HMAC است.
محاسبه سیآرسی
برای محاسبه یک سیآرسی دودویی nبیتی، بیتهای ورودی را در یک سطر بنویسید، و الگوی (n+1)بیتی را که نشاندهنده مقسوم علیه سیآرسی است (و چندجملهای نامیده میشود) زیر سمت چپترین بیت قرار دهید. در زیر، اولین محاسبه برای ایجاد یک سیآرسی ۳۲ بیتی (CRC32) نشان داده شدهاست:
۱۱۰۱۰۰۱۱۱۰۱۱۰۰ <--- ورودی ۱۰۱۱ <--- مقسوم علیه (۴ بیت) ---- ۰۱۱۰۰۰۱۱۱۰۱۱۰۰ <--- نتیجه
اگر سمت چپترین بیت ورودی بالای مقسوم علیه صفر باشد، محاسبهای انجام نشده و مقسوم علیه را یک بیت به راست حرکت میدهیم. اگر سمت چپترین بیت ورودی بالای مقسوم علیه یک باشد، مقسوم علیه و ورودی XOR میشوند (به بیان دیگر بیت ورودی بالای هر بیت یک مقسوم علیه عکس میشود). سپس مقسوم علیه را یک بیت به راست حرکت میدهیم و این روند تا زمانی تکرار میشود که انتهای مقسوم علیه به انتهای سطر ورودی نرسیدهاست. در زیر، آخرین محاسبه نشان داده شدهاست:
۰۰۰۰۰۰۰۰۰۰۱۱۱۰ <--- نتیجه محاسبه قبلی ۱۰۱۱ <--- مقسوم علیه ---- ۰۰۰۰۰۰۰۰۰۰۰۱۰۱ <--- باقیمانده (۳ بیت)
از آنجایی که چپترین بیت مقسوم علیه در مواجه با هر بیت یک ورودی آن را صفر میکند، وقتی این روند پایان مییابد تنها بیتهای ورودی که میتوانند غیر صفر باشند آخرین n بیت سمت راست است. این n بیت، باقیمانده مرحله تقسیم است و البته همان مقدار تابع سیآرسی است (مگر آنکه تابع سیآرسی انتخابی شامل تعدادی پس پردازش باشند).
مشخصات سیآرسی
مفهوم سیآرسی به عنوان یک کد تشخیص خطا هنگام پیادهسازی آن در یک سامانه واقعی میتواند شامل برخی پیچیدگیهای دیگر نیز باشد. در ذیل، تعدادی از آنها آمدهاست:
- یک پیادهسازی خاص ممکن است یک الگوی بیتی ثابت را پیشوند قرار دهد. این زمانی مفید است که خطاهای ساعتی ممکن است بیتهای صفر را در ابتدای پیام قرار دهد و در این صورت با این الگو قابل تشخیص است.
- یک پیادهسازی خاص ممکن است به پیام n بیت صفر الحاق کند. این میتواند بررسی صحت پیامی را که سیآرسی به آن الحاق شدهاست سادهتر کند. در این روش پس از الحاق n بیت صفر و محاسبه مجدد سیآرسی، نتیجه دقیقاً صفر میشود و باقیمانده کافیست با صفر مقایسه شود.
- یک پیادهسازی خاص ممکن است نتیجه را با یک الگوی ثابت XOR کند.
- ترتیب بیتها: برخی روشها کمارزشترین بیت را نخست قرار میدهند و برخی بالعکس. ترتیب بیتها در سختافزارهای انتقال سریالی داده بسیار اهمیت دارد زیرا اکثر روشهای انتقال که به صورت وسیع استفاده میشوند از الگوی ابتدا-کمارزشترین-بیت استفاده میکنند.
- ترتیب بایتها: در CRCهای چند بایتی، ممکن است این تردید پیش آید که آیا بایت منتقل شده اول، کمارزشترین بایت است یا باارزشترین. به عنوان مثال در برخی روشها بایتهای سیآرسی ۱۶بیتی را جابجا میکنند.
- حذف باارزشترین بیت چندجملهای مقسم: از آنجایی که باارزشترین بیت همیشه یک است، و از آنجایی که یک سیآرسی nبیتی باید به صورت یک مقسوم علیه (n+1)بیتی تعریف شود و در این صورت میتواند از یک ثبات nبیتی سرریز میشود، برخی نویسندگان بیان بیت بالای مقسوم علیه را غیرضروری میدانند.
CRCهای پرکاربرد و استاندارد
اگرچه CRCها از اجزای استاندههای متعددی هستند اما خودشان، از منظر وجود الگوریتمی جهانی، استانده نیستند. به عنوان مثال دو چندجملهای سیآرسی-۱۲، ده نوع مستند سیآرسی-۱۶ و چهار سیآرسی-۳۲ وجود دارد. این چندجملهایها عموماً بهترین چندجملهایهای ممکن نیستند. بین ۱۹۹۳ و ۲۰۰۴، کوپمن، کستاگنولی و سایرین فضای چندجملهایها تا ۱۶ بیت، ۲۴ و ۳۲ بیتی را جهت یافتن مثالهایی با کارایی بهتر (از نظر فاصله هامنی برای یک طول پیام خاص) از چندجملهایهای پروتکلهای پیشین بررسی کردند و بهترین آنها را در جهت بهبود ظرفیت تشخیص خطای استاندههای آتی منتشر کردند. بهطور خاص، iSCSI یکی از یافتههای این پژوهش را مورد استفاده قرار دادهاست.
جدول زیر تنها شامل چندجملهایهای مورد استفاده در الگوریتمهای متداول است. همانطور که پیشتر توضیح داده شد هر پروتکل خاص میتواند دارای چینشهای بیت مختلفی باشد. CRCها در پروتکلهای تجاری ممکن است از مقدار اولیه خاص و XOR نهایی جهت مبهمسازی استفاده کنند ولی این کار استحکام رمزنگاری الگوریتم را افزایش نمیدهد.
توجه: در این جدول با ازرشترین بیت حذف شدهاست؛ جهت توضیح به قسمت مشخصات سیآرسی در بالا مراجعه کنید.
نام | چندجملهای | نمایش: عادی یا قرینه (قرینه معکوس) |
---|---|---|
CRC-1 | 0x1 or 0x1 (0x1) | |
CRC-4-ITU | 0x3 or 0xC (0x9) | |
CRC-5-EPC | 0x09 or 0x12 (0x14) | |
CRC-5-ITU | 0x15 or 0x15 (0x1A) | |
CRC-5-USB | 0x05 or 0x14 (0x12) | |
CRC-6-ITU | 0x03 or 0x30 (0x21) | |
CRC-7 | 0x09 or 0x48 (0x44) | |
CRC-8-ATM | 0x07 or 0xE0 (0x83) | |
CRC-8-CCITT | 0x8D or 0xB1 (0xC6) | |
CRC-8-Dallas/Maxim | 0x31 or 0x8C (0x98) | |
CRC-8 | 0xD5 or 0xAB (0xEA) | |
CRC-8-SAE J1850 | 0x1D or 0xB8 (0x8E) | |
CRC-10 | 0x233 or 0x331 (0x319) | |
CRC-11 | 0x385 or 0x50E (0x5C2) | |
CRC-12 | 0x80F or 0xF01 (0xC07) | |
CRC-15-CAN | 0x4599 or 0x4CD1 (0x62CC) | |
CRC-16-CCITT | 0x1021 or 0x8408 (0x8810) | |
CRC-16-DNP | 0x3D65 or 0xA6BC (0x9EB2) | |
CRC-16-IBM | 0x8005 or 0xA001 (0xC002) | |
CRC-24 | 0x5D6DCB or 0xD3B6BA (0xAEB6E5) | |
CRC-24-Radix-64 | 0x864CFB or 0xDF3261 (0xC3267D) | |
CRC-30 | 0x2030B9C7 or 0x38E74301 (0x30185CE3) | |
CRC-32-IEEE 802.3 | 0x04C11DB7 or 0xEDB88320 (0x82608EDB) | |
CRC-32C (Castagnoli) | 0x1EDC6F41 or 0x82F63B78 (0x8F6E37A0) | |
CRC-32K (Koopman) | 0x741B8CD7 or 0xEB31D82E (0xBA0DC66B) | |
CRC-32Q | 0x814141AB or 0xD5828281 (0xC0A0A0D5) | |
CRC-64-ISO | 0x000000000000001B or 0xD800000000000000 (0x800000000000000D) | |
CRC-64-ECMA-182 | 0x42F0E1EBA9EA3693 or 0xC96C5795D7870F42 (0xA17870F5D4F51B49) |
CRCهای زیر نیز وجود دارند ولی از نظر فنی کارایی ندارند و عمدتاً با توابع درهمسازی رمزی جایگزین شدهاند:
- سیآرسی-۱۲۸ (IEEE)
- سیآرسی-۲۵۶ (IEEE)
منابع
- ویکیپدیای انگلیسی
- ↑ Peterson, W. Wesley. ; Brown, D. T. (January 1961), "Cyclic Codes for Error Detection", Proceedings of the IRE (به انگلیسی), vol. 49, p. 228
- ↑ (slib) Cyclic Checksum (به انگلیسی), archived from the original on 18 September 2008, retrieved 6 July 2009 Retrieved on 6 April 2008.
- ↑ Class-1 Generation-2 UHF RFID Protocol (PDF) (به انگلیسی), EPCglobal, 23 October 2008, p. ۱۰۸ ۳۵, archived from the original (PDF) on 20 November 2008, retrieved 6 July 2009
- ↑ AIXM Primer (PDF) (به انگلیسی), European Organisation for the Safety of Air Navigation, 20 March 2006
پیوند به بیرون
- Free CRC-8 Checksum Calculator: یک پیادهسازی متن باز محاسبه سیآرسی-۸ در زبان اسمبلی
ابزارهای برخط
- مولد رایگان مدار سیآرسی وریلاگ
- محاسبه آنلاین سیآرسی۳۲ و سیآرسی۳۲بیتی (با استفاده از چندجملهای IEEE ۸۰۲٫۳)
- ابزاری برای محاسبه CRCهای معمول (۸/۱۶/۳۲/۶۴) از روی رشتهها
- کدگشا و کد نگار کاراکتر (ASCII)، مبنای ۱۶، دودویی، مبنای ۶۴، غیره... به همراه الگوریتمهای درهمسازی MD2، MD4، MD5، SHA1+2، CRC، غیره