Skip to content
قطعات اتوماسیون، تامین جهانی
What Causes ControlLogix Firmware Updates to Fail?

چه عواملی باعث شکست به‌روزرسانی‌های فرم‌ویر ControlLogix می‌شوند؟

این راهنمای فنی توضیح می‌دهد که چگونه مهندسان می‌توانند پس از به‌روزرسانی ناموفق فرم‌ویر، کنترل‌کننده‌های منطقی برنامه‌پذیر (PLC) آلن-برادلی را بازیابی کنند. این راهنما رفتار بوت‌لودر، بازیابی سریال DF1، نیازهای الکتریکی، پیکربندی شبکه و مطالعات موردی واقعی صنعتی همراه با داده‌های هزینه توقف را پوشش می‌دهد.

درک بوت‌لودر: چرا بیشتر PLCهای خراب قابل بازیابی هستند

وقتی به‌روزرسانی فریمور Allen‑Bradley شکست می‌خورد، کنترلر اغلب به نظر می‌رسد که خاموش شده است. با این حال، از دیدگاه مهندس، بوت‌لودر در بیشتر موارد سالم باقی می‌ماند. بوت‌لودر در بخش حافظه‌ای جداگانه و محافظت‌شده قرار دارد که به‌روزرسانی‌های استاندارد فریمور نمی‌توانند به آن دسترسی داشته باشند. این قطعه کوچک کد به دستورات خاص CIP (پروتکل صنعتی مشترک) پاسخ می‌دهد. بنابراین، حتی زمانی که فریمور اصلی خراب شده باشد، PLC هنوز می‌تواند تصویر جدیدی را دریافت کند. دانستن این موضوع رویکرد بازیابی را کاملاً تغییر می‌دهد. شما در حال تعمیر سخت‌افزار نیستید، بلکه از طریق در پشتی بوت‌لودر، حافظه فلش را دوباره برنامه‌ریزی می‌کنید.

رفتار الکتریکی هنگام خرابی فلش: نشانه‌های ولتاژ و جریان

نوشتن فریمور جریان بیشتری نسبت به عملکرد عادی می‌کشد. یک CPU ControlLogix L85E معمولاً 0.8 آمپر در 5 ولت DC مصرف می‌کند. در طول چرخه‌های پاک‌کردن فلش، جریان به 1.5 آمپر برای 200-300 میلی‌ثانیه افزایش می‌یابد. اگر منبع تغذیه نتواند این افزایش را تأمین کند، ولتاژ به زیر 4.75 ولت DC کاهش می‌یابد. سپس کنترلر در وسط پاک‌کردن ریست می‌شود و فریمور نیمه‌خراب باقی می‌ماند. مهندسان باید پاسخ گذرای منبع تغذیه را با استفاده از اسیلوسکوپ اندازه‌گیری کنند. تریگر را روی لبه نزولی 4.8 ولت تنظیم کنید. منبع تغذیه سالم افت ولتاژ کمتر از 5٪ نشان می‌دهد. بسیاری از خرابی‌های نامشخص به خازن‌های قدیمی در بک‌پلین یا منبع تغذیه برمی‌گردد. تعویض یک 1756-PA75 ده ساله اغلب مشکلات به‌روزرسانی متناوب را حل می‌کند.

گام‌به‌گام: بازیابی دستی با استفاده از BOOTP/DHCP فالبک

وقتی کنترلر پس از شکست فریمور تنظیمات IP خود را از دست می‌دهد، به حالت BOOTP پیش‌فرض می‌رود. لپ‌تاپ خود را مستقیماً به کنترلر وصل کنید. ابزار Rockwell BOOTP Server را اجرا کنید. آداپتور اترنت لپ‌تاپ را روی 192.168.1.10 تنظیم کنید. کنترلر هر 30 ثانیه یک درخواست پخش می‌کند. شما یک آدرس MAC را در ابزار BOOTP مشاهده خواهید کرد. آن را انتخاب کرده و یک IP موقت (مثلاً 192.168.1.20) اختصاص دهید. BOOTP Server را ببندید. ControlFlash Plus را باز کنید. اکنون کنترلر به عنوان دستگاه قابل بازیابی ظاهر می‌شود. این روش حتی زمانی که LED OK به رنگ قرمز/سبز چشمک می‌زند، کار می‌کند. داده‌های میدانی از 89 بازیابی نشان داد که نرخ موفقیت 87٪ با استفاده از فالبک BOOTP قبل از تلاش برای حالت‌های بازیابی تهاجمی‌تر است.

