|
Щупаю HAL библиотеку. Групповое управление выводами?, С пинами понятно.А как для шин,когда в этом порту есть независим пины? |
|
|
2 страниц
1 2 >
|
 |
Ответов
(1 - 14)
|
Jul 12 2015, 12:55
|

Знающий
   
Группа: Свой
Сообщений: 815
Регистрация: 7-06-06
Из: Харьков
Пользователь №: 17 847

|
Цитата(Defin @ Jul 12 2015, 14:51)  HAL от ST я так понимаю? Для такой задачи он не нужен, можно просто выставлять биты в регистре BSRR порта GPIO. Можно как задавать выводы для установки, так и для снятия. Спасибо! Да! STM32... Сам HAL это использует... Цитата /** * @brief Sets or clears the selected data port bit. * * @note This function uses GPIOx_BSRR register to allow atomic read/modify * accesses. In this way, there is no risk of an IRQ occurring between * the read and the modify access. * * @param GPIOx: where x can be (A..G depending on device used) to select the GPIO peripheral * @param GPIO_Pin: specifies the port bit to be written. * This parameter can be one of GPIO_PIN_x where x can be (0..15). * @param PinState: specifies the value to be written to the selected bit. * This parameter can be one of the GPIO_PinState enum values: * @arg GPIO_BIT_RESET: to clear the port pin * @arg GPIO_BIT_SET: to set the port pin * @retval None */ void HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState) { /* Check the parameters */ assert_param(IS_GPIO_PIN(GPIO_Pin)); assert_param(IS_GPIO_PIN_ACTION(PinState));
if(PinState != GPIO_PIN_RESET) { GPIOx->BSRR = GPIO_Pin; } else { GPIOx->BSRR = (uint32_t)GPIO_Pin << 16; } } Побитно это уместно. Но на 8 бит лаконично не получится...
|
|
|
|
|
Jul 12 2015, 13:33
|

Знающий
   
Группа: Свой
Сообщений: 815
Регистрация: 7-06-06
Из: Харьков
Пользователь №: 17 847

|
Цитата(Defin @ Jul 12 2015, 16:20)  Этот регистр принимает маску.
GPIOx->BSRR = (маска_пинов_для_установки_в_1) | (маска_пинов_для_установки_в_0 << 16);
Например есть порт GPIOA. Пины 0 - 7 используются для вывода на шину 1 байта. А Пины 8-15 для каких-либо других целей. Допустим управляют светодиодами. И вот в шину понадобилось вывести значение 0xA1, при этом светодиоды не должны изменить своего состояния.
Делается просто:
void setByte(uint16_t value) { GPIOx->BSRR = (0xFF & value) | ((0xFF & (~value)) << 16 ); }
После вызова setByte(0xA1); в порте будут выставлены нужные биты. Ну да!.. Непосредственно в регистр.. "Лучшее - враг хорошего!"(HAL ориентирован на биты) Проще не бывает!.. Я ожидал от HAL боле изящных ходов... Спасибо!
|
|
|
|
|
Jul 12 2015, 20:43
|
Частый гость
 
Группа: Свой
Сообщений: 105
Регистрация: 26-12-11
Из: Казань
Пользователь №: 69 101

|
Цитата(Nixon @ Jul 12 2015, 21:12)  Кто вам мешает делать вызов HAL_GPIO_WritePin с параметрами в виде маски? Код HAL_GPIO_WritePin(GPIOx, PIN1 | PIN2 | | PINX, PinState) Можно, но это подходит только если всем пинам нужно выставить одно состояние. А если необходимо вывести байт иди два на шину - то нет. Цитата(scifi @ Jul 12 2015, 23:07)  +1. Вот сейчас ваяю под LPC4370. У них там софтина называется LPCOpen. Я ваще не понял, зачем оно надо. Документации на софтину практически нет, работать напрямую с регистрами проще и быстрее (про них же написан мануал!). Заглядываю внутрь и вижу индусский говнокод: например, задержка 50 мкс "while(delay--) {}" - это вообще как или где? Такие дела. Видимо, не все софты одинаково полезны. Такие софтины полезны для быстрого освоения процессора/платформы, нет необходимости прыгать по тысячестраничному референс мануалу. Иногда отсутствие документации компенсируется примерами, внятными комментариями к коду или хорошим стилем кода. Но говнокод в таких библиотеках раздражает, приходится допиливать. А если уж нужна скорость работы - то оперировать только регистрами.
|
|
|
|
|
Jul 13 2015, 06:14
|

Знающий
   
Группа: Свой
Сообщений: 815
Регистрация: 7-06-06
Из: Харьков
Пользователь №: 17 847

|
Цитата(Nixon @ Jul 12 2015, 21:12)  Кто вам мешает делать вызов HAL_GPIO_WritePin с параметрами в виде маски? Код HAL_GPIO_WritePin(GPIOx, PIN1 | PIN2 | | PINX, PinState) Именно это меня и ужаснуло!... Коряво..
|
|
|
|
|
Jul 14 2015, 02:49
|

Местный
  
Группа: Участник
Сообщений: 319
Регистрация: 31-01-12
Пользователь №: 69 978

|
Цитата(Сергей Борщ @ Jul 13 2015, 23:42)  Ну ладно, с содержимым функции еще можно было бы смириться, но почему не сделать эту функцию статической и не поместить ее в заголовочный файл? Компилятор бы ужал ее по максимуму и эффективность была бы практически как с прямой записью в регистр. Но видимо это верхняя математика для писателей библиотек. эм. простите что немного не по теме.. я привык считать, что статические функции имеют ограничения и доступны только в пределах библиотеки (за счет чего происходит сжатие - оптимизация). т.е. выражения " сделать эту функцию статической" и " поместить ее в заголовочный файл" взаимоисключающие.. или я чего то не понимаю..?
|
|
|
|
|
Jul 14 2015, 04:29
|
Знающий
   
Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153

|
Цитата(k000858 @ Jul 14 2015, 05:49)  эм. простите что немного не по теме.. я привык считать, что статические функции имеют ограничения и доступны только в пределах библиотеки (за счет чего происходит сжатие - оптимизация). т.е. выражения "сделать эту функцию статической" и "поместить ее в заголовочный файл" взаимоисключающие.. или я чего то не понимаю..? static-функции доступны в пределах единицы трансляции (т.е. файла *.c после подстановки в него всех файлов *.h) static в хидере - это, как я понимаю, замена inline для древних си-компиляторов. Без static будет ошибка линковки. Однако со static, если компилятор не проинлайнит, получится несколько копий одной и той же функции в разных объектниках, а затем и в программе. Для inline, как я понимаю, в таком случае в программе будет одна копия. Что касается громкого слова "библиотека", то это в данном случае это просто набор исходных файлов, которые лежат в отдельной папке и включаются в проект наравне с файлами самой программы.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|