default:
gcc -o ul2switch main_ul2switch.c -lua -lreg -lpthread
clean:
rm -rf ul2switch
root@HNXS:/home/hnxs/l2switch# make
系统 输入 如下:gcc -o ul2switch main_ul2switch.c -lua -lreg -lpthread
以后 目录会多发作 一个ul2switch文件 root@HNXS:/home/hnxs/l2switch# ls
main_ul2switch.c Makefile ul2switch
root@HNXS:/home/hnxs/l2switch# ./ul2switch
fastU->REG Version:20180827,OpenBox HW Version:2020210329
fastU->Register UA to FAST Kernel! Wait Reply......
fastU->UA->pid:3069,mid:129,Register OK!
fastU->libua version:20180827
fastU->fast_ua_recv......
/*UA模块初始化*/
ua_init(mid);
/*设置
硬件默许
规则,将硬件一切
报文送到模块ID为mid的历程
处置赏罚
*/
fast_reg_wr(FAST_ACTION_REG_ADDR|FAST_DEFAULT_RULE_ADDR,ACTION_SET_MID<<28|mid);
/*启动线程吸收
分配给UA历程
的报文*/
fast_ua_recv();
/*主历程
进入暂停形状
,数据处置赏罚
主要
在回调函数*/
pause();
void ua_init(u8 mid)
{
int ret = 0;
/*向系统
注册,自己
历程
处置赏罚
报文模块ID为mid的一切
报文*/
if((ret=fast_ua_init(mid,callback)))//UA模块实例化(输入
参数1:吸收
模块ID号,输入
参数2:吸收
报文的回调处置赏罚
函数)
{
perror("fast_ua_init!\n");
exit (ret);//若是
初始化失败,则需求
打印失败信息,并将法式竣事
参与
!
}
}
int callback(struct fast_packet *pkt,int pkt_len)
{
return 0;
}
xprintf("inport:%d,dstmid:%d,len:%d,dmac:%02X:%02X:%02X:%02X:%02X:%02X,smac:%02X:%02X:%02X:%02X:%02X:%02X\n",
pkt->um.inport,pkt->um.dstmid,pkt_len,pkt->data[0],pkt->data[1],pkt->data[2],pkt->data[3],pkt->data[4],pkt->data[5],pkt->data[6],pkt->data[7],pkt->data[8],pkt->data[9],pkt->data[10],pkt->data[11]);
void pkt_send_normal(struct fast_packet *pkt,int pkt_len)
{
xprintf("pkt_send_normal->%p,outport:%d,len:%d\n",pkt,pkt->um.outport,pkt_len);
pkt->um.pktsrc = 1;/*报文泉源
为CPU输入
,站在硬件角度*/
pkt->um.pktdst = 0;/*报文目的为硬件输入
*/
pkt->um.dstmid = 5;/*直接从硬件GOE模块输入
,不走剖析
、查表等模块*/
fast_ua_send(pkt,pkt_len);/*挪用
FAST API函数发送*/
}