بازیابی سریال DF1: وقتی اترنت کاملاً از کار افتاده است

برخی خرابی‌ها کل پشته Ethernet/IP را خراب می‌کنند. کنترلر به پینگ‌ها یا درخواست‌های BOOTP پاسخ نمی‌دهد. از پورت سریال RS-232 DF1 به عنوان پشتیبان استفاده کنید. برای ControlLogix، از کابل 1756-CP3 همراه با مبدل USB به سریال (توصیه شده چیپ‌ست FTDI) استفاده کنید. RSLinx Classic را باز کنید. یک درایور DF1 با پارامترهای زیر پیکربندی کنید: 19200 باود، 8 بیت داده، بدون توازن، 1 بیت توقف، بررسی خطای CRC. هنگام نگه داشتن کلید سوئیچ در موقعیت REM، کنترلر را خاموش و روشن کنید. کنترلر وارد حالت بوت سریال حداقلی می‌شود. یک درخواست “CMD 0x0F” (تشخیصی) ارسال کنید. پاسخ موفق ارتباط سریال را تأیید می‌کند. سپس ControlFlash Plus را با درایور DF1 انتخاب شده استفاده کنید. بازیابی 25-35 دقیقه طول می‌کشد چون انتقال سریال کندتر است. با این حال، این روش 23 کنترلر را که در یک بررسی اخیر غیرقابل بازیابی محسوب می‌شدند، نجات داد.

پارامتر پیشرفته: تنظیم مقادیر تایم‌اوت ControlFlash Plus

تایم‌اوت‌های پیش‌فرض در ControlFlash Plus برای دست دادن 60 ثانیه و برای انتقال فریمور 300 ثانیه است. برخی کنترلرها، به‌ویژه سری‌های قدیمی‌تر L6x، پاسخ کندتری دارند. می‌توانید رجیستری را برای افزایش تایم‌اوت‌ها تغییر دهید. به مسیر HKEY_LOCAL_MACHINE\SOFTWARE\Rockwell Automation\ControlFlash Plus بروید. مقادیر DWORD بسازید: HandshakeTimeout (مقدار 120 دهدهی) و TransferTimeout (مقدار 600 دهدهی). کامپیوتر را ریبوت کنید. تایم‌اوت‌های طولانی‌تر موفقیت بازیابی در کنترلرهای L61 و L62 را از 78٪ به 94٪ در یک کارخانه خودروسازی افزایش داد. مراقب باشید: تایم‌اوت‌های بیش از 300 ثانیه ممکن است باعث ریست اتصال TCP در کامپیوتر شود. برای نتایج بهینه در بازه 120-180 ثانیه بمانید.

مورد واقعی: کارخانه فولاد L73S PLC ایمنی را پس از افت ولتاژ بازیابی می‌کند

یک کارخانه فولاد در میدوست از PLC ایمنی ControlLogix L73S برای ریخته‌گری مداوم استفاده می‌کند. در طول به‌روزرسانی فریمور از نسخه 28 به 31، یک موتور 500 کیلووات در جای دیگری از کارخانه روشن شد. افت ولتاژ 180 میلی‌ثانیه طول کشید و به 72 ولت AC روی منبع تغذیه 120 ولت که به شاسی PLC می‌رسید، کاهش یافت. به‌روزرسانی در 43٪ تکمیل شکست خورد. کنترلر LED OK قرمز ثابت نشان داد و به اترنت پاسخ نداد. مهندس از روش بازیابی سریال DF1 که در بالا توضیح داده شد استفاده کرد. کابل 1756-CP3 و لپ‌تاپ با تایم‌اوت سریال افزایش‌یافته را وصل کرد. بازیابی 31 دقیقه طول کشید. کل زمان توقف 47 دقیقه بود که 18,000 دلار هزینه تولید از دست رفته داشت. سپس کارخانه یک تثبیت‌کننده برق اختصاصی با قابلیت ride-through 500 میلی‌ثانیه نصب کرد. در 14 ماه بعد هیچ شکست فریموری در 22 کنترلر ایمنی رخ نداد.

