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

 
 
 
Reply to this topicStart new topic
> Keil + LPC, Битовые поля
Пал
сообщение Dec 11 2008, 12:31
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 3-12-08
Пользователь №: 42 171



Уважаемые. кто как обращается к битовым полям регистров перефирии LPC-шников в Keil-е. Нужно сделать так, чтобы эти регистры по прежнему читались как регистры(целиком) и давали доступ к своим битовым полям. Заставить работать Иаровскую конструкцию PINSEL1_bit.P0_28=1 в Кейле не получается.
Go to the top of the page
 
+Quote Post
richie
сообщение Dec 11 2008, 13:14
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 147
Регистрация: 5-07-04
Из: Обнинск
Пользователь №: 261



Цитата(Пал @ Dec 11 2008, 15:31) *
Уважаемые. кто как обращается к битовым полям регистров перефирии LPC-шников в Keil-е. Нужно сделать так, чтобы эти регистры по прежнему читались как регистры(целиком) и давали доступ к своим битовым полям. Заставить работать Иаровскую конструкцию PINSEL1_bit.P0_28=1 в Кейле не получается.

А я, наоборот, пока въезжал в иаровкую идеалгию (на которую забил в итоге) при портировании под
него своих текстов, оставил определения битовых операций и везде их использую. Одинаково
транслируется и под кейл, и под иар, и под гну и т.д.

Сделай опеределения:
#define BIT( i ) ( 1 << ( i ) )
#define CLR_BIT( val, b ) ( ( val ) &= ~BIT( b ) )
#define SET_BIT( val, b ) ( ( val ) |= BIT( b ) )
#define CHK_BIT( val, b ) ( ( ( val ) & BIT( b ) ) == BIT( b ) )

Это типа универсальные определения битовых операций. И используй их.

Для твоего случая:
SET_BIT( PINSEL1, 28 );
Go to the top of the page
 
+Quote Post
Пал
сообщение Dec 11 2008, 14:58
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 3-12-08
Пользователь №: 42 171



Цитата(richie @ Dec 11 2008, 19:14) *
А я, наоборот, пока въезжал в иаровкую идеалгию (на которую забил в итоге) при портировании под
него своих текстов, оставил определения битовых операций и везде их использую. Одинаково
транслируется и под кейл, и под иар, и под гну и т.д.

Сделай опеределения:
#define BIT( i ) ( 1 << ( i ) )
#define CLR_BIT( val, b ) ( ( val ) &= ~BIT( b ) )
#define SET_BIT( val, b ) ( ( val ) |= BIT( b ) )
#define CHK_BIT( val, b ) ( ( ( val ) & BIT( b ) ) == BIT( b ) )

Это типа универсальные определения битовых операций. И используй их.

Для твоего случая:
SET_BIT( PINSEL1, 28 );


Вы меня не поняли. Я про битовые поля Мне нужно обратиться к битам 5-16 регистра ADDR, в которых содержится результат преобразования АЦП. Но прочитать такое поле - полбеды, сдвинул замаскировал и готово. а если модифицировать? Руки сломаешь.
Go to the top of the page
 
+Quote Post
abcdefg
сообщение Dec 11 2008, 15:02
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 23-01-06
Из: Msk
Пользователь №: 13 490



Цитата(Пал @ Dec 11 2008, 17:58) *
Но прочитать такое поле - полбеды, сдвинул замаскировал и готово. а если модифицировать? Руки сломаешь.


гы, все на cortex'ы! smile.gif
Go to the top of the page
 
+Quote Post
Пал
сообщение Dec 11 2008, 15:46
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 3-12-08
Пользователь №: 42 171



Цитата(abcdefg @ Dec 11 2008, 21:02) *
гы, все на cortex'ы! smile.gif


Я не в теме, чем там лучче?
Go to the top of the page
 
+Quote Post
defunct
сообщение Dec 11 2008, 15:53
Сообщение #6


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



из списка фич кортекса:
...
- Unaligned data access, enabling data to be efficiently packed into memory
- Atomic bit manipulation (bit-banging) delivers maximum memory utilization and sreamlined peripheral control
...
Go to the top of the page
 
+Quote Post
richie
сообщение Dec 12 2008, 07:19
Сообщение #7


Частый гость
**

Группа: Свой
Сообщений: 147
Регистрация: 5-07-04
Из: Обнинск
Пользователь №: 261



Цитата(Пал @ Dec 11 2008, 17:58) *
Вы меня не поняли. Я про битовые поля Мне нужно обратиться к битам 5-16 регистра ADDR, в которых содержится результат преобразования АЦП. Но прочитать такое поле - полбеды, сдвинул замаскировал и готово. а если модифицировать? Руки сломаешь.

Ну, руки ломать не надо - это главный инструмент программиста. smile.gif
Но вот голову один раз можно и поломать.
Когда мне нужно работать с битами, то я обычно создаю необходимые макросы, которые работают по
битовым маскам.
Создай макросы типа:
#define GET_REG( reg, mask ) ( (reg) & (mask) )
#define SET_REG( reg, val ) ( (reg) |= (val) )
#define CHK_REG( reg, mask ) ( (reg) & (mask) == (mask) )

