本文主要是介绍bcm 使用技巧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1. log和debug使用
使用bcm sdk调试时,其实sdk代码自带很多日志,掌握开启日志的方法可以很方便定位问题:
进入bcm命令行后,输入pwd可以查看当前目录;
cd /flash 切换到想要存文件的目录
输入 log flie=aaa on 在该目录创建aaa文件用于记录bcm终端输出的日志;
debug命令开启不同模块的日志:
开启SOC模块所有日志:
debug SOC +
遇到打印多的情况,手动输入恢复默认配置:
debug SOC =
一般来说这回造成大量输出日志,所以尽可能缩小日志范围:
如只查看soc模块下的phy日志,具体可以通过debug show查看;
debug soc phy debug
debug SOC error,只看err日志;
debug SOC debug,查看debug日志;
2. 查看bcm 表项修改的方法
一般定位bcm问题时,可能由于某个表项mem被修改,但却找不到哪里的代码修改;
可以通过在表项修改的代码增加print_backtrace(参考之前写的文章)来快速定位;
调试时,可以通过修改变量g_test,当出现满足条件的修改时就会输出调用栈信息
3. 使用DEBUG寄存器找出RDBGC原因
简单一些的通过RDBGC0有统计,可以查看ING_EVENT_DEBUG表项
getreg ING_EVENT_DEBUG
其结果代表了,哪个bit或几个bit导致的丢包原因:
可以先停止发包,再使用setreg ING_EVENT_DEBUG 0,然后开启发包;
查看ING_EVENT_DEBUG的值哪个bit置位
如果多个bit置位,可以进一步通过 RDBGC0_SELECT来选择只由某一个bit触发
RDBGC0_SELECT
4. 莫名其妙的表项修改
有时候遇到一些莫名其妙的问题,怀疑是某些表项被修改,但有不确定;
list 模块名,先看看该模块相关的表项或者寄存器listr
二层为常用的表项也要查:
d chg l2_entry
d chg vlan_profile
5. bcm一些命令
5.1 phy相关
phy control xx 查看端口phy的一些配置如CL74、DFE等
BCM.0> phy ge0 * //phy 端口名 *可以查看支持的寄存器名称
Port ge0:
PHYID2r [0x70000002] = 0x600d
REGID1<15:0>=0x600d
PHYID3r [0x70000003] = 0x8770
REGID2<15:0>=0x8770
BCM.0> phy ge0 CL72_TXC_TAP_LIMIT_CTL1r //通过具体的命令可以查看和修改对应寄存器值
6.bcm的部分接口
6.1 获取bcm芯片ID
soc_cm_get_id(unit, &dev_id, &rev_id)
对应 show unit 里面的内容
unit 0:
pci device b170 rev 11
7.bcm查看风暴抑制命令
BCM.0> rate
Current settings:
xe0: Bcast= TRUE,Limit=1000000; Mcast=FALSE ; Dlfbc=FALSE ;
xe1: Bcast=FALSE ; Mcast=FALSE ; Dlfbc=FALSE ;
这篇关于bcm 使用技巧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!