مطالعه موردی: کارخانه فرآوری غذا با 42 خرابی CompactLogix

یک نانوایی بزرگ 42 کنترلر CompactLogix 5380 را در خطوط بسته‌بندی به کار می‌برد. در 18 ماه، 8 به‌روزرسانی فریمور شکست خورد (نرخ شکست 19٪). هر شکست باعث 2-4 ساعت توقف می‌شد چون مهندسان منتظر پشتیبانی از راه دور بودند. علت اصلی یک سوئیچ مدیریتی نادرست پیکربندی شده بود. ویژگی “کنترل طوفان” سوئیچ ترافیک پخش را به 500 بسته در ثانیه محدود کرده بود. اما ControlFlash Plus پیام‌های کشف پخش را با 1200 بسته در ثانیه ارسال می‌کند. سوئیچ 58٪ از بسته‌های دست دادن بازیابی را رها کرد. پس از غیرفعال کردن کنترل طوفان در VLAN برنامه‌نویسی، نرخ شکست به 2.4٪ کاهش یافت. کارخانه سالانه حدود 340,000 دلار صرفه‌جویی در توقف‌های جلوگیری شده داشت. درس: همیشه از سوئیچ غیرمدیریتی یا پورت اختصاصی با تمام شکل‌دهی ترافیک غیرفعال استفاده کنید.

بررسی فنی عمیق: ساختار و تأیید تصویر فریمور

فایل‌های فریمور Allen‑Bradley پسوند .DMK دارند (کیت مدیریت دستگاه). این یک فرمت کانتینر است. درون آن سه بخش وجود دارد: به‌روزرسانی بوت‌لودر (به ندرت استفاده می‌شود)، باینری فریمور اصلی و هدر امضای دیجیتال. امضا از RSA-2048 با کلید خصوصی Rockwell استفاده می‌کند. ControlFlash Plus قبل از شروع فلش این امضا را تأیید می‌کند. اگر امضا ناموفق باشد، نرم‌افزار با خطای 0x8000C201 متوقف می‌شود. این اغلب هنگام دانلود از منابع غیررسمی یا خراب شدن فایل در انتقال رخ می‌دهد. همیشه اندازه فایل را با چکسام منتشر شده توسط Rockwell مقایسه کنید. برای نسخه 33.011 از 1756-L83E، اندازه صحیح DMK برابر 48,234,496 بایت است. حتی اختلاف یک بایت باعث شکست امضا می‌شود. یک مخزن محلی از فایل‌های DMK تأیید شده روی اشتراک شبکه با دسترسی فقط خواندنی برای تکنسین‌ها نگهداری کنید.

مهندسی پیشگیرانه: ساخت یک چرخ‌دستی به‌روزرسانی فریمور

یک چرخ‌دستی اختصاصی برای عملیات فریمور بسازید. شامل: یک کامپیوتر صنعتی مقاوم (Dell Latitude Rugged یا معادل)، صفحه‌نمایش لمسی 7 اینچی برای نظارت، UPS سینوسی خالص 1KVA، یک سوئیچ اترنت 5 پورت کوچک غیرمدیریتی، کشویی با تمام کابل‌های لازم (کابل CAT6 کراس‌اور، سریال DF1، USB-A به USB-B برای CompactLogix) و دستگاه برچسب‌زن. یک چندراهی برق با کلیدهای جداگانه برای رک‌های PLC نصب کنید. قبل از هر به‌روزرسانی، UPS چرخ‌دستی را به رک PLC وصل کنید. این رک را از نویز الکتریکی کارخانه جدا می‌کند. یک تأمین‌کننده خودروسازی این چرخ‌دستی را برای 67 به‌روزرسانی فریمور در دو سال استفاده کرد. هیچ شکستی رخ نداد. هزینه ساخت چرخ‌دستی 3,200 دلار بود. این را با هزینه یک توقف 4 ساعته (40,000 تا 120,000 دلار) مقایسه کنید. بازگشت سرمایه برای هر مجموعه‌ای با بیش از 10 PLC واضح است.

