Перейти к содержанию

    

csm7

Участник
  • Публикаций

    72
  • Зарегистрирован

  • Посещение

Репутация

0 Обычный

Информация о csm7

  • Звание
    Участник

Контакты

  • Сайт
    http://
  • ICQ
    0

Посетители профиля

1 409 просмотров профиля
  1. Спасибо всем за рекомендации. Сейчас разбираюсь с прерываниями для USART. Также хочу прикрутить библиотеку GSM для STM32. Какую библиотеку посоветуете ув. форумчане.
  2. Запустил Переписал код и порты заработали Похоже #include "stm32l1xx.h" #include "stm32l1xx_gpio.h" #include "stm32l1xx_rcc.h" #include "stm32l1xx_usart.h" #include "myinit.h" int main() { initPereherial(); myUsartInit(USART1, 115200); Usart1Send(USART1, 'A'); do { Usart1Send(USART1, 'S'); GPIO_SetBits(GPIOB, LD_GREEN_GPIO_PIN); Delay_ms(100); Usart1Send(USART3, 'T'); GPIO_SetBits(GPIOB, LD_BLUE_GPIO_PIN); Delay_ms(100); GPIO_ResetBits(GPIOB, LD_GREEN_GPIO_PIN | LD_BLUE_GPIO_PIN); Delay_ms(500); }while(1); } в файле myinit.c #include "misc.h" #include "stm32l1xx_adc.h" #include "stm32l1xx_pwr.h" #include "stm32l1xx_rcc.h" //#include "stm32l1xx_rtc.h" #include "stm32l1xx_exti.h" #include "stm32l1xx_gpio.h" #include "main.h" #include "stm32l1xx_syscfg.h" //#include "stm32l1xx_dbgmcu.h" #include "stm32l1xx_usart.h" void initPereherial(void) { GPIO_InitTypeDef GPIO_InitStructure; /* configure gpios */ /* Enable GPIOs clock */ RCC_AHBPeriphClockCmd(LD_GPIO_PORT_CLK, ENABLE); /* Configure the LED_pin as output push-pull for LD3 & LD4 usage*/ GPIO_InitStructure.GPIO_Pin = LD_GREEN_GPIO_PIN | LD_BLUE_GPIO_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz; GPIO_Init(LD_GPIO_PORT, &GPIO_InitStructure); /* Force a low level on LEDs*/ GPIO_LOW(LD_GPIO_PORT,LD_GREEN_GPIO_PIN); GPIO_LOW(LD_GPIO_PORT,LD_BLUE_GPIO_PIN); /* Enable USARTx Clock */ RCC_AHBPeriphClockCmd(RCC_AHBENR_GPIOAEN, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); // GPIO_InitTypeDef GPIO_InitStructure; /* USART1 Rx (PA10) input */ GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_40MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_Init(GPIOA, &GPIO_InitStructure); /* USART1 Tx (PA9) output */ GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_40MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_Init(GPIOA, &GPIO_InitStructure); /* Configuration port PA9, PA10 how alternative function for USART1 */ GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1); GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1); /* Enable the GPIOs clocks */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE); /* Enable PWR, USART3 mngt clocks */ RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_USART3, ENABLE); /* USART3 Tx (PB10) output */ GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_Init(GPIOC, &GPIO_InitStructure); /* USART3 Rx (PB11) input */ GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_Init(GPIOB, &GPIO_InitStructure); /* Configuration prts PC10, PC11 how alternative function for USART3 */ GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_USART3); GPIO_PinAFConfig(GPIOB, GPIO_PinSource11, GPIO_AF_USART3); } void myUsartInit(USART_TypeDef* USARTx, int BaudRate) { USART_InitTypeDef USART_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; /* Configuration USART1 */ USART_InitStructure.USART_BaudRate = BaudRate; 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; /* Take On USART1 */ USART_Init(USART1, &USART_InitStructure); USART_Cmd(USART1, ENABLE); /* Take On USART1 */ /* Initialization USART3 */ USART_Init(USART3, &USART_InitStructure); USART_Cmd(USART3, ENABLE); //after configuration USART configure interrupt // NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn; //channel // NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //priority // NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;//priority subgroup // NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //enable channel // NVIC_Init(&NVIC_InitStructure); //initialization // USART_ITConfig(USART3, USART_IT_RXNE, ENABLE); //take on interrupt for input } void Delay_ms(uint32_t ms) { volatile uint32_t nCount; RCC_ClocksTypeDef RCC_Clocks; RCC_GetClocksFreq (&RCC_Clocks); nCount=(RCC_Clocks.HCLK_Frequency/10000)*ms; for (; nCount!=0; nCount--); } void Usart1Send(USART_TypeDef* USARTx, uint8_t ch) { USART_SendData(USARTx, (uint8_t) ch); //Loop until the end of transmission while(USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET) {} } uint8_t Usart1Get(void) { while ( USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET) {} return (uint8_t)USART_ReceiveData(USART1); } /*************** End My creation ****************/
  3. В мире программистов принято знаки препинания, некоторые буквы ... опускать Дабы ускорить процесс общения
  4. Код идентичен По вопросу библиотек не уверен но я туда не лазил Отлаживаю в CoIDE Оптимизацию отключил Плата stm32l-Discovery
  5. Я пробовал и в USART1 и в USART3 передавать Ничего нет на выходе точнее не могу выйти со строки while(USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);
  6. Инициализация и работа с USART1

    Добрый день форумчане Работаю в CoIDE Пытаюсь передать данные по USARTX Пока ничего не получается в чем проблема #include "misc.h" #include "stm32l_Init.h" #include "stm32l1xx_rcc.h" #include "stm32l1xx_gpio.h" #include "stm32l1xx_usart.h" void RCC_Configuration(){ RCC_HSICmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY)==RESET); RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI); RCC_MSIRangeConfig(RCC_MSIRange_6); RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB | RCC_AHBPeriph_GPIOC, ENABLE); /* My Reset USART1, USART3 */ USART_DeInit(USART1); USART_DeInit(USART3); /* My Enable clocks USART3 PB10 -> USART3_TX, PB11 -> USART3_RX */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); /* Enable PWR, USART3 mngt clocks */ RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_USART3, ENABLE);//RCC_APB1Periph_COMP | /* Enable ADC & SYSCFG clocks */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG , ENABLE); } void Alt_GPIO_Init(GPIO_TypeDef* GPIOx, uint32_t GPIO_Pin){ /* Initialize Leds mounted on STM32L1-DISCOVERY board */ GPIO_InitTypeDef GPIO_InitStructure; /* GPIOB Periph clock enable */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE); /* Configure Port in output pushpull mode */ GPIO_InitStructure.GPIO_Pin = GPIO_Pin; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_40MHz; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_Init(GPIOx, &GPIO_InitStructure); } /****************----------------------------------------------------*******************/ void Alt_UsartInit(USART_TypeDef* USARTx, GPIO_TypeDef* GPIOx, uint32_t GPIO_Pins, uint32_t BaudRate) { /* Конфигурируем порты PB10 - TX, PA11- RX как альтернативную функцию для USART3 */ USART_InitTypeDef USART_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; /* Configure USART3 Rx (PB10 PB11) as input floating */ GPIO_InitStructure.GPIO_Pin = GPIO_Pins; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOx, &GPIO_InitStructure); GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_USART3); GPIO_PinAFConfig(GPIOB, GPIO_PinSource11, GPIO_AF_USART3); /* Настраиваем USARTx */ USART_InitStructure.USART_BaudRate = BaudRate; 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; /* Включаем USARTx */ USART_Init(USARTx, &USART_InitStructure); /* Включаем USARTx */ USART_Cmd(USARTx, ENABLE); } #include "stm32l1xx.h" #include "stm32l1xx_rcc.h" #include "stm32l1xx_gpio.h" #include "stm32l1xx_usart.h" #include "stm32l_Init.h" /* Private define ------------------------------------------------------------*/ #define LD_GREEN_GPIO_PIN GPIO_Pin_7 #define LD_BLUE_GPIO_PIN GPIO_Pin_6 /* Private functions ---------------------------------------------------------*/ void Delay(__IO uint32_t nCount); int main(void) { RCC_Configuration(); Alt_GPIO_Init(GPIOB, LD_GREEN_GPIO_PIN | LD_BLUE_GPIO_PIN); Alt_UsartInit(USART3, GPIOB, GPIO_Pin_10 | GPIO_Pin_11, 9600); while(1) { GPIO_SetBits(GPIOB, LD_GREEN_GPIO_PIN | LD_BLUE_GPIO_PIN); Delay(10000); GPIO_ResetBits(GPIOB, LD_GREEN_GPIO_PIN | LD_BLUE_GPIO_PIN); Delay(10000); USART_SendData(USART3, 's'); while(USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);// } return 0; } Ожидает выход со строки while(USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);//
  7. stm32l

    Спасибо за ответ
  8. stm32l

    Доброго времени суток! Есть плата stm32l-discovery, применял для прошивки и отладки stm32l151. Сейчас заинтересовался stm32f4xx. Могу ли я прошивать и отлаживать на этой плате stm32fxx предварительно ее доработав или перепрошив.
  9. Спасибо попробую копать в этом направлении Команду at+csurv опробовал - с установленной симкой выдает станции оператора симка которого установлена Без симки иногда попадаются и другие операторы но в этом случае приходится использовать команду at+bnd - сканируя каждый диапазон по отдельности.
  10. Запустил AT#CSURV на GL868 V3 Полет нормальный Выдало много разных станций разных операторов
  11. Спасибо С SDR работать не приходилось Это новое направление для меня Да и цена кусается Может модуль другого производителя рассмотреть к примеру Telit Возникла даже такая идея - влезть в прошивку чипсета Qualcomm MDM6200 на котором построен SIM5360 и попробовать свои силы в реверс инженеринге.
  12. Доброго времени суток Необходимо просканировать видимые для модуля SIM5360 базовые станции и получить от них mcc,mnc,lac,cellId. Использовал команды at+cnsvs, at+moni. Ответы этих команд не дают полной информации о всех видимых базовых станциях. При том в ответе одной команды присутствуют одни базовые станции а в другой другие... Может существуют специальные команды позволяющие сканировать базовые станции всех операторов?