Vous êtes sur la page 1sur 4

Listingi Wywietlacz widmowy

Listing 1. Konfiguracja sygnau taktujcego


ErrorStatus HSEStartUpStatus;
// Reset ustawie RCC, przywrcenie wartoci domylnych
RCC_DeInit();
// Wczenie HSE
RCC_HSEConfig(RCC_HSE_ON);
// Oczekiwanie a HSE bdzie gotowy
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)
{
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
// zwoka dla pamici Flash
FLASH_SetLatency(FLASH_Latency_2);
// Ustalenie rde i czstotliwoci taktowa poszczeglnych magistral
RCC_HCLKConfig(RCC_SYSCLK_Div1);
RCC_PCLK2Config(RCC_HCLK_Div1);
RCC_PCLK1Config(RCC_HCLK_Div2);
// PLLCLK = 8MHz * 9 = 72 MHz
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
// Wlczenie PLL
RCC_PLLCmd(ENABLE);
// Oczekiwanie a PLL poprawnie sie uruchomi
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
// PLL bdzie rdem sygnau zegarowego
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
// Oczekiwanie a PLL bdzie sygnaem zegarowym systemu
while(RCC_GetSYSCLKSource() != 0x08);
// Wczenie taktowanie GPIOB i TIM2
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1 | RCC_APB2Periph_GPIOA |
RCC_APB2Periph_USART1 | RCC_APB2Periph_AFIO, ENABLE);
}

Listing 2. Konfiguracja wej i wyj


GPIO_InitTypeDef GPIO_InitStructure;
// PA1 wejciem drugiego kanau TIM2, wejcie czujnika
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, & GPIO_InitStructure);
// Konfiguracja wyj sterujacych rejestrami przesuwnymi
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_6 ;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, & GPIO_InitStructure);
// Konfiguracja PA9 jako Tx nadawanie danych do bluetooth
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
// Konfiguracja PA10 jako Rxodbir danych od bluetooth
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);

Listing 3. Konfiguracja kontrolera przerwa


NVIC_InitTypeDef NVIC_InitStructure;
// Waczenie przerwania od TIM1
NVIC_InitStructure.NVIC_IRQChannel = TIM1_CC_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
// Waczenie przerwania od TIM2
NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
// Wczenie przerwania od USART1
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);

Listing 4. Konfiguracja licznika 1


// Konfiguracja ukadu podstawy czasu
TIM_TimeBaseStructure.TIM_Period = 65535;
TIM_TimeBaseStructure.TIM_Prescaler = 360; //fclk = 72MHz/360 = 200kHz
TIM_TimeBaseStructure.TIM_ClockDivision = 0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);
// Konfiguracja kanau 1
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_Timing;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_Pulse = CC1;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OC1Init(TIM1, &TIM_OCInitStructure);
TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Disable);
// Wczenie przerwa od kanaw
TIM_ITConfig(TIM1, TIM_IT_CC1, ENABLE);
// Wczenie timera
TIM_Cmd(TIM1, ENABLE);

Listing 5. Konfiguracja interfejsu USART


USART_InitTypeDef USART_InitStructure;
// Konfiguracja USART
USART_InitStructure.USART_BaudRate = 57600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStructure);
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
USART_Cmd(USART1, ENABLE);

Listing 6. Konfiguracja licznika 2