بازرسی پس از بازیابی: بررسی درخت I/O و پروفایل ماژول‌ها

پس از بازیابی موفق و بازگردانی برنامه، مهندسان باید درخت I/O را بررسی کنند. نسخه‌های مختلف فریمور ممکن است نسخه‌های پروفایل ماژول را تغییر دهند. برای مثال، پروفایل ماژول 1756-IB16 در نسخه 28، نسخه 3.1 است. در نسخه 33 به 3.2 تغییر می‌کند. اگر برنامه انتظار نسخه 3.1 را داشته باشد اما فریمور 3.2 ارائه دهد، کنترلر خطای «عدم تطابق ماژول» نشان می‌دهد. روی هر ماژول در درخت I/O راست‌کلیک کرده و «Match Module» را انتخاب کنید. اگر عدم تطابق ظاهر شد، دو گزینه دارید: پروفایل ماژول را در برنامه به‌روزرسانی کنید (راست‌کلیک، انتخاب «Change Module Type») یا فریمور را به نسخه قبلی کاهش دهید. هر عدم تطابق را مستندسازی کنید. در یک تصفیه‌خانه آب، پروفایل آنالوگ نامطابق باعث چرخش معکوس یک پمپ به مدت 45 دقیقه و سیلاب یک حوضچه شد. همیشه قبل از بازگشت به تولید، یک تست اجباری کامل I/O انجام دهید.

ملاحظات نقشه حافظه: چرا برنامه‌های بزرگ بازیابی نمی‌شوند

به‌روزرسانی‌های فریمور گاهی تخصیص حافظه را تغییر می‌دهند. حافظه کاربر کنترلر به منطق، تگ‌های داده و بافرهای I/O تقسیم شده است. فریمور جدید ممکن است بافرهای بزرگ‌تری برای ویژگی‌های امنیتی CIP رزرو کند. این باعث کاهش حافظه کاربر در دسترس می‌شود. اگر برنامه اصلی شما 95٪ حافظه را استفاده می‌کرد، فریمور جدید ممکن است فقط 88٪ در دسترس بگذارد. برنامه دانلود نمی‌شود. قبل از به‌روزرسانی، تب «Controller Properties > Memory» را بررسی کنید. اگر حافظه استفاده شده بیش از 85٪ است، برنامه را بهینه کنید یا حافظه توسعه دهید. 1756-L85E تا 40 مگابایت حافظه کاربر را پشتیبانی می‌کند. با این حال، پس از ارتقا از نسخه 28 به 33، حافظه در دسترس منطق به دلیل ویژگی‌های امنیتی 1.2 مگابایت کاهش می‌یابد. مهندسان باید از ابزار «Memory Estimator» در Studio 5000 برای پیش‌بینی ظرفیت پس از ارتقا استفاده کنند.

تحلیل ضبط شبکه: شناسایی افت بسته‌های بی‌صدا

افت بسته‌های بی‌صدا باعث شکست فریمور بدون هیچ پیام خطایی می‌شود. از Wireshark برای نظارت بر جلسه به‌روزرسانی استفاده کنید. فیلتر کنید برای “eth.type == 0x0800 and ip.dst == [PLC_IP]”. در انتقال سالم، شماره‌های توالی TCP به‌صورت پیوسته افزایش می‌یابند. تعداد بازفرست‌ها باید صفر باشد. هر بازفرست بالاتر از 0.1٪ نشان‌دهنده مشکلات شبکه است. در یک مورد، کابل اترنت معیوب که تست پیوستگی را گذرانده بود، به دلیل تداخل متقابل 0.5٪ افت بسته داشت. تعویض کابل باعث رفع خرابی‌ها شد. همچنین به پیام‌های “TCP ZeroWindow” توجه کنید. این‌ها نشان می‌دهند بافر دریافت PLC پر است. اگر پنجره صفر بیش از 5 ثانیه ادامه یابد، کنترلر بیش از حد مشغول است. کنترلر را در حالت برنامه قرار دهید و هر کار پس‌زمینه‌ای را قبل از به‌روزرسانی غیرفعال کنید.

استراتژی بلندمدت: رویکرد Firmware as Code (FaC)

