|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
||||||||||||||||
STM32 USB MASS STORAGE in FLASH memory27.08.2016, 17:32. Показов 8274. Ответов 9
Метки нет (Все метки)
Привет!
Есть программа, которая заставляет плату с МК STM32F103RET7 работать в режиме USB MASS STORAGE, причем по USB он отдает куски собственной флеш памяти, с какого-то по какой-то адреса. Файл Mass_Mal.h выглядит вот так:
Mass_Mal.c вот:
https://www.cyberforum.ru/savedimages/2016/08/27/8jmmdrbwxtyhrqgxvbkh.jpg Дампы памяти тоже показывают, что с адресами все в порядке, файловая система создается: https://www.cyberforum.ru/savedimages/2016/08/27/vrlwqgkmmubdxchga1pkvyb.jpg Но все же что-то периодически происходит не так. И я никак не могу отловить причину этого сбоя. 1) Создаю файл 1.txt, заполняю его любым текстом, сохраняю на носителе 2) Перезагружаю МК. Все отлично, файл после перезагрузки виден, чтение данных показывает, что ничего не изменилось. 3) Меняю содержимое файла 1.txt на любое другое, сохраняю 4) Перезагружаюсь. И иногда все отлично, файл открывается без ошибки с тем же самым содержимым. А иногда винда говорит вот такие плохие слова: https://www.cyberforum.ru/savedimages/2016/08/27/zqetggu9ujysyzvpqujktwp.jpg А иногда все хорошо. И это состояние не зависит от длины файла, названия или каких-то таких параметров. Просто иногда и вдруг портится файловая система и файл не получается открыть. В чем может быть проблема? В данном случае работать с отведенной областью флеша может только винда, никакие другие ресурсы в МК не задействованы, кроме самого нужного для запуска USB MSD
0
|
||||||||||||||||
| 27.08.2016, 17:32 | |
|
Ответы с готовыми решениями:
9
Stm32 USB host Mass Storage
STM32 + mass storage + cdc |
|
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 3,113
|
|
| 27.08.2016, 19:06 | |
|
С "извлечения устройства" это не может быть связано? Попробуйте отключать устройство из Wymdows, перед извлечением.
0
|
|
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 27.08.2016, 21:00 | |
|
Попробовал. Однозначно не могу сказать, связано ли с безопасным извлечением.
Залил на диск два файла - APP.BIN и DEBUG.txt. В текстовом записан один символ - 1 или 0 - поочередно меняю это значение и сохраняю на диск. Раз 10 извлекал безопасно и перезагружал - все ОК. Потом кучу раз изменял файл и уже перезагружал без безопасного извлечения (хардварным резетом на плате)- тоже все ОК. И на n-ную перезагрузку вдруг снова фейл. При этом виндоусовский Chkdsk находит ошибку и выдает следующий лог: https://www.cyberforum.ru/savedimages/2016/08/27/tgjytgwka2mnutucspl.jpg Ну и после работы Chkdsk файл DEBUG.txt пропадает с диска
0
|
|
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 27.08.2016, 21:03 | |
|
Видал я в интернете архивчик с примерами для китайской платы Hy-STM32-mini - как-то так называлась она.
Помню, что там шел такой пример - USB-Mass_Storage-MCU Ftosh. Но не могу сейчас найти... Может, завалялся у кого на винте?
0
|
|
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 27.08.2016, 21:31 | |
|
Вот еще какой эксперимент:
Получил снова описанную выше ошибку. Проверил том с помощью Chkdsk без ключа /f - программа проверки исключительно читала файловую систему, ничего не исправляя. Лог: https://www.cyberforum.ru/savedimages/2016/08/27/ztxrshzynxrfjrzy5.jpg И тут же снял дамп FLASH памяти Потом провел проверку тома с ключом /f Лог: https://www.cyberforum.ru/savedimages/2016/08/27/wfaqdfewx9hecsnwbf.jpg И снова снял дамп. Сравнил дампы - различие в одном байте. При этом после исправления файл DEBUG.txt не видится проводником на диске. Разница в дампах на картинке: https://www.cyberforum.ru/savedimages/2016/08/27/adwcuagxtd4emwrbwmqvgc.jpg
0
|
|
|
1 / 1 / 0
Регистрация: 06.12.2016
Сообщений: 553
|
|
| 27.08.2016, 22:53 | |
|
Винда кеширует работу с файловой системой. При безопасном извлечении все изменения сбрасываются на носитель. Если выдернуть девайс без предварительного "извлечения", можно нарваться на ситуацию, когда файл или часть FAT будет не дописана, получится либо битый файл, либо вышеописанная борода.
Если с носителя только читать, то можно выдергивать его в любое время, а вот если писать, то надо "извлекать" сначала. В div managerе винды в свойствах диска можно убрать галку "enable write caching on the divice", тогда кеширование отключится и все изменения винда будет сразу же сбрасывать на устройство, таким образом работа будет медленней, но зато, чтобы сломать файловую систему, выдернуть устройство нужно будет конкретно в тот момент, когда идет запись. ЗЫ: на последней картинке видно, что файл в FAT просто отмечен как удаленный.
0
|
|
|
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 90
|
||
| 27.08.2016, 23:07 | ||
Поделишься результатом с остальными?
0
|
||
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 28.08.2016, 00:22 | |
|
TomityWotf, спасибо за полезную информацию.
С безопасным извлечением - меня смущает то, что при нажатии "Извлечь устройство" ни разу не замечал вызовов функций MAL_Read или MAL_Write (а их вызовы я отслеживаю логическим анализатором), а доступ к чтению/стиранию/записи во флеш происходит исключительно через них. А если они не вызываются, значит безопасное отключение не вносит никаких изменений... Наверное. А еще то, что подобные проблемы возникают не систематически: я иногда повторить не могу по нескольку десятков раз описанную проблему, хотя гоняю с компа на диск кучу файлов. Пока что попробую всегда извлекать носитель безопасно, пособираю статистику крашей FAT. imbidd, круто! Спасибо! У меня был этот архивчик на CD диске когда-то, потом диск поцарапался и я уже отчаялся найти его в сети. Завтра попробую собрать проект из архива и проверить его на подобные глюки. Обязательно поделюсь. Надеюсь даже, что полным проектом.
0
|
|
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 28.08.2016, 12:31 | |
|
Собрал USB-Mass_Storage-MCU Ftosh из китайского проекта - ведет себя точно так же.
И кстати, кажется что по умолчанию кеширование отключено: https://www.cyberforum.ru/savedimages/2016/08/28/avdpbwbnwbmxn5aj.jpg Пока займусь другими вещами, а параллельно буду использовать безопасное извлечение. Посмотрим, будут ли еще краши ФС.
0
|
|
|
0 / 0 / 0
Регистрация: 08.04.2011
Сообщений: 27
|
|
| 04.09.2016, 20:37 | |
|
imbidd, как и обещал - продолжение: https://habrahabr.ru/post/309218/
0
|
|
| 04.09.2016, 20:37 | |
|
Помогаю со студенческими работами здесь
10
LPC1788 Mass Storage device на базе SPI Flash USB on stm32f107 + mass storage USB mass storage class Вопрос по HAL USB MASS STORAGE. Вопрос по USB Mass storage на stm32f103 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
|
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO
Апнулись до NET10.
Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта
так и в интерактивном режиме. из сложностей - чисто функциональный подход.
Решил. . .
|
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2.
Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники".
В. . .
|
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии.
. . .
|
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|