FPGA USART发送字符串

发送数字时候 +“0”;


module uart_send(
    input	      sys_clk,                  //系统时钟
    input         sys_rst_n,                //系统复位,低电平有效

    
    output  reg   uart_txd               //UART发送端口

    );
    
//parameter define
parameter  CLK_FREQ = 50000000;             //系统时钟频率
parameter  UART_BPS = 9600;                 //串口波特率
localparam BPS_CNT  = CLK_FREQ/UART_BPS;    //为得到指定波特率,对系统时钟计数BPS_CNT次


reg[31:0] i;
reg [ 31:0] Data_Count;
reg [7:0] arry [Data_Len-1:0];
parameter [ 31:0] Data_Len=32'd9;//修改此处


//reg define
reg        usart_down;
reg        uart_en_d0; 
reg        uart_en_d1;  
reg [15:0] clk_cnt;                         //系统时钟计数器
reg [ 3:0] tx_cnt;                          //发送数据计数器
reg        tx_flag;                         //发送过程标志信号'b
reg [7:0]  tx_data;
reg        first;



initial begin   
    for(i=0; i<Data_Len; i=i+1'b1) begin    
    case(i)
      0: arry[0] = "j";
      1: arry[1] = "q";
      2: arry[2] = "w"; 
      3: arry[3] = "e"; 
      4: arry[4] = "r"; 
      5: arry[5] = "m"; 
      6: arry[6] = "n"; 
      7: arry[7] = "b"; 
      8: arry[8] = "v"; //修改此处
      endcase
    end 
end 

//*****************************************************
//**                    main code
//*****************************************************
//捕获uart_en上升沿,得到一个时钟周期的脉冲信号
assign en_flag = (~uart_en_d1) & uart_en_d0;


always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin
        usart_down <= 1'b0;   
        first <= 1'b1; 
    end 
    else if (first)begin//创造usart_down的第一个上升沿 first实现
        usart_down <= 1;
        first <= 0;    
    end  
    else if(tx_cnt == 4'd0) begin                                      
        usart_down <= 1;      
    end
    else 
        usart_down <= 0; 
end


//usart_down的边沿检测
always @(posedge sys_clk or negedge sys_rst_n) begin 
    if (!sys_rst_n) begin 
        uart_en_d0 <= 1'b0;
        uart_en_d1 <= 1'b0;          
    end
    else begin
        uart_en_d0  <= usart_down;                   
        uart_en_d1  <= uart_en_d0;
    end   
end



//当脉冲信号en_flag到达时,寄存待发送的数据,并进入发送过程          
always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin                                  
        tx_flag <= 1'b0;
        tx_data <= arry[0];
        Data_Count <= 4'b0; 
    end 
    else if(en_flag) begin                 //检测到发送使能上升沿                      
        tx_flag <= 1'b1;                //进入发送过程,标志位tx_flag拉高
        tx_data <= arry[Data_Count];            //寄存待发送的数据
    end
    else  if((tx_cnt == 4'd10)&&(clk_cnt == BPS_CNT/2))
    begin                               //计数到停止位中间时,停止发送过程
        tx_flag <= 1'b0;                //发送过程结束,标志位tx_flag拉低
        Data_Count<=Data_Count+4'b1;
    if (Data_Count==Data_Len)
        Data_Count<=32'b0;      
    end
end



//进入发送过程后,启动系统时钟计数器与发送数据计数器
always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin                             
        clk_cnt <= 16'd0;                                  
        tx_cnt  <= 4'd0;
    end                                                      
    else if (tx_flag) begin                 //处于发送过程
        if (clk_cnt < BPS_CNT - 1) begin
            clk_cnt <= clk_cnt + 1'b1;
            tx_cnt  <= tx_cnt;
        end
        else begin
            clk_cnt <= 16'd0;               //对系统时钟计数达一个波特率周期后清零
            tx_cnt  <= tx_cnt + 1'b1;       //此时发送数据计数器加1
        end
    end
    else begin                              //发送过程结束
        clk_cnt <= 16'd0;
        tx_cnt  <= 4'd0;
    end
end





//根据发送数据计数器来给uart发送端口赋值
always @(posedge sys_clk or negedge sys_rst_n) begin        
    if (!sys_rst_n)  
        uart_txd <= 1'b1;        
    else if (tx_flag)
        case(tx_cnt)
            4'd0: uart_txd <= 1'b0;         //起始位 
            4'd1: uart_txd <= tx_data[0];   //数据位最低位
            4'd2: uart_txd <= tx_data[1];
            4'd3: uart_txd <= tx_data[2];
            4'd4: uart_txd <= tx_data[3];
            4'd5: uart_txd <= tx_data[4];
            4'd6: uart_txd <= tx_data[5];
            4'd7: uart_txd <= tx_data[6];
            4'd8: uart_txd <= tx_data[7];   //数据位最高位
            4'd9: uart_txd <= 1'b1;         //停止位
            default: ;
        endcase
    else 
        uart_txd <= 1'b1;                   //空闲时发送端口为高电平
end

endmodule	          
  • 3
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: USART_SendData函数可以用来发送单个字符或字节,如果要发送字符串,需要使用循环来逐个发送字符串中的每个字符或字节。以下是一个示例代码: ``` char str[] = "Hello, world!"; int len = strlen(str); for (int i = ; i < len; i++) { USART_SendData(USART1, str[i]); while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); } ``` 这个代码将字符串"Hello, world!"发送USART1串口。首先计算字符串的长度,然后使用for循环逐个发送每个字符。在发送每个字符之后,使用while循环等待USART1串口发送完成标志位TXE被设置,表示数据已经被成功发送。 ### 回答2: USART(通用同步/异步收发器)是一种串行通信协议,它被广泛应用于各种嵌入式系统和通信设备中,用于传输数据或命令。 在嵌入式系统中,我们需要通过UART(通用异步收发器)与其它设备进行通信。而USART是UART的升级版本,支持同步和异步两种传输方式,具有更加稳定可靠的数据传输能力。 当我们需要在嵌入式系统中向其它设备发送字符串时,我们可以使用USART的数据发送函数USART_SendData()。该函数用来发送数据(包括字符、字符串和数字等)到串口通信模块。 在USART_SendData()函数中,我们需要传入两个参数。第一个参数是USARTx,表示我们要使用哪个USART通信模块。第二个参数是data,表示需要发送的数据。 当我们需要发送字符串时,需要同时按照字符串的格式进行处理。在C语言中,字符串是由一系列字符组成的数组,并以'\0'结尾。因此,我们需要借助C语言中的字符串处理函数,将字符串转换为字符数组,并将其按照字符数组的形式发送USART通信模块。 代码示例: #include <stdio.h> #include <string.h> /** * @brief USART数据发送函数 * @param USARTx:USART模块编号 * data:待发送数据 */ void USART_SendData(USART_TypeDef* USARTx, uint16_t data) { /* 等待发送缓冲区为空 */ while((USARTx->SR&0X40) == 0); USARTx->DR = (data & (uint16_t)0x01FF); } /** * @brief 发送字符串函数,通过循环调用USART_SendData()函数将字符数组的每个元素依次发送USART通信模块 * @param USARTx:USART模块编号 * str:待发送字符串 */ void USART_SendString(USART_TypeDef* USARTx, char* str) { uint16_t i = 0; for(i = 0; i < strlen(str); i++) { USART_SendData(USARTx, (uint16_t)str[i]); /* 等待发送完毕 */ while((USARTx->SR&0X40) == 0); } } //将字符串"hello world"发送USART1模块 USART_SendString(USART1, "hello world"); 此时,我们就可以通过USART1模块向其它设备发送字符串了。 ### 回答3: USART_SendData函数是STM32中串口发送数据的函数之一。USART是指通用同步/异步收发传输器,它是一种同步和异步两种传输模式都支持的总线,广泛应用于各种通信领域,包括单片机应用中。 USART_SendData函数的功能是通过USART对外发送数据。在STM32中,USART是由若干个外设寄存器组成,通过编程来实现串口数据的读写,其中USART_SendData函数用于将指定的数据通过USART的数据寄存器发送出去。 该函数的调用方式为: USART_SendData(USART_TypeDef* USARTx, u16 Data) 其中USARTx是指定的USART外设;Data是待发送的数据。 USART_SendData函数的调用过程如下: 1.检查发送缓冲区是否为空,如果不为空,等待缓冲区为空。 2.向USART的数据寄存器中写入数据。 3.等待数据发送完成。 4.返回发送数据的状态。 另外,通常采用中断方式触发发送过程,这样可以在数据传输过程中进行其他操作,通过配置相关的中断标志位来实现数据发送的可靠性和稳定性。 在STM32的项目中,USART_SendData函数的具体应用场景可能比较多,可以用于串口调试、通信等多种领域。通过 USART_SendData发送字符串,可以使用循环将要发送的字符一个一个地放入USART数据缓冲区中,实现串口数据的发送。在发送完成后,如果想让命令提示符立刻刷新,可以通过发送回车符(0x0D)或换行符(0x0A)来实现。 综上所述,USART_SendData函数是STM32中串口发送数据功能的重要函数之一,可以通过该函数将指定的数据通过USART外设传输出去,在实现STM32单片机与其他设备或系统之间的通信,以及各种串口调试等应用场景中得到广泛应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值