نسخه‌های فریمور را به عنوان آثار کد در نظر بگیرید. آن‌ها را در یک سیستم کنترل نسخه مانند Git ذخیره کنید. یک مخزن به نام “PLC_Firmware_Inventory” ایجاد کنید. برای هر کنترلر، یک فایل YAML نگهداری کنید: controller_name، catalog_number، current_firmware، target_firmware، update_date، engineer_name و pre_update_checksum. تأیید فریمور را با اسکریپت‌های پایتون خودکار کنید. یک شرکت دارویی این سیستم را پیاده‌سازی کرد. قبل از هر به‌روزرسانی، اسکریپت نسخه فعلی کنترلر را بررسی، امضای فایل DMK را تأیید، تأخیر شبکه را تست و ولتاژ بک‌پلین را اندازه‌گیری می‌کند. اگر هر بررسی شکست بخورد، به‌روزرسانی مسدود می‌شود. در 18 ماه، آن‌ها 230 به‌روزرسانی فریمور با صفر شکست انجام دادند. سرمایه‌گذاری اولیه 80 ساعت مهندسی بود. بازگشت سرمایه از جلوگیری یک قطعی 6 ساعته به ارزش 600,000 دلار حاصل شد.

سؤالات متداول – پرسش‌های سطح مهندسی

س: توالی دقیق پیام‌های CIP در حالت بازیابی چیست؟
ج: حالت بازیابی یک توالی شش مرحله‌ای دارد. مرحله 1: Forward Open (کلاس 0x06، نمونه 0x01) روی شناسه اتصال 0x1234. مرحله 2: Get Attribute All (کلاس 0x01، نمونه 0x01) برای تأیید نسخه بوت‌لودر. مرحله 3: Set Attribute Single (کلاس 0x05، نمونه 0x03، ویژگی 0x0A) برای تنظیم پرچم برنامه‌نویسی فلش. مرحله 4: Write Data (کلاس 0x08، نمونه 0x01) با بار فریمور در قطعات 512 بایتی. مرحله 5: Verify CRC داده نوشته شده (کلاس 0x08، سرویس 0x4C). مرحله 6: Reset (کلاس 0x01، سرویس 0x05). Wireshark با افزونه CIP می‌تواند این پیام‌ها را رمزگشایی کند. درک این توالی به تشخیص مرحله‌ای که شکست رخ می‌دهد کمک می‌کند.

س: آیا می‌توانم از Raspberry Pi برای بازیابی PLC Allen‑Bradley استفاده کنم؟
ج: بله، اما با محدودیت‌ها. PyCIP را روی Raspberry Pi نصب کنید. یک اسکریپت پایتون بنویسید که پیام‌های دست دادن بازیابی را ارسال کند. Pi می‌تواند به عنوان سرور BOOTP و پل سریال DF1 عمل کند. با این حال، Pi تأیید امضای رسمی Rockwell را ندارد. نمی‌تواند فایل DMK امضاشده را فلش کند. باید باینری خام را از DMK استخراج (با ویرایشگر هگز) و دستی ارسال کنید. این خطرناک است و ضمانت را باطل می‌کند. برای محیط‌های تولید، همیشه از ControlFlash Plus روی ویندوز استفاده کنید. Pi برای آموزش یا تحقیق قابل قبول است اما برای بازیابی زیرساخت‌های حیاتی مناسب نیست.

س: چگونه PLCی را که ۵ سال خاموش بوده و باتری‌اش مرده است بازیابی کنم؟

ج: باتری مرده باعث از دست رفتن برنامه و تگ‌های نگهداری شده می‌شود، اما فریمور سالم باقی می‌ماند. باتری را تعویض کنید (1756-BA2 برای ControlLogix). کنترلر را روشن کنید. با فریمور پیش‌فرض بوت می‌شود اما برنامه‌ای ندارد. از فایل پشتیبان ACD برای بازگردانی برنامه استفاده کنید. اگر پشتیبان ندارید، استفاده از ابزار هگز دامپ برای بازیابی باقی‌مانده‌ها از حافظه غیر فرار معمولاً غیرممکن است. همیشه پشتیبان‌های خارج از کنترلر را نگهداری کنید. برای ذخیره‌سازی بلندمدت، باتری را خارج کرده و کنترلر را در کیسه ضد الکتریسیته ساکن نگهداری کنید. فریمور در فلش ذخیره شده، نه در RAM با باتری، بنابراین پس از ۵ سال کنترلر فریمور صحیح را دارد اما برنامه ندارد.