#if ( CPU_TYPE == LPC23xx )
#define ADC_DATA_REG AD0DR0
#define ADC_DATA_SHFT 5
#define ADC_DATA_MSK 0x3FF
#define ADC_DONE BIT( 31 )
#define ADC_DONE_STATE 1
#elif (CPU_TYPE == ??? )
....
#endif //CPU_TYPE

#define ADC_GET_DATA() ( GET_REG( ADC_DATA_REG, (ADC_DATA_MSK << ADC_DATA_SHFT) ) >> ADC_DATA_SHFT )
#define ADC_IS_DONE() ( GET_BIT( ADC_DATA_REG, ADC_DONE ) == ADC_DONE_STATE )

На 100% правильность реализации не претендую, вариантов реализации много, кому как нравится.
Но думаю идея понятна.
Go to the top of the page
 
+Quote Post
MaxEngee
сообщение Dec 12 2008, 07:33
Сообщение #8


Частый гость
**

Группа: Свой
Сообщений: 120
Регистрация: 17-03-07
Из: Беларусь, Минск
Пользователь №: 26 249



А что битовые поля уже использовать не модно?

struct my_str{
unsigned z :4;
unsigned a :1;
unsigned b :1;
} stat;

stat.z=5;
stat.a=stat.b=1;

Правда если речь идет о служебных регистрах, которые в иклюде определенны не как битовые поля,то придется либо пользоваться макросами либо научиться пользоваться сдвигами, и, или, и считать биты
Go to the top of the page
 
+Quote Post
Faradey
сообщение Dec 12 2008, 07:54
Сообщение #9


Частый гость
**

Группа: Свой
Сообщений: 127
Регистрация: 31-05-06
Из: Belarus, Minsk
Пользователь №: 17 638



Цитата(MaxEngee @ Dec 12 2008, 09:33) *
А что битовые поля уже использовать не модно?

struct my_str{
unsigned z :4;
unsigned a :1;
unsigned b :1;
} stat;

stat.z=5;
stat.a=stat.b=1;

Правда если речь идет о служебных регистрах, которые в иклюде определенны не как битовые поля,то придется либо пользоваться макросами либо научиться пользоваться сдвигами, и, или, и считать биты


Если речь идет о регистрах, то не стоит забывать про "__packed" или "__attribute__((packed))" (если пользуете ключик "--gnu").

http://www.keil.com/support/man/docs/armcc...he.htm#babcgedf

http://www.keil.com/support/man/docs/armcc...cc_cjadhedh.htm


--------------------
Завтра пойму, что нужно было сделать вчера...
Go to the top of the page
 
+Quote Post
abcdefg
сообщение Dec 12 2008, 08:07
Сообщение #10


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 23-01-06
Из: Msk
Пользователь №: 13 490



Цитата(Пал @ Dec 11 2008, 18:46) *
Я не в теме, чем там лучче?


кроме побитового доступа к некоторым сегментам памяти (bit-band),
есть команды работы непосредственно с битами - BFC (bit field clear), BFI (bit field insert) и UBFX (bit field extract)
Go to the top of the page
 
+Quote Post
triod647
сообщение Dec 13 2008, 09:25
Сообщение #11





Группа: Новичок
Сообщений: 2
Регистрация: 14-11-08
Пользователь №: 41 618



Цитата(Пал @ Dec 11 2008, 17:58) *
Вы меня не поняли. Я про битовые поля Мне нужно обратиться к битам 5-16 регистра ADDR, в которых содержится результат преобразования АЦП. Но прочитать такое поле - полбеды, сдвинул замаскировал и готово. а если модифицировать? Руки сломаешь.


В случае с GPIO (у меня на 16 - 23 висел дисплей) я модифицировал и читал IOPIN , отлично получалось хотя он ReadOnly.
Go to the top of the page
 
+Quote Post
Пал
сообщение Dec 13 2008, 11:01
Сообщение #12


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 3-12-08
Пользователь №: 42 171



Цитата(richie @ Dec 12 2008, 13:19) *
Ну, руки ломать не надо - это главный инструмент программиста. smile.gif
Но вот голову один раз можно и поломать.
Когда мне нужно работать с битами, то я обычно создаю необходимые макросы, которые работают по
битовым маскам.
Создай макросы типа:
#define GET_REG( reg, mask ) ( (reg) & (mask) )
#define SET_REG( reg, val ) ( (reg) |= (val) )
#define CHK_REG( reg, mask ) ( (reg) & (mask) == (mask) )

#if ( CPU_TYPE == LPC23xx )
#define ADC_DATA_REG AD0DR0
#define ADC_DATA_SHFT 5
#define ADC_DATA_MSK 0x3FF
#define ADC_DONE BIT( 31 )
#define ADC_DONE_STATE 1
#elif (CPU_TYPE == ??? )
....
#endif //CPU_TYPE

#define ADC_GET_DATA() ( GET_REG( ADC_DATA_REG, (ADC_DATA_MSK << ADC_DATA_SHFT) ) >> ADC_DATA_SHFT )
#define ADC_IS_DONE() ( GET_BIT( ADC_DATA_REG, ADC_DONE ) == ADC_DONE_STATE )

На 100% правильность реализации не претендую, вариантов реализации много, кому как нравится.
Но думаю идея понятна.



Спасибо, похоже то что мне нужно, попробую разобраться
Go to the top of the page
 
+Quote Post

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

 


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


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