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

 
 
 
Reply to this topicStart new topic
> LPC2478. При включении lcd контроллера сбивается таймер.
madcoat
сообщение Aug 24 2009, 07:01
Сообщение #1





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



Здравствуйте, разбираюсь с отладочным набором NXP LPC2478STK.

По прерываниям от таймера с частотой 100 КHz переключаю дискретный выход (FIO4PIN 31 бит - 12ая нога).
При включении LCD контроллера осциллограф показывает погрешность в 1-2 мкс. Без LCD картина ровная.

Подобное наблюдается при задании двух таймеров. На 100 КHz и на 200 КHz
Погрешности составляют 1-2мкс (без LCD), ~4мкс при включении LCD.

Подскажите пожалуйста в чем может быть дело.
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Aug 24 2009, 10:21
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Погрешность в частоте? Или фронт скачет? Как настраиваете таймер?


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Aug 24 2009, 10:48
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(madcoat @ Aug 24 2009, 11:01) *
Подскажите пожалуйста в чем может быть дело.

Процессор тормозится, пока FIFO LCD-контроллера заполняется, ничего удивительного в общем-то.
Go to the top of the page
 
+Quote Post
madcoat
сообщение Aug 24 2009, 10:49
Сообщение #4





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



Цитата(Andy Mozzhevilov @ Aug 24 2009, 14:21) *
Погрешность в частоте? Или фронт скачет? Как настраиваете таймер?


В обработчике прерывания таймера изменяю дискр.выход. Осциллографом смотрю изменения на ноге.
Импульсы приходят не вовремя - скачет частота.
Вот так настраиваю таймер:
CODE

void clock_init2(Int32U IntrPriority)
{
PCONP_bit.PCTIM2 = 1;// Enable TMR2 clk
T2TCR_bit.CE = 0; // counting disable
T2TCR_bit.CR = 1; // set reset
T2TCR_bit.CR = 0; // release reset
T2CTCR_bit.CTM = 0; // Timer Mode: every rising PCLK edge
T2MCR_bit.MR0I = 1; // Enable Interrupt on MR0
T2MCR_bit.MR0R = 1; // Enable reset on MR0
T2MCR_bit.MR0S = 0; // Disable stop on MR0
// set timer 2 period
T2PR = 0;
T2MR0 = SYS_GetFpclk(TIMER2_PCLK_OFFSET)/(100000);
T2IR_bit.MR0INT = 1; // clear pending interrupt
VIC_SetVectoredIRQ((timer_handler)Timer2IntrHandler,IntrPriority,VIC_TIMER2);
VICINTENABLE |= 1UL << VIC_TIMER2;
T2TCR_bit.CE = 1; // counting Enable
}

static __irq void Timer2IntrHandler (void)
{
T2IR_bit.MR0INT = 1;
FIO4_bit.P4_31 ^=1;
VICADDRESS = 0;
}
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Aug 24 2009, 11:25
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



В вашем случае должна скакать не частота, а гулять фронты.
Причину джиттера aaarrr уже озвучил, LCD отъедает часть пропускной способности AHB, вот вы и ждете, когда она освободится, прежде чем сможете записать изменение в порт.

Точнее, судя по структурной схеме из UM "LPC2478 block diagram" ожидание доступа к шине у вас должно возникать при обращении к регистрам таймера и VIC. Попробуйте при входе в прерывание первым делом проинвертировать внешний пин, а потом все остальное.
Хотя это только в простейшем случае - если вы не читаете адрес фукнции прерывания из VIC.
Можете еще попробовать посадить таймер на FIQ.
Хотя генерить программно такие частоты - не кошерно.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post

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

 


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


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