// Konfiguracja ukadu podstawy czasu
TIM_TimeBaseStructure.TIM_Period = 65535;
TIM_TimeBaseStructure.TIM_Prescaler = 360; //fclk = 72MHz/360 = 200kHz
TIM_TimeBaseStructure.TIM_ClockDivision = 0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
// Konfiguracja kanalu 2 jako "input capture"
TIM_ICInitStructure.TIM_Channel = TIM_Channel_2;
// Reakcja na zbocze narastajce
TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;
TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI;
// Nie uwzgldnianie preskalera, kade zdarzenie jest uwzgldniane
TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;
// Nie uywanie filtra
TIM_ICInitStructure.TIM_ICFilter = 0;
TIM_ICInit(TIM2, &TIM_ICInitStructure);
// Wczenie przerwania od TIM2
TIM_ITConfig(TIM2, TIM_IT_CC2, ENABLE);
// Wczenie timera
TIM_Cmd(TIM2, ENABLE);
Listing 7. Funkcja obsugi przerwania od TIMER 1
void TIM1_CC_IRQHandler(void)
{
//sprawdzenie statusw przerwa od poszczeglnych kanaw
if (TIM_GetITStatus(TIM1, TIM_IT_CC1) != RESET)
{
// Wyzerowanie flagi przerwania
TIM_ClearITPendingBit(TIM1, TIM_IT_CC1);
//Wyzerowanie licznika TIM1
TIM_SetCompare1(TIM1, TIM_GetCapture1(TIM1) + CC1);
//Wywietl kolejn lini obrazu przy nastpnym przerwaniu
c++;
//--------WYWIELTENIE 1 LINII OBRAZU-------
GPIO_ResetBits(GPIOA, GPIO_Pin_4); //Poziom niski na RCLK
for (d=0 ; d<6 ; d++)
{
for (k=0 ; k<8 ; k++)
{
z = (128)>>k;
if (czerwony) //sprawd czy zaczony kolor
{
if ((mapa[a][0][c][d] & z) == z) //czerwony
GPIO_ResetBits(GPIOA, GPIO_Pin_0);
else GPIO_SetBits(GPIOA, GPIO_Pin_0);
}
else GPIO_SetBits(GPIOA, GPIO_Pin_0);
if (zielony) //sprawd czy zaczony kolor
{
if ((mapa[a][1][c][d] & z) == z) //zielony
GPIO_ResetBits(GPIOA, GPIO_Pin_2);
else GPIO_SetBits(GPIOA, GPIO_Pin_2);
}
else GPIO_SetBits(GPIOA, GPIO_Pin_2);
if (niebieski) //sprawd czy zaczony kolor
{
if ((mapa[a][2][c][d] & z) == z) //niebieski
GPIO_ResetBits(GPIOA, GPIO_Pin_3);
else GPIO_SetBits(GPIOA, GPIO_Pin_3);
}
else GPIO_SetBits(GPIOA, GPIO_Pin_3);
//Poziom wysoki na SRCLK
GPIO_SetBits(GPIOA, GPIO_Pin_6);
//Poziom niski na SRCLK
GPIO_ResetBits(GPIOA, GPIO_Pin_6);
}
}
//Poziom wysoki na RCLK
GPIO_SetBits(GPIOA, GPIO_Pin_4);
}
}

Listing 8. Funkcja obsugi przerwania pochodzcego od czujnika


void TIM2_IRQHandler(void)
{
// Jezeli przerwanie od kanalu 2
if (TIM_GetITStatus(TIM2, TIM_IT_CC2) == SET)
{
// Wyzerowanie flagi przerwania
TIM_ClearITPendingBit(TIM2, TIM_IT_CC2);
// Odczytanie wartoci rejestru CCR kanau 2
cnt = TIM_GetCapture2(TIM2);
//Warto do jakiej zlicza ma timer1
CC1 = cnt / 96 ;
//zmie odcie koloru po przejciu czujnika
a++;
if (a>3) a=0; //po przejciu czujnika rozpocznij wywietlanie
//obrazu od pierwszej linii
c=0;
// Zeruj licznik TIM2
TIM_SetCounter(TIM2, 0);
//Wylij warto iloci obrotw przez UART
TxBuf[0]=(uint8_t)(200000/cnt);
USART_ITConfig(USART1, USART_IT_TXE, ENABLE);
}
}

Listing 9. Funkcja obsugi przerwania od USART


void USART1_IRQHandler(void)
{
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
RxBuf[RxIndex++] = USART_ReceiveData(USART1);
if(RxBuf[RxIndex-1] == 0x0D)
{
odebrano_polecenie = 1;
RxIndex = 0;
}
}
if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET)
{
USART_SendData(USART1, TxBuf[TxIndex++]);
if(TxBuf[TxIndex-1] == 0x0D)
{
USART_ITConfig(USART1, USART_IT_TXE, DISABLE);
TxIndex = 0;
}
}
}

Vous aimerez peut-être aussi