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 ;

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值