|
|
  |
мигать светодиодом gpio |
|
|
|
Jan 4 2014, 08:24
|

Профессионал
    
Группа: Свой
Сообщений: 1 001
Регистрация: 27-06-06
Пользователь №: 18 409

|
Цитата(mantech @ Jan 4 2014, 09:38)  Это кто такое пишет?? Я думал, только программисты СТ на такое способны #define InvBit(dat, bit) dat ^= (1<<(bit)) Пользуемся так - InvBit(GPIOB, 1); //инвертировать 1-й бит PORTB А что в этом не так? И разве Ваш код подойдёт для ARM, где для установки/сброса пина используются разные регистры? Например для LPC17xx я часто использую такой код: Код void invLED(void) { static int led_stat = 0; if(led_stat) { led_stat = 0; FIO0CLR = 1<<6; } else { led_stat = 1; FIO0SET = 1<<6; } } Найдите процедуру, разберитесь в ней и увидите что в итоге Код FIO_SetValue(2,1<<9); преобразуется к виду Код FIO2SET = 1<<9; Код FIO_ClrValue(2,1<<9); к виду Код FIO2CLR = 1<<9;
|
|
|
|
|
Jan 4 2014, 09:03
|

Профессионал
    
Группа: Свой
Сообщений: 1 001
Регистрация: 27-06-06
Пользователь №: 18 409

|
Цитата(psL @ Jan 4 2014, 12:52)  Код bli?FIO_SetValue(2,bli--<<9):FIO_ClrValue(2,bli++<<9); так короче?  Короче, но не правильно. bli--<<9, bli++<<9 это для чего? Там всегда должно быть (1<<x) или любая другая битовая маска. Если проблема только в длине записи кода, то тогда уж лучше так: Код static int bli = 0; bli?FIO_SetValue(2,1<<9):FIO_ClrValue(2,1<<9); bli ^= 0x1 На худой конец можно и так сделать: Код if(FIO2PIN&(1<<9)) FIO2CLR = 1<<9; else FIO2SET = 1<<9;
|
|
|
|
|
Jan 5 2014, 00:16
|

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

|
Цитата(sergey sva @ Jan 4 2014, 13:10)  Сделаю так, как подсказал mempfis_ как то эстетичней выглядит. )) Вы это серьезно? Завести переменную чтобы хранить в ней значение другой переменной (бита порта) вы называете "эстетичнее"? У вас в Индии родственников нет случайно? Я вот открыл user manual на LPC43xx и там английским по белому написано, что у LPC43xx есть специальный регистр для атомарного инвертирования ноги порта: Код GPIO1NOT = 1UL << bit; Объясните, почему вместо чтения документации вы ищете готовые примеры сомнительного качества? Вы бы хоть указали, какой именно у вас процессор. А то сначала упоминаете LPC43xx, а потом берете код для LPC17xx. Цитата(mempfis_ @ Jan 4 2014, 10:24)  И разве Ваш код подойдёт для ARM, где для установки/сброса пина используются разные регистры? Надо внимательно читать документацию: обычно там есть не только отдельные регистры для установки и сброса. Все это для ARM: для LPC2xxx Код IO1PIN ^= 1UL << bit для ADuC70xx Код GP1DAT ^= 1UL << (bit + 16); для AT91SAM7 Код AT91C_BASE_PIOA->PIO_ODSR ^= 1UL << bit; для LPC11xx, LPC13xx: Код LPC_GPIO1->MASKED_ACCESS[1UL << bit] ^= 1UL << bit; с LPC17хx не приходилось сталкиваться, но должно работать так: Код FIO1PIN ^= 1UL << bit;
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Jan 5 2014, 16:11
|

Профессионал
    
Группа: Свой
Сообщений: 1 001
Регистрация: 27-06-06
Пользователь №: 18 409

|
Цитата(Сергей Борщ @ Jan 5 2014, 03:16)  Вы это серьезно? Завести переменную чтобы хранить в ней значение другой переменной (бита порта) вы называете "эстетичнее"? У вас в Индии родственников нет случайно? Надо внимательно читать документацию: обычно там есть не только отдельные регистры для установки и сброса. Все это для ARM: для LPC2xxx Код IO1PIN ^= 1UL << bit с LPC17хx не приходилось сталкиваться, но должно работать так: Код FIO1PIN ^= 1UL << bit; Спасибо что напомнили, но хамить не нужно (это я про индусов). В LPC43 действительно есть GPIO port toggle registers, который упрощает топикстартеру задачу. UM LPC17 p. 127 GPIO port Pin valueregister FIOxPIN This register provides the value of port pinsthat are configured to perform only digital functions. The register will give the logic value of the pin regardless of whether the pin is configured for input or output, or as GPIO or an alternate digital function. Т.е. если на порту есть несколько цифровых функций, то применив код IO1PIN ^= 1UL << bit можно попасть на такой момент, когда IO1PIN считался, сразу после этого переферия изменила состояние порта (например UART или PWM), потом на значение IO1PIN наложилась маска и новое значение занеслось в IO1PIN. И мы потеряли требуемое состояние порта? Конечно можно запретить прерывания или использовать маскирование доступа (Fast GPIO port Mask register FIOxMASK). Но не все могут знать об эти подробностях (особенно новички, коим я был, когда придумал такой способ инвертирования бита порта).
|
|
|
|
|
Jan 6 2014, 00:49
|

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

|
Цитата(mempfis_ @ Jan 5 2014, 18:11)  Т.е. если на порту есть несколько цифровых функций, то применив код IO1PIN ^= 1UL << bit можно попасть на такой момент, когда IO1PIN считался, сразу после этого переферия изменила состояние порта (например UART или PWM), Если на ногу порта включен вывод периферии, то запись в IOPIN на него влиять не будет и IO1PIN ^= 1UL << bit ничего плохого не сделает: Цитата Selection of a single function on a port pin excludes other peripheral functions available on the same pin. However, the GPIO input stays connected and may be read by software or used to contribute to the GPIO interrupt feature.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|