vivado学习第二 串口通信

vivado学习第二 串口通信

  1. 奇偶校验位
     奇偶校验位分为奇数校验位和偶数校验位,奇数和偶数的判断标准是依据发送一串或者一帧数据中“1”的个数。
    奇数校验:发送的数据位+奇数校验位中“1”的个数为奇数个,也就是说如果数据位的“1”的个数为奇数个,则奇数校验位为数字0;如果数据位的“1”的个数为偶数个,则奇数校验位为数字1。
    偶数校验:发送的数据位+偶数校验位中“1”的个数为偶数个,也就是说如果数据位的“1”的个数为奇数个,则奇数校验位为数字1;如果数据位的“1”的个数为偶数个,则奇数校验位为数字0。
  2. 关于拼接运算符
     {}拼接运算符的使用方法:
    {4{w}}; //这等同于{w,w,w,w}
    {b,{3{a,b}}}; //这等同于{b,a,b,a,b,a,b}
    注意:在位拼接表达式中不允许存在没有指明位数的信号。
    例如:{4{1}};//这种写法是错误的,因为没有指定1的位数,计算机编译器无法识别。正确写写法应该是{4{1’b1}};
     {}拼接运算符和算术运算符一起使用:
    例子一:
    wire[MEM_DATA_BITS - 1:0] rd_burst_data; // 这里定义了rd_burst_data为MEM_DATA_BITS这么个的位数。

    assign err = rd_burst_data_valid &(rd_burst_data != {MEM_DATA_BITS/8{rd_cnt[7:0]}}); //MEM_DATA_BITS/8是字节数, 然后用位接复制的方法,产生64位数据和rd_burst_data进行比较。
    例子二:
    output[MEM_DATA_BITS/8 - 1:0] local_be,

assign local_be = {MEM_DATA_BITS/8{1’b1}}; // local_be 实际为8·`b11111111的数

https://blog.csdn.net/USB_ABC/article/details/52745002

你可能感兴趣的:(奇偶校验,位缩减运算,verilog,VIVADO)