ENCYCLOPEDIA VỀ ĐIỆN TỬ TRUYỀN THANH VÀ KỸ THUẬT ĐIỆN Cách kiểm tra tệp HEX. Bách khoa toàn thư về điện tử vô tuyến và kỹ thuật điện Bách khoa toàn thư về điện tử vô tuyến và kỹ thuật điện / Bộ vi điều khiển Многие радиолюбители, пытаясь по журнальной публикации повторить то или иное устройство на микроконтроллере, нередко сталкиваются с необъяснимыми, на первый взгляд, трудностями. Казалось бы, и исправность микроконтроллера сомнений не вызывает, и программатор в полном порядке, и устройство собрано точно по схеме, но работать, как следует, отказывается. В такой ситуации нередки нарекания в адрес автора разработки - представил, дескать, неработоспособную программу! На самом деле в подавляющем большинстве случаев все обстоит иначе. Виноваты ошибки, допущенные при ручном вводе в компьютер НЕХ-файла программы по его "распечатке" на страницах печатного издания. Значительно реже бывают сбои при копировании файлов с дискет или "скачивании" их из Интернета. Как проверить НЕХ-файл? Ответ на этот вопрос - в публикуемой статье. Любая, самая безобидная, на первый взгляд, опечатка в НЕХ-файле ведет к выполнению микроконтроллером (МК) неверной команды, нередко полностью искажает заданный алгоритм его работы и способна привести к совершенно непредсказуемому поведению изготовленного устройства. Ни один самый квалифицированный специалист в этой ситуации не сможет по внешним признакам точно указать место ошибки. Остается очень тщательно и многократно сверять НЕХ-файл с оригиналом. Особенность нашей психики в том, что, проверив что-либо однажды, мы подсознательно убеждены в собственной непогрешимости и при повторных проверках нередко пропускаем то, чего не заметили в первый раз. Поэтому полезно иметь помощника, который, даже не вникая в суть работы, осуществит "независимый контроль". Ни в коем случае не следует оставлять без проверки тексты программ, считанные сканером с последующим распознаванием с помощью программы FineReader и ей подобных. Практика показывает, что ошибки распознавания символов неизбежны даже при очень высоком качестве печатного текста. При вводе НЕХ-файлов вручную (с клавиатуры) или их электронных версий, полученных сканированием, чаще всего случается следующее:
Самый безобидный из этих дефектов - последний. В отличие от других, он не сказывается на работоспособности программы. То же самое в большинстве случаев можно сказать и о нарушении порядка следования строк. Однако программаторы, в которых предусмотрен строгий контроль правильности вводимых данных, могут файл с такими ошибками все-таки забраковать. Нужно сказать, что контроль правильности структуры HEX-файла в процессе его чтения с диска выполняет программное обеспечение очень многих программаторов. Определенные возможности для этого заложены в самой структуре подобного файла, о которой можно прочитать, например, в статье автора "Разработка и отладка устройств на МК" ("Радио", 2001, № 5, с. 19). Беда в том, что программатор зачастую сообщает лишь о факте обнаружения ошибки без каких-либо подробностей, предоставляя пользователю разбираться самому. При этом дефектный файл нередко оказывается полностью или частично загруженным в программатор и, если неосторожно подать команду "Программирование", ошибочные данные будут перенесены в память МК. После этого будет успешно выполнена верификация (сверка содержимого памяти МК и программатора) и у пользователя создастся впечатление, что все в порядке. В этом отношении очень опасно ведет себя программа РоnуРrоg (версии 2.05 и более ранних). Кроме HEX, здесь предусмотрено несколько других форматов входных файлов, и при загрузке она пытается самостоятельно выбрать нужный. Не распознав правильно формат файла с ошибками, она все-таки вводит его как двоичный. На рис. 1 показан вид окна программатора РоnуРrоg после такого ввода. В памяти находятся не машинные коды команд, а ASCI-коды букв и цифр, из которых состоит текстовый НЕХ-файл. Естественно, по такой "программе" МК работать не будет. Вид того же окна после ввода идентичного первому безошибочного файла представлен на рис. 2. Заметим, что никаких сообщений об ошибках или об автоматически определенном формате файла программатор в обоих случаях не давал. Помочь найти и исправить ошибки в НЕХ-файле до ввода его в программатор сможет программа CheckHEX. С ее же помощью можно создать новый НЕХ-файл, набрав его содержимое на клавиатуре компьютера. В последнем случае проверка идет одновременно с вводом данных. Окно данных программы CheckHEX после ввода НЕХ-файла, содержащего несколько ошибок, изображено на рис. 3. В его верхней части слева выведены текущие координаты курсора, показывающего, куда будет введен символ при нажатии клавиши. Справа имеется окошко, щелкнув по которому "мышью", можно в любой момент отменить или вновь разрешить проверку ошибок. Заблокировать контроль бывает полезно на время ручного ввода данных, иначе каждую незавершенную строку сопровождает множество сообщений, только отвлекающих внимание. Окно предупреждений и сообщений об ошибках (рис. 4) находится ниже основного. Сообщения, начинающиеся словом "Информация", лишь свидетельствуют об особом статусе тех или иных строк НЕХ-файла. В данном случае таких строк две. Первая из них необязательна, так как и в ее отсутствие отсчет адресов начнется с нуля. Подобные строки (их может быть несколько в разных местах файла) позволяют адресовать более 64 Кбайт (32 Кслов) памяти. Именно их присутствие отличает НЕХ-файлы формата INX32 от аналогичных формата INX8M. Строка 25 служит признаком конца НЕХ-файла. Если какие-нибудь данные находятся после нее (строка 26), они не будут восприняты программатором. Этим можно воспользоваться, например, чтобы поместить в НЕХ-файл текстовый комментарий. В примере сюда была просто перемещена строка 20 исходного файла, оставшаяся пустой. В принципе, наличие пустых строк в НЕХ-фаиле допустимо, но некоторые программаторы все-таки могут счесть их ошибками. Программа CheckHEX, на всякий случай, предупреждает об этом. Обратите внимание на сообщение об ошибке контрольной суммы в строке 3. Она может быть результатом неправильного ввода любого (кроме двоеточия) символа строки, которую следует проверить особенно внимательно. Приведенная в скобках "правильная" контрольная сумма полезна, если один или несколько символов строки изменены преднамеренно (например, чтобы исправить действительно имевшую место ошибку в программе). В рассматриваемом случае ошибка - результат ввода цифры 8 вместо буквы В. Характер ошибки, допущенной в пятом символе четвертой строки, понятен. Заметим лишь, что для облегчения визуального поиска ошибок шрифт текста в основном окне не содержит символов кириллицы, их место занимают символы, не имеющие ничего общего с правильными. Однако в сообщениях об ошибках русские буквы представлены. Справа от окна данных расположено окно, отображающее картину заполнения памяти МК кодами из анализируемого файла. Фрагмент этого окна - на рис. 5. Белый цвет соответствует свободным ячейкам, синий или красный - занятым. Имеющиеся на рисунке пояснительные надписи (в реальном окне их нет) относятся к типовому для РIС-контроллеров распределению памяти, для других МК и РПЗУ оно может быть совершенно иным. Перемещая курсор "мыши" внутри окна, можно определить адрес любой из отображенных там ячеек. В данном случае курсор (перекрестие в правой верхней части окна) указывает на байт по адресу ООСОН - младший в двубайтном слове по адресу 0060Н. Конечно, пользователь, не разрабатывавший загружаемую программу и внимательно не анализировавший ее, как правило, не знает, какие ячейки должны быть заняты, а какие - нет. Тем не менее есть смысл обратить внимание на разрывы в сплошной последовательности занятых ячеек и лишний раз убедиться, что они появились не в результате ошибок, как в рассматриваемом случае. Отрезок красного цвета говорит о том, что коды, заносимые по этим адресам, встретились в файле неоднократно. В примере (см. рис. 3) идентичны седьмая и восьмая строки. Если дублирующая строка - результат невнимательности при ручном вводе данных, ее можно удалить. Но чаще виновата ошибка, допущенная в адресной части строки (символы с четвертого по седьмой). В подобном случае не только коды по ошибочным адресам будут искажены, но и останется неопределенной область памяти, к которой данная строка относилась исходно. Все это необходимо еще и еще раз проверить. В заключение отметим, что в окне программы CheckHEX имеются три управляющие кнопки: - создать новый НЕХ-фаил; - открыть и проверить существующий ; - сохранить созданный или отредактированный файл. При попытке загрузить или создать еще один файл, предварительно не сохранив измененный вариант старого, программа всегда напоминает о необходимости это сделать. То же самое происходит перед завершением работы программы. Tác giả: A. Dolgiy, Moscow Xem các bài viết khác razdela Bộ vi điều khiển. Đọc và viết hữu ích bình luận về bài viết này. Tin tức khoa học công nghệ, điện tử mới nhất: Máy tỉa hoa trong vườn
02.05.2024 Kính hiển vi hồng ngoại tiên tiến
02.05.2024 Bẫy không khí cho côn trùng
01.05.2024
Tin tức thú vị khác: ▪ Điện thoại thông minh Fujitsu Arrows A 202F ▪ Hình ảnh ba chiều trên màn hình điều khiển Nguồn cấp tin tức khoa học và công nghệ, điện tử mới
Tài liệu thú vị của Thư viện kỹ thuật miễn phí: ▪ phần trang web Động cơ điện. Lựa chọn các bài viết ▪ bài viết Sự thật nói cho chính họ. biểu hiện phổ biến ▪ Các đặc điểm của sự xuất hiện của nhà nước La Mã cổ đại là gì? Câu trả lời chi tiết ▪ bài viết Các thiết bị trên phần tử logic. Đài phát thanh - cho người mới bắt đầu ▪ bài viết Chỉ báo đĩa vệ tinh. Bách khoa toàn thư về điện tử vô tuyến và kỹ thuật điện
Để lại bình luận của bạn về bài viết này: Tất cả các ngôn ngữ của trang này Trang chủ | Thư viện | bài viết | Sơ đồ trang web | Đánh giá trang web www.diagram.com.ua |