реклама на сайте
подробности

 
 
> MSP430F5438A запись в INFO-D без стирания, Возможна ли запись байта без стирания сегмента
k155la3
сообщение Jun 7 2017, 13:37
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 123
Регистрация: 8-03-09
Из: Днепр
Пользователь №: 45 848



MSP430F5438A
Работа с INFO-D флеш сегментом.
Задача - в заполненном иноформацией INFO-D поверх незаписанных байт по фиксированным адресам (содержащим == 0xFF )
прописать несколько байт данных. (не стирая данные по остальным адресам сегмента)

Примеры Ti представлены все со стиранием сегмента.

(?) При выполнении этой ф-ии тестовые байты пишутся, но и сегмент при этом стирается.
Допустим ли в принципе такой режим (не в формате ERASE+WRITE, а только WRITE) ?

Ф-ия выполняется из флеш-памяти.

Код
#define FLASH_BUSY 0x0001
#define FLASH_LOCK 0x0010
void INF_Lock( void )
{
    Flash_ptr = (char *) 0x1800; // INFO-D

    __disable_interrupt();

    FCTL3 = FWKEY;                            // Clear Lock bit
    FCTL1 = FWKEY + WRT;                         // Enable byte/word write mode

    //while ( (FCTL3 & FLASH_BUSY ) != 0 );     // test busy - для RAM
    *Flash_ptr = 0xAB;

     Flash_ptr++;

     //while ( (FCTL3 & FLASH_BUSY ) != 0 );     // test busy
     *Flash_ptr = 0xCD;

     FCTL1 = FWKEY;                                 // Clear WRT bit
     FCTL3 = FWKEY + FLASH_LOCK;           // Set LOCK bit

    __enable_interrupt();

    return;
}




Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
k155la3
сообщение Jun 9 2017, 10:19
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 123
Регистрация: 8-03-09
Из: Днепр
Пользователь №: 45 848



==================== NextStep ================
Симптомы проблемы пролечились, когда я структуры, расположенные в INFO-областях передекларировал на __no_init.
( FIELD_1 расположено в INFO )
Код
_root const TMystruct Mystuct @ "FIELD_1" = { 1,2,3, . . . };

переделано на
Код
_root  _no_init  TMystruct Mystuct @ "FIELD_1";

Предположительно, при записи инициализаций в сегменты C, D на этапе загрузки из программатора, происходит
какая-то накладка (возможно - не отрабатывает таймаут на запись предыдущего сегмента перед записью следующего)
в результате которой (опятьже, возможно) и нарушается содержимое флеша, и работа отладчика.

Go to the top of the page
 
+Quote Post
Baser
сообщение Jun 9 2017, 11:40
Сообщение #3


Просто Che
*****

Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881



Цитата(k155la3 @ Jun 9 2017, 13:19) *
Симптомы проблемы пролечились, когда я структуры, расположенные в INFO-областях передекларировал на __no_init.

Вы ни разу не обмолвились, какой у вас компилятор.
Для ИАР-а применяйте спец конструкцию такого типа, у меня с ней никогда проблем не было:
Код
#pragma segment = "INFOD"
#pragma location = "INFOD"
__root __ro_placement const volatile config_t ConfigFLASH_1;

Go to the top of the page
 
+Quote Post
k155la3
сообщение Jun 12 2017, 06:23
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 123
Регистрация: 8-03-09
Из: Днепр
Пользователь №: 45 848



Цитата(Baser @ Jun 9 2017, 14:40) *
. . . какой у вас компилятор. . . .

IAR C/C++ Compiler for MSP430 6.40.1.950
-------
__ro_placement - не знал.
Спасибо за инф.
Go to the top of the page
 
+Quote Post
NikolyaN
сообщение Jun 15 2017, 11:43
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 20
Регистрация: 28-08-09
Пользователь №: 52 074



Тут пришел Ржевский и все опошлил :-)
В свое время тоже реализовывал подобную задачу. И байтики можно дописывать и в байтиках битики менять с 1 на 0. И все это замечательно работало. Но от использования в коммерческом проекте меня остановил один абзац в SLAU208:
Цитата
7.3.2.1 Byte or Word Write
...
In any write mode, the internally-generated programming voltage is applied to the complete 128-byte
block. The cumulative programming time, tCPT, must not be exceeded for any block. Each byte, word, or
long-word write adds to the cumulative program time of a segment. If the maximum cumulative program
time is reached or exceeded, the segment must be erased. Further programming or using the data returns
unpredictable results (see the device-specific data sheet for specifications).

То есть, как я понимаю это дело. Есть какое-то накапливающееся время подачи программирующего напряжения. При каждой записи байта/слова это время увеличивается. И если оно превысило tCPT (можно посмотреть в даташите на кристалл) то результат становится непредсказуемым.
В итоге было реализовано поочередная запись в 2 сегмента. В сегменте выделен специальный байт в качестве флага. Сначала этот флаг ставится в состояние что данные устарели, потом новые настройки пишутся в другой сегмент, проверяется правильность записи и только потом сегмент со старыми настройками стирается.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 28th July 2025 - 04:56
Рейтинг@Mail.ru


Страница сгенерированна за 0.01395 секунд с 7
ELECTRONIX ©2004-2016