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

 
 
> LPC1766: порты ввода-вывода тормозят?
poganoe_lamerish...
сообщение Sep 27 2012, 12:39
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 4-07-11
Пользователь №: 66 052



Завязка:
К отладочной плате olymex была варварски припаяна (так как свободно-торчащих пинов на плате нет) самодельная светодиодная матрица 2х2 (схему матрицы могу приложить, если нужно).
Какое-то время мой код для работы с этой матрицей работал без нареканий, а потом в один прекрасный момент я решил поднять частоту процессора (заюзав PLL) до 100 МГц. Светодиоды гореть перестали.
Это явление было не очень стабильным, на разных частотах код вел себя по-разному и не всегда одинаково.

На четвертый день разборок бажный код редуцировался до вот такого фрагмента, который должен выключать все светодиоды. В таком виде код работает.:
Код
LPC_GPIO1->FIOPIN |= (1<<14 | 1<<15);
LPC_GPIO1->FIOPIN &= ~(1<<16 | 1<<17);

А вот в таком - нет. PLL в обоих случаях отключен, проц тактируется от внутренней цепочки на 4Мгц.
Код
uint32_t tempPin;
uint32_t mask;

uint32_t temp;
    
tempPin = LPC_GPIO1->FIOPIN;
mask = (1<<14 | 1<<15);
tempPin |= mask;
    
LPC_GPIO1->FIOPIN = tempPin;

tempPin = LPC_GPIO1->FIOPIN;
mask = (1<<16 | 1<<17);
tempPin &= ~mask;


При пошаговой отладке работают оба варианта. Если вот этот момент
Код
LPC_GPIO1->FIOPIN = tempPin;
tempPin = LPC_GPIO1->FIOPIN;

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

Вопрос: прав ли я или проблема может быть в чем-то другом? Если я прав, где в даташите это описано или как это вообще гуглить, что делать? <_>
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
RabidRabbit
сообщение Sep 27 2012, 13:33
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 397
Регистрация: 3-12-09
Из: Россия, Москва
Пользователь №: 54 040



А почему бы не заюзать FIOSET/FIOCLR, удобней же (на мой взгляд)?


И 3 последние строчки

tempPin = LPC_GPIO1->FIOPIN;
mask = (1<<16 | 1<<17);
tempPin &= ~mask;

вроде вообще не нужны? что они делают?
Go to the top of the page
 
+Quote Post
poganoe_lamerish...
сообщение Sep 27 2012, 13:42
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 4-07-11
Пользователь №: 66 052



Цитата(RabidRabbit @ Sep 27 2012, 17:33) *
А почему бы не заюзать FIOSET/FIOCLR, удобней же (на мой взгляд)?


И 3 последние строчки

tempPin = LPC_GPIO1->FIOPIN;
mask = (1<<16 | 1<<17);
tempPin &= ~mask;

вроде вообще не нужны? что они делают?


Таки да, FIOSET/FIOCLR заюзать можно и работают они корректно. Просто я к портам по указателям обращаюсь и так пришлось бы хранить два указателя, вместо одного. К тому же FIOPIN должен работать точно так же

Три последние строчки - это запись нулей в 16 и 17 бит, то же самое, что FIOPIN &= ~(1<<16 | 1<<17); чтобы выключить столбцы матрицы.
Go to the top of the page
 
+Quote Post
MBR
сообщение Sep 28 2012, 04:55
Сообщение #4


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

Группа: Участник
Сообщений: 107
Регистрация: 26-09-10
Пользователь №: 59 748



Цитата(poganoe_lamerishe @ Sep 27 2012, 17:42) *
FIOPIN &= ~(1<<16 | 1<<17);

Это три инструкции: считать, наложить маску, записать. Set/Clr - одна. У кортекса можно вообще обращаться через битовую память.

А причина такого поведения может быть, если между read/set другой процесс также ставит свои биты в порте. Попробуйте прерывания запретить.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- poganoe_lamerishe   LPC1766: порты ввода-вывода тормозят?   Sep 27 2012, 12:39
|- - alx2   Цитата(poganoe_lamerishe @ Sep 27 2012, 18...   Sep 28 2012, 05:49
||- - poganoe_lamerishe   Цитата(alx2 @ Sep 28 2012, 09:49) В перво...   Sep 28 2012, 11:12
|- - RabidRabbit   Цитата(poganoe_lamerishe @ Sep 27 2012, 17...   Sep 28 2012, 06:49
- - poganoe_lamerishe   В целом, вопрос следующий - это вообще нормальное ...   Oct 1 2012, 15:25
- - ReAl   Такое поведение (когда запись на выход может в сле...   Oct 1 2012, 17:55
|- - poganoe_lamerishe   Цитата(ReAl @ Oct 1 2012, 21:55) Такое по...   Oct 1 2012, 23:51
|- - Petka   Цитата(poganoe_lamerishe @ Oct 2 2012, 03...   Oct 2 2012, 04:46
||- - poganoe_lamerishe   Цитата(Petka @ Oct 2 2012, 08:46) Вот это...   Oct 4 2012, 10:56
|- - esaulenka   Цитата(poganoe_lamerishe @ Oct 2 2012, 03...   Oct 2 2012, 13:16
- - theBMV   Предлагаю Вам для начала посмотреть, на какой част...   Oct 3 2012, 05:35
- - theBMV   Предлагаю Вам для начала посмотреть, правильно ли ...   Oct 3 2012, 05:36
|- - RabidRabbit   Цитата(theBMV @ Oct 3 2012, 09:36) Если н...   Oct 3 2012, 06:07
|- - theBMV   Цитата(RabidRabbit @ Oct 3 2012, 10:07) Э...   Oct 4 2012, 10:17
- - esaulenka   Цитата(theBMV @ Oct 3 2012, 09:36) У меня...   Oct 4 2012, 11:29


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

 


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


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