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

nilll

Новичок
  • Постов

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

  • Посещение

Репутация

0 Обычный
  1. добрый день всем. Вопрос такой: можно ли каким либо способом узнать список имен файлов в таком то каталоге на ftp сервере с помощью sim900???? Вопрос горит :( Помогите кто нибудь с ответом.
  2. Всем привет. Вопрос такой: Можно ли открывать сразу несколько файлов на чтение или на запись одновременно в ftp у sim900? Реализованно ли это? А то что то у меня не хочет :)
  3. USART stm32

    Проблема следующем. Хочу организовать между платой stm32f103 и sim900d по usart1 обмен. Все хорошо, но никак не хочет работать прерывание по приему. По передачи работает. По приему цикл вставлял даже while(1) {}, и ниче не зависает. Вот код: /*---------------------------------------------------------------------------- * Name: Usart.c * Purpose: USART usage for STM32 * Note(s): *---------------------------------------------------------------------------- * This file is part of the uVision/ARM development tools. * This software may only be used under the terms of a valid, current, * end user licence from KEIL for a compatible version of KEIL software * development tools. Nothing else gives you the right to use this software. * * This software is supplied "AS IS" without warranties of any kind. * * Copyright © 2011 Keil - An ARM Company. All rights reserved. *----------------------------------------------------------------------------*/ #include <stdio.h> #include "STM32F10x.h" int r = 0; /*---------------------------------------------------------------------------- Notes: The length of the receive and transmit buffers must be a power of 2. Each buffer has a next_in and a next_out index. If next_in = next_out, the buffer is empty. (next_in - next_out) % buffer_size = the number of characters in the buffer. *----------------------------------------------------------------------------*/ #define TBUF_SIZE 256 /*** Must be a power of 2 (2,4,8,16,32,64,128,256,512,...) ***/ #define RBUF_SIZE 256 /*** Must be a power of 2 (2,4,8,16,32,64,128,256,512,...) ***/ /*---------------------------------------------------------------------------- *----------------------------------------------------------------------------*/ #if TBUF_SIZE < 2 #error TBUF_SIZE is too small. It must be larger than 1. #elif ((TBUF_SIZE & (TBUF_SIZE-1)) != 0) #error TBUF_SIZE must be a power of 2. #endif #if RBUF_SIZE < 2 #error RBUF_SIZE is too small. It must be larger than 1. #elif ((RBUF_SIZE & (RBUF_SIZE-1)) != 0) #error RBUF_SIZE must be a power of 2. #endif /*---------------------------------------------------------------------------- *----------------------------------------------------------------------------*/ struct buf_st { unsigned int in; /* Next In Index */ unsigned int out; /* Next Out Index */ char buf [RBUF_SIZE]; /* Buffer */ }; static struct buf_st rbuf = { 0, 0, }; #define SIO_RBUFLEN ((unsigned short)(rbuf.in - rbuf.out)) static struct buf_st tbuf = { 0, 0, }; #define SIO_TBUFLEN ((unsigned short)(tbuf.in - tbuf.out)) static unsigned int tx_restart = 1; /* NZ if TX restart is required */ /* Тупая задежка */ void Delay(uint32_t Val) { Val = Val * 10000; for( ; Val != 0; Val--) { __nop(); } } /*---------------------------------------------------------------------------- Initialize UART pins, Baudrate *----------------------------------------------------------------------------*/ void USART1_Init (void) { int i; RCC->APB2ENR |= ( 1UL << 0); /* enable clock Alternate Function */ AFIO->MAPR &= ~( 1UL << 2); /* clear USART1 remap */ RCC->APB2ENR |= ( 1UL << 2); /* enable GPIOA clock */ GPIOA->CRH &= ~(0xFFUL << 4); /* clear PA9, PA10 */ GPIOA->CRH |= (0x0BUL << 4); /* USART1 Tx (PA9) output push-pull */ GPIOA->CRH |= (0x04UL << 8); /* USART1 Rx (PA10) input floating */ RCC->APB2ENR |= ( 1UL << 14); /* enable USART#1 clock */ USART1->BRR = 0x0271; /* 115200 baud @ PCLK2 72MHz */ USART1->CR1 = (( 1UL << 2) | /* enable RX */ ( 1UL << 3) | /* enable TX */ ( 1UL << 5) | /* enable RXNE Interrupt */ ( 1UL << 7) | /* enable TXE Interrupt */ ( 0UL << 12) ); /* 1 start bit, 8 data bits */ USART1->CR2 = 0x0000; /* 1 stop bit */ USART1->CR3 = 0x0000; /* no flow control */ for (i = 0; i < 0x1000; i++) __NOP(); /* avoid unwanted output */ NVIC_EnableIRQ(USART1_IRQn); USART1->CR1 |= (( 1UL << 13) ); /* enable USART */ } /*---------------------------------------------------------------------------- USART1_IRQHandler Handles USART1 global interrupt request. *----------------------------------------------------------------------------*/ void USART1_IRQHandler (void) { volatile unsigned int IIR; struct buf_st *p; IIR = USART1->SR; if (IIR & USART_SR_RXNE) { /* read interrupt */ USART1->SR &= ~USART_SR_RXNE; /* clear interrupt */ p = &rbuf; if (((p->in - p->out) & ~(RBUF_SIZE-1)) == 0) { p->buf [p->in & (RBUF_SIZE-1)] = (USART1->DR & 0x1FF); p->in++; } } if (IIR & USART_SR_TXE) { USART1->SR &= ~USART_SR_TXE; /* clear interrupt */ p = &tbuf; if (p->in != p->out) { USART1->DR = (p->buf [p->out & (TBUF_SIZE-1)] & 0x1FF); p->out++; tx_restart = 0; } else { tx_restart = 1; USART1->CR1 &= ~USART_SR_TXE; /* disable TX IRQ if nothing to send */ } } } /*------------------------------------------------------------------------------ buffer_Init initialize the buffers *------------------------------------------------------------------------------*/ void buffer_Init (void) { tbuf.in = 0; /* Clear com buffer indexes */ tbuf.out = 0; tx_restart = 1; rbuf.in = 0; rbuf.out = 0; } /*------------------------------------------------------------------------------ SenChar transmit a character *------------------------------------------------------------------------------*/ int SendChar(int c) { struct buf_st *p = &tbuf; if (SIO_TBUFLEN >= TBUF_SIZE) /* If the buffer is full */ return (-1); /* return an error value */ p->buf [p->in & (TBUF_SIZE - 1)] = c; /* Add data to the transmit buffer. */ p->in++; if (tx_restart) { /* If TX interrupt is disabled */ tx_restart = 0; /* enable it */ USART1->CR1 |= USART_SR_TXE; /* enable TX interrupt */ } return (0); } void SendString(uint8_t *s) { while (*s != '\0') { SendChar(*s); s ++; } } /*------------------------------------------------------------------------------ GetKey receive a character *------------------------------------------------------------------------------*/ int GetKey (void) { struct buf_st *p = &rbuf; if (SIO_RBUFLEN == 0) return (-1); return (p->buf [(p->out++) & (RBUF_SIZE - 1)]); } /*---------------------------------------------------------------------------- MAIN function *----------------------------------------------------------------------------*/ int main (void) { char c; buffer_Init(); /* init RX / TX buffers */ USART1_Init(); RCC->APB2ENR |= RCC_APB2ENR_IOPCEN; //Затактировали порт GPIOC->CRH &= ~GPIO_CRH_CNF8; //определили режим работы. GPIOC->CRH |= GPIO_CRH_MODE8_0; //определили направление. GPIOC->BSRR =GPIO_BSRR_BR8; // Установили 0. Delay(1000); GPIOC->BSRR =GPIO_BSRR_BS8; //Установили на выводе 1 Delay(2000); GPIOC->BSRR =GPIO_BSRR_BR8; // Установили 0. Delay(3000); GPIOC->BSRR =GPIO_BSRR_BS8; //Установили на выводе 1 Delay(7000); SendString("AT\r\n"); Delay(200); while (1) { } }
×
×
  • Создать...