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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> mspgcc, явное задание адреса переменной (константы)
MrYuran
сообщение Jan 12 2009, 08:45
Сообщение #1


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



в ИАРе было #pragma location, а здесь как?
пока вроде обходился такой штукой
#define __special_area__ __attribute__((section(".infomem")))

const __special_area__ unsigned long erase_num = 0x0000; // Счётчик стираний
const __special_area__ int default_Treg = 0x0064; // Treg
const __special_area__ int default_Xust = 0x0064; // Xust
const __special_area__ int default_mode = 0x0007; // Mode

а теперь хочу поставить конкретную константу в конкретный адрес.
Как?


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
diwil
сообщение Jan 12 2009, 10:28
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 366
Регистрация: 5-09-06
Из: Санкт-Петербург
Пользователь №: 20 107



несколько способов -
первый:
#define var_name (*(volatile int *)0x1234)

второй:
voaltile int var_name asm("0x1234");
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jan 12 2009, 10:54
Сообщение #3


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(diwil @ Jan 12 2009, 13:28) *
#define var_name (*(volatile int *)0x1234)

оригинально, сам бы не додумался
можно в h-файл поместить, будет равносильно extern


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 12 2009, 11:08
Сообщение #4


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MrYuran @ Jan 12 2009, 12:54) *
можно в h-файл поместить, будет равносильно extern
Нет, не равносильно. Линкер не резервирует место, не следит за непересечением с другими данными.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jan 12 2009, 11:16
Сообщение #5


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(Сергей Борщ @ Jan 12 2009, 14:08) *
Нет, не равносильно. Линкер не резервирует место, не следит за непересечением с другими данными.

Ну да, я об этом уже подумал. Тут надо аккуратность проявлять, особенно если в ОЗУ такие фокусы делать.
Ну а сегменты A и В флеши - мои на 100%.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 12 2009, 14:57
Сообщение #6


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MrYuran @ Jan 12 2009, 13:16) *
Ну а сегменты A и В флеши - мои на 100%.
И что? Вы можете в одном файле разместить по адресу 0x1000 структуру на 10 байт, а в другом файле - long int по адресу 0x1002. Все же линкеру-линкерово, вариант с секциями ненамного сложнее, но значительно безопаснее.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jun 26 2009, 12:02
Сообщение #7


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Продолжаем беседу smile.gif
volatile register unsigned int PC asm("r0");
volatile register unsigned int RSP asm("r1");
volatile register unsigned int PSP asm("r4");
volatile register unsigned int IP asm("r5");
volatile register unsigned int W asm("r6");
volatile register unsigned int TOS asm("r7");

без квалификатора register была ошибка типа non-register variable for register... чего-то там...
Не помню уже.
А теперь пишет:

warning: volatile register variables don't work as you might wish

То есть типа, регистровые переменные могут не работать так, как я мог бы надеяться (насколько позволяет мой инглишь...)

В чём могут быть грабли?
Или не обращать внимания? (не забывая поглядывать листинги)


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
rezident
сообщение Jun 26 2009, 13:56
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(MrYuran @ Jun 26 2009, 18:02) *
В чём могут быть грабли?
Грабли в том, что компиляторы обычно пилюют на тип данных register, т.к. используют регистры по своему собственному разумению. В IAR, например, R4 и R5 можно зарезервировать под свои цели, а все остальные регистры компилятор использует так, как ему нужно. Для размещения локальных переменных и передачи параметров в/из функций.
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jun 26 2009, 14:02
Сообщение #9


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Понятно.
Я как-то забыл, что компилятору тоже регистры нужны...
Единственный вариант порезвиться - __asm__ __volatile__("...")


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jun 26 2009, 15:12
Сообщение #10


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MrYuran @ Jun 26 2009, 15:02) *
warning: volatile register variables don't work as you might wish
aesok объяснял сочетание volatile и register применительно к avr-gcc, но поскольку front-end у них один и тот же - подойдет. И еще в нескольких местах.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jul 28 2009, 06:25
Сообщение #11


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Сходная тема, решил не плодить
Объявляю в сегменте А секцию, размещаю там константы.
Код
#define __SEG_A__    __attribute__((section(".seg_a"),used))
//---------------------------------------------------------------//
//            Параметры по умолчанию (Хранятся в Seg A)             //
//---------------------------------------------------------------//
const __SEG_A__ float cf_T_K_calibr = 0.001;    // Начальное значение K_calibr канала температуры
const __SEG_A__ float cfK_Termo     = 1.2345;    // Коэффициент термокомпенсации
const __SEG_A__ float cfCsens         = 2.345;    // Постоянная датчика проводимости
const __SEG_A__ float cfC3     = 1.0;    // Постоянная датчика 3 канала

const __SEG_A__ unsigned int uiDefaultMode = 0x003f;    // Mode
//    !!! -> Компилить с ключом линкера -Wl,--section-start -Wl,.seg_a=0x1080 <- !!!

Пишет: attribute used ignored
Смотрю листинг - никаких упоминаний ни секции, ни констант.
Естественно, в памяти 0xFF, полная лажа
Ладно.
Инициализирую явно структуру в памяти этими константами.
Код
void InitFlashData()
{
    tempFlashData.T_K_calibr = cf_T_K_calibr;
    tempFlashData.K_Termo = cfK_Termo;
    tempFlashData.Csens = cfCsens;
}

