STM32 получает вход от счетчика Гейгера - PullRequest
0 голосов
/ 25 февраля 2019

Я пытаюсь отправить выходной сигнал с устройства на фотографии на STM32F100rbt6b.Я подключил контакт UIN от счетчика Гейгера к контакту PA10 на STM32F100rbt6b.Но кажется, что это работает неправильно, потому что каждый раз, когда щелчок счетчика Гейгера ЖК-дисплей не увеличивает число.Я думаю, что это связано с неправильным режимом Pin10.Какой правильный?С GPIO_Mode_IN_FLOATING это слишком большое число приращения.

#include "stm32f10x.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_gpio.h"

#define LCD_PORT GPIOC
#define LCD_RCC_GPIO RCC_AHB1Periph_GPIOC
#define LCD_E_Pin GPIO_Pin_12
#define LCD_RS_Pin GPIO_Pin_10

void delay(unsigned int s);
void lcd_init_gpio();
void lcd_write_data(int data);
void lcd_init();
void lcd_write_str(char*str);
void lcd_write_cmd(u16 cmd);
void lcd_set_cursor(int line,int pos);
void lcd_write_dec_xxx(uint16_t data);
void lcd_write_dec_xxx(uint16_t data);
void lcd_write_dec_xx(uint8_t data);
void lcd_write_dec_x(uint8_t data);
int counter = 0;

int main(void)
{
      lcd_init();
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

        GPIO_InitTypeDef initInput;
        initInput.GPIO_Mode = GPIO_Mode_AIN;
        initInput.GPIO_Speed = GPIO_Speed_2MHz;
        initInput.GPIO_Pin = GPIO_Pin_10;
        GPIO_Init(GPIOA, &initInput);
      lcd_set_cursor(0,1);

    while(1){

                    if (GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_10))
                    {
                        counter=counter+1;
                        lcd_set_cursor(0,3);
                        lcd_write_dec_xxx(((uint8_t)counter));
                        delay(1000000);
                    }           

    }
}

void delay(unsigned int s){
    while(--s > 0) {
        __NOP();
    }
}

const uint8_t lcd_2x16_decode[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };

void lcd_write_dec_xxxx(uint16_t data){
    lcd_write_data(lcd_2x16_decode[(data / 1000) & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 1000) / 100) & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 1000) % 100) / 10 & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 1000) % 100) % 10 & 0x0F]);
}

void lcd_write_dec_xxx(uint16_t data){
    lcd_write_data(lcd_2x16_decode[(data / 100) & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 100) / 10) & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 100) % 10) & 0x0F]);
}

void lcd_write_dec_xx(uint8_t data){
    lcd_write_data(lcd_2x16_decode[((data % 100) / 10) & 0x0F]);
    lcd_write_data(lcd_2x16_decode[((data % 100) % 10) & 0x0F]);
}

void lcd_write_dec_x(uint8_t data) {
    lcd_write_data(lcd_2x16_decode[data]);
}
void lcd_init_gpio() {
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);
    GPIO_InitTypeDef init;
    init.GPIO_Mode = GPIO_Mode_Out_PP;
    init.GPIO_Speed=GPIO_Speed_50MHz;
    init.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_10  | GPIO_Pin_12;
    GPIO_Init(GPIOC, &init);
}
void lcd_write_data(int data) {
    GPIO_SetBits(LCD_PORT,data | LCD_E_Pin);
    delay(0xFFFF);
    GPIO_ResetBits(LCD_PORT,LCD_E_Pin | data);
}
void lcd_init() {
    lcd_init_gpio();
    int del = 99999;
    GPIO_ResetBits(LCD_PORT, LCD_RS_Pin);
    delay(del);
    lcd_write_data(0x30);
    delay(del);
    lcd_write_data(0x30);
    delay(del);
    lcd_write_data(0x30);
    delay(del);
    lcd_write_data(0x38);
    delay(del);
    lcd_write_data(0x0f);
    delay(del);
    lcd_write_data(0x01);
    delay(del);
    lcd_write_data(0x06);
    delay(del);
    lcd_write_data(0x02);
    delay(del);
    GPIO_SetBits(LCD_PORT,LCD_RS_Pin);
}

void lcd_write_str(char*str) {
    do {
        lcd_write_data(*str);
    }while(*++str);
}
void lcd_write_cmd(u16 cmd) {
    GPIO_ResetBits(LCD_PORT,LCD_RS_Pin);
    lcd_write_data(cmd);
    GPIO_SetBits(LCD_PORT,LCD_RS_Pin);
}
void lcd_set_cursor(int line,int pos) {
    pos |=0x80;
    if (line == 1) {
        pos += 0x40;
    }
    lcd_write_cmd(pos);
}

enter image description here

1 Ответ

0 голосов
/ 25 февраля 2019

Вы инициализировали ваш вывод PA10 как аналоговый вход.Если вы хотите использовать аналоговый вход с ЖК-экраном, вам нужно настроить АЦП на этот вывод.

Если вы хотите настроить вывод PA10 в качестве обычного цифрового входа высокого / низкого уровня, вы бысделать что-то вроде этого:

/* Setup PA10 input */
void PA10_Config(void)
{
  /* Local variables */
  GPIO_InitTypeDef   GPIO_InitStructure;

  /* Configure PA10 as input */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
}

Но, глядя на ваше приложение, вы, вероятно, не хотите этого.Скорее всего, вы ищете аналоговый вход с АЦП, который преобразует аналоговое напряжение на этом выводе в число, которое ваш микро может интерпретировать.

Если вы хотели, чтобы PA10 был аналоговым входом с АЦПк сожалению, это невозможно, согласно разделу Table 4. Low & medium-density STM32F100xx pin definitions таблицы данных STM32F100x6, АЦП не указан в качестве одной из альтернативных функций (AF) этого вывода:

enter image description here

...