180 lines
5.4 KiB
C
Raw Normal View History

2022-02-10 19:03:59 +08:00
#include "stm32_p103.h"
#include "stm32f10x.h"
#include "stm32f10x_gpio.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_usart.h"
#include "stm32f10x_exti.h"
#include "stm32f10x_adc.h"
#include "misc.h"
void init_led(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable GPIO C clock. */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
/* Set the LED pin state such that the LED is off. The LED is connected
* between power and the microcontroller pin, which makes it turn on when
* the pin is low.
*/
GPIO_WriteBit(GPIOC,GPIO_Pin_12,Bit_SET);
/* Configure the LED pin as push-pull output. */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOC, &GPIO_InitStructure);
}
void init_button(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable GPIO A clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
/* Configure the button pin as a floating input. */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOC, &GPIO_InitStructure);
}
void enable_button_interrupts(void)
{
EXTI_InitTypeDef EXTI_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;
/* Enable the AFIO clock. GPIO_EXTILineConfig sets registers in
* the AFIO.
*/
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
/* Connect EXTI Line 0 to the button GPIO Pin */
GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource0);
/* Configure the EXTI line to generate an interrupt when the button is
* pressed. The button pin is high when pressed, so it needs to trigger
* when rising from low to high. */
EXTI_InitStructure.EXTI_Line = EXTI_Line0;
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
EXTI_Init(&EXTI_InitStructure);
/* Enable and set Button EXTI Interrupt to the lowest priority */
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x0F;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x0F;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}
void init_rs232(void)
{
USART_InitTypeDef USART_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable peripheral clocks. */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
/* Configure USART2 Rx pin as floating input. */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Configure USART2 Tx as alternate function push-pull. */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Configure the USART2 */
USART_InitStructure.USART_BaudRate = 9600;
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(USART2, &USART_InitStructure);
USART_Cmd(USART2, ENABLE);
}
void enable_rs232_interrupts(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* Enable transmit and receive interrupts for the USART2. */
USART_ITConfig(USART2, USART_IT_TXE, DISABLE);
USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
/* Enable the USART2 IRQ in the NVIC module (so that the USART2 interrupt
* handler is enabled). */
NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}
void enable_rs232(void)
{
/* Enable the RS232 port. */
USART_Cmd(USART2, ENABLE);
}
void rs232_print_str(const char *str)
{
const char *curr_char = str;
while(*curr_char != '\0') {
while(USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET);
USART_SendData(USART2, *curr_char);
curr_char++;
}
}
/* Functions for sending numbers through the UART */
char hex_to_char(unsigned hex_number)
{
if(hex_number < 0xA) {
return hex_number + '0';
} else {
return hex_number - 0xA + 'A';
}
}
void send_byte(uint8_t b)
{
/* Wait until the RS232 port can receive another byte. */
while(USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET);
/* Toggle the LED just to show that progress is being made. */
GPIOC->ODR ^= 0x00001000;
/* Send the byte */
USART_SendData(USART2, b);
}
void send_number(unsigned long sample, int radix)
{
int digit;
unsigned long mod;
char str[100];
digit = 0;
do {
mod = sample % radix;
str[digit] = hex_to_char(mod);
sample /= radix;
digit++;
} while(sample != 0);
while(digit != 0) {
digit--;
while(USART_GetFlagStatus(USART2, USART_FLAG_TXE) == RESET);
USART_SendData(USART2, str[digit]);
}
}