И что же?
Код
00002b7a <InitFlashData>:
    2b7a:    b2 40 6f 12     mov    #4719,    &0x0280;#0x126f
    2b7e:    80 02
    2b80:    b2 40 83 3a     mov    #14979,    &0x0282;#0x3a83
    2b84:    82 02
    2b86:    b2 40 19 04     mov    #1049,    &0x0284;#0x0419
    2b8a:    84 02
    2b8c:    b2 40 9e 3f     mov    #16286,    &0x0286;#0x3f9e
    2b90:    86 02
    2b92:    b2 40 7b 14     mov    #5243,    &0x0288;#0x147b
    2b96:    88 02
    2b98:    b2 40 16 40     mov    #16406,    &0x028a;#0x4016
    2b9c:    8a 02
    2b9e:    30 41           ret

Компилятор взял значения и подсунул напрямую.
Естественно, констант в памяти опять нет.
Что за хитрые компиляторы пошли, хрен обманешь...
Как по-культурному решить эту проблему?
Цель - константы должны лежать в флеши, на эту область я проецирую структуру в памяти


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jul 28 2009, 06:44
Сообщение #12


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MrYuran @ Jul 28 2009, 09:25) *
Как по-культурному решить эту проблему?
Цель - константы должны лежать в флеши, на эту область я проецирую структуру в памяти
Два варианта:
1) Оформить константы в проецируемую структуру и в отдельном файле положить их в нужную секцию в виде структуры. В месте проецирования инициализировать указатель адресом этой структуры, обеспечив обращение таким образом к ней. Да и смысл проецирования? Читать прямо из структуры.
2) В скрипте линкера взять секцию в KEEP().
Мне первый нравится больше.
а!!! Режим компиляции случайно не С++? Тогда попробовать константы в отдельный файл и добавить extern к const


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jul 28 2009, 07:00
Сообщение #13


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(Сергей Борщ @ Jul 28 2009, 10:44) *
Да и смысл проецирования? Читать прямо из структуры.

Это параметры для загрузки при включении и (ре)инициализации
При калибровках, сменах режимов и т.д. они могут меняться и, только если удовлетворены определённые условия, записываться обратно в флешь.
А то, что у меня получилось сейчас, вполне подходит под команду "Загрузить заводские константы"

Цитата(Сергей Борщ @ Jul 28 2009, 10:44) *
а!!! Режим компиляции случайно не С++? Тогда попробовать константы в отдельный файл и добавить extern к const

Да вроде стоит msp430-gcc
Спасибо, сейчас попробую разные варианты

ХЕ, прокатило.
Код
stFlashData __SEG_A__ FlashData = {0.001, 1.2345, 2.345, 1.0, 0x003f};

Вроде очевидно, а самому мозга не хватило...

И в результате:
SYMBOL TABLE:
00001080 l d .seg_a 00000000 .seg_a
00001100 l d .text 00000000 .text
00000200 l d .data 00000000 .data
0000020e l d .bss 00000000 .bss
0000ffe0 l d .vectors 00000000 .vectors
00000000 l d .stab 00000000 .stab
00000000 l d .stabstr 00000000 .stabstr
...
00001080 g O .seg_a 00000012 FlashData (а почему 12?)

А понял, 0x12


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jul 28 2009, 07:41
Сообщение #14


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MrYuran @ Jul 28 2009, 10:00) *
А то, что у меня получилось сейчас, вполне подходит под команду "Загрузить заводские константы"
Все равно описать структуру, завести три экземпляра: один в ОЗУ (рабочий), один - в сегменте констант (заводские калибровки) и один - в инфо-памяти(текущие). Далее копированием одной из флешовых структур в ОЗУшную получаем заводские или текущие параметры. В ОЗУ же их корректируем и сливаем в структуру в инфо-памяти. Работа всегда идет с параметрами из ОЗУшной структуры.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jul 28 2009, 10:00
Сообщение #15


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



flash.h :
Код
typedef struct
{
    float           T_K_calibr;
    float           K_Termo;
    float           Csens;
    float           K_T3;
    unsigned int    Mode;
}   stFlashData;

#define DEFAULTS    {   0.001,\
                        1.2345,\
                        2.345,\
                        1.0,\
                        0x003f }

extern stFlashData tempFlashData;
extern stFlashData FlashData;


flash.c :
Код
stFlashData tempFlashData;
const stFlashData DefaultFlashData = DEFAULTS;
#define __SEG_A__    __attribute__((section(".seg_a")))
//---------------------------------------------------------------//
//            Параметры по умолчанию (Хранятся в Seg A)             //
//---------------------------------------------------------------//
stFlashData __SEG_A__ FlashData = DEFAULTS;

Вроде ничего, а?
хотя надо ещё проверить, куда const закинет...

Ok, всё в порядке
Код
00002b8c <DefaultFlashData>:
    2b8c:    6f 12 83 3a 19 04 9e 3f 7b 14 16 40 00 00 80 3f     o..:...?{..@...?
    2b9c:    3f 00

Хотя нет, не всё...
Опять мои константы повыкидывал!!!
AAAAAAA!!! maniac.gif
Секция есть, структура в ней есть, а данных нету!
Он просто издевается!


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 10:30
Рейтинг@Mail.ru


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