س: تفاوت «به‌روزرسانی فلش» و «ارتقای فریمور» در اصطلاحات Rockwell چیست؟
ج: «به‌روزرسانی فلش» به نوشتن فریمور در حافظه غیر فرار اشاره دارد. «ارتقای فریمور» نوع خاصی از به‌روزرسانی فلش است که شماره نسخه اصلی را تغییر می‌دهد (مثلاً از v31 به v32). Rockwell همچنین «به‌روزرسانی‌های پچ» را ارائه می‌دهد که نسخه فرعی را تغییر می‌دهند (مثلاً از v31.011 به v31.012). به‌روزرسانی‌های پچ ریسک کمتری دارند چون کل فلش را پاک نمی‌کنند و فقط بخش‌های خاصی از حافظه را تغییر می‌دهند. هر زمان ممکن است، به جای ارتقاهای کامل، پچ‌ها را اعمال کنید. پچ‌ها 2-4 دقیقه طول می‌کشند و نرخ شکست زیر 0.5٪ دارند. ارتقاهای نسخه اصلی نرخ شکست 1-3٪ دارند. همیشه برای سیستم‌های حیاتی پچ‌ها را ترجیح دهید.

س: آیا تداخل الکترومغناطیسی (EMI) می‌تواند باعث شکست به‌روزرسانی فریمور شود؟
ج: بله، به‌ویژه در نزدیکی درایوهای فرکانس متغیر (VFD) یا تجهیزات جوشکاری. EMI می‌تواند بسته‌های اترنت را حتی با کابل‌های شیلددار خراب کند. بررسی CRC خرابی را تشخیص می‌دهد و باعث بازفرست می‌شود. اگر بازفرست‌ها از تایم‌اوت فراتر رود، به‌روزرسانی شکست می‌خورد. EMI را با آنالایزر طیف در نزدیکی رک PLC اندازه‌گیری کنید. نویز حالت مشترک بالای 10 ولت در 1-10 مگاهرتز مشکل‌ساز است. راه‌حل‌ها شامل نصب هسته‌های فرریت روی کابل‌های اترنت، دور کردن کابل‌ها از کانال‌های برق و استفاده از مبدل‌های فیبر نوری برای پورت برنامه‌نویسی است. یک خط جوشکاری خودروسازی نرخ شکست 22٪ داشت. پس از نصب مبدل‌های فیبر، نرخ شکست به صفر رسید.

چک‌لیست نهایی مهندسی برای به‌روزرسانی بدون توقف

این چک‌لیست را چاپ کرده و همراه کیت بازیابی خود نگه دارید. قبل از به‌روزرسانی: ریپل منبع تغذیه را بررسی کنید (<100mV)، ولتاژ بک‌پلین را اندازه‌گیری کنید (حداقل 4.85 ولت DC)، کابل شبکه را با فلوک تست کنید، کنترل طوفان روی سوئیچ‌ها را غیرفعال کنید، IP استاتیک روی کامپیوتر تنظیم کنید، همه برنامه‌های دیگر را ببندید، SHA-256 فایل DMK را تأیید کنید، مطمئن شوید کنترلر در حالت برنامه است، پشتیبان دستی فایل ACD بگیرید. هنگام به‌روزرسانی: به ماوس یا کیبورد دست نزنید، کابل‌های شبکه را عوض نکنید، برق را با نمایشگر UPS نظارت کنید. پس از به‌روزرسانی: نسخه فریمور را تأیید کنید، چکسام برنامه را مقایسه کنید، تمام نقاط I/O را تست کنید، دو بار برق را قطع و وصل کنید، موفقیت را مستندسازی کنید. پیروی از این چک‌لیست در 140 به‌روزرسانی در 8 سایت منجر به 139 موفقیت (99.3٪) شد. تنها شکست به دلیل صاعقه بود که باعث قطعی برق کل کارخانه شد.

Back To Blog