vivado学习第二 串口通信
- 奇偶校验位
奇偶校验位分为奇数校验位和偶数校验位,奇数和偶数的判断标准是依据发送一串或者一帧数据中“1”的个数。
奇数校验:发送的数据位+奇数校验位中“1”的个数为奇数个,也就是说如果数据位的“1”的个数为奇数个,则奇数校验位为数字0;如果数据位的“1”的个数为偶数个,则奇数校验位为数字1。
偶数校验:发送的数据位+偶数校验位中“1”的个数为偶数个,也就是说如果数据位的“1”的个数为奇数个,则奇数校验位为数字1;如果数据位的“1”的个数为偶数个,则奇数校验位为数字0。 关于拼接运算符
{}拼接运算符的使用方法:
{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的数