Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Помогите со SPORT портом у blackfina пожалста
Форум разработчиков электроники ELECTRONIX.ru > Цифровая обработка сигналов - ЦОС (DSP) > Алгоритмы ЦОС (DSP)
Soyma
Вот
Код
*pSPORT0_TCR1 = 0x0A02; // внутренняя CLK и FCLK не зависящая от данных
*pSPORT0_TCR2 = 0x0007; // восьмиразрядные слова
*pSPORT0_TCLKDIV = 0x0080;
*pSPORT0_TFSDIV = 0x0008;
*pSPORT0_TCR1 |= TSPEN; // Enable SPORT0 Transmitter
    
for(i = 0; i <= 327680-1; i++)  {
    while(!(*pSPORT0_STAT & TXHRE));
    *pSPORT0_TX = 0x55;
}


Смотрю осцилографом. CLK спорта выходят, кадровые импульсы тоже есть, а вот данных нет.
Soyma
Мож подкините пример работы со SPORTом без использования DMA (по прерываниям)?
fontp
Цитата(Soyma @ Mar 1 2007, 10:18) *
Мож подкините пример работы со SPORTом без использования DMA (по прерываниям)?


Чтобы разрешить прерывания, нужно инициализировать (до пуска SPORT) SIC, handler на IVG9 и IMASK

*pSIC_IAR0 = 0xf2ffffff;

// assign ISRs to interrupt vectors
// Sport0 TX ISR(as well as RX) -> IVG 9
register_handler(ik_ivg9, Sport0_TX_ISR);

// enable Sport0 TX interrupt
*pSIC_IMASK = 0x00000040;

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

Вот мне попался пример использования SPORT в качестве UART, без dMA smile.gif
http://www.blackfin.org/phorum/read.php?10,5971

Там только RX а не ТХ но принцип тот же. Вообще на blackfin.org много примеров, хороших и разных
Soyma
Всё, разобрался!!!
Вот рабочий пример
В SPORT выдаётся цифирка, у спорта передатчик завёл на приёмник и дальше вываливаю цифирку в UART, ...
Код
int m; int i; int k; int l;

*pSPORT0_RCR1 = 0x4000;
*pSPORT0_RCR2 = 0x0006;
//*pSPORT0_RCLKDIV = 0x0080;
//*pSPORT0_RFSDIV = 0x0007;
//*pSPORT0_RX16 = 0x55; // Use 16-bit Access Macro to Write Register
  
*pSPORT0_TCR1 = 0x4E02;
*pSPORT0_TCR2 = 0x0006;
*pSPORT0_TCLKDIV = 0x0080;
*pSPORT0_TFSDIV = 0x0006;
//*pSPORT0_TX16 = 0x00; // Use 16-bit Access Macro to Write Register
*pSPORT0_TCR1 |= TSPEN; // Enable SPORT0 Transmitter
*pSPORT0_RCR1 |= RSPEN; // Enable SPORT0 Transmitter

for(m = 0; m <= 327680; m++)  {
for(m = 0; m <= VEC_SIZE-1; m++)  {       
    while(!(*pSPORT0_STAT & TXHRE));
    *pSPORT0_TX16 = 0x72;
    while(!(*pSPORT0_STAT & RXNE));
    spectrum[m] = *pSPORT0_RX16;
}
for(m = 0; m <= VEC_SIZE-1; m++)  {
    while (!(*pUART_LSR & TEMT)) { };
    while (!(*pUART_LSR & THRE)) { };
    *pUART_THR = spectrum[m];
}
}
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.