[ 4.746509] initcall phy_init+0x0/0x6c returned 0 after 186 usecs [ 4.763443] initcall usb_init+0x0/0x17c returned 0 after 16525 usecs [ 4.763483] initcall dual_role_class_init+0x0/0x8c returned 0 after 27 usecs [ 4.774618] initcall usb_phy_generic_init+0x0/0x24 returned 0 after 10861 usecs [ 4.774662] initcall usb_udc_init+0x0/0x70 returned 0 after 31 usecs [ 4.774741] initcall serio_init+0x0/0x44 returned 0 after 65 usecs
时间: 2024-03-27 22:41:01 浏览: 83
这是一段内核启动时的日志信息,其中包含了多个 initcall 的执行情况,每个 initcall 都有一个返回值和执行时间。每个 initcall 都是内核中的一个函数,用于初始化某个子系统或者模块,返回值为 0 表示初始化成功,否则表示初始化失败。
该段日志信息中,每个 initcall 的格式为:
```
initcall function_name+offset/length returned return_value after execution_time usecs
```
其中:
- function_name 表示 initcall 对应的函数名;
- offset 表示函数在内存中的偏移量;
- length 表示函数的长度;
- return_value 表示函数的返回值,0 表示成功,非 0 表示失败;
- execution_time 表示函数执行的时间,单位为微秒。
这些信息可以帮助开发人员了解各个子系统或模块初始化的情况,以及定位可能存在的问题。
相关问题
[ 7.309563] initcall ci_hdrc_usb2_driver_init+0x0/0x10 returned 0 after 396 usecs
这一行文本中,`ci_hdrc_usb2_driver_init+0x0/0x10` 表示函数名,`returned 0` 表示函数返回值为 0,`after 396 usecs` 表示函数执行时长为 396 微秒。
因此,可以使用 sed 命令将这一行文本中的信息提取出来,具体命令如下:
```bash
echo '[ 7.309563] initcall ci_hdrc_usb2_driver_init+0x0/0x10 returned 0 after 396 usecs' | sed -E 's/.*initcall ([^+]+)\+.+ returned ([0-9]+) after ([0-9]+) usecs/\1 \2 \3/g'
```
输出结果为:
```
ci_hdrc_usb2_driver_init 0 396
```
其中,`ci_hdrc_usb2_driver_init` 是函数名,`0` 是函数返回值,`396` 是函数执行时长,三者之间用空格分隔。
该命令的具体解释如下:
- `echo '[ 7.309563] initcall ci_hdrc_usb2_driver_init+0x0/0x10 returned 0 after 396 usecs'`:用于模拟输入原始文本;
- `sed -E`:使用 sed 并开启扩展正则表达式模式;
- `'s/.*initcall ([^+]+)\+.+ returned ([0-9]+) after ([0-9]+) usecs/\1 \2 \3/g'`:使用正则表达式匹配每行中的函数名、返回值和执行时长,并将它们用空格分隔开来;
- `.*initcall`:匹配文本中任意字符,后跟一个空格和 `initcall` 字符串;
- `([^+]+)`:匹配函数名部分,中括号表示匹配其中任意一个字符,加号表示匹配前面的字符至少一次,这里的加号需要使用反斜杠转义;
- `\+.+ returned `:匹配 `+` 和 `returned` 之间的任意字符;
- `([0-9]+)`:匹配返回值部分,中括号表示匹配其中任意一个数字字符,加号表示匹配前面的字符至少一次;
- `after `:匹配 `after ` 字符串;
- `([0-9]+)`:匹配执行时长部分,同上;
- `usecs`:匹配 `usecs` 字符串;
- `/\1 \2 \3/g`:替换成三个匹配到的部分,中间用空格分隔,`g` 表示对每行文本都进行替换操作,而不是只替换第一个匹配项。
[ 7.290235] calling ci_hdrc_platform_register+0x0/0x1c @ 1 [ 7.295997] initcall ci_hdrc_platform_register+0x0/0x1c returned 0 after 169 usecs [ 7.303629] calling ci_hdrc_usb2_driver_init+0x0/0x10 @ 1 [ 7.309563] initcall ci_hdrc_usb2_driver_init+0x0/0x10 returned 0 after 396 usecs
根据您的要求,提取出包含 initcal 的行,删除方括号及里面的内容,并按 after 后面的时间大小重新对文本降序排序,最后在行首添加时间和单位,输出结果如下:
```
396 usecs calling ci_hdrc_usb2_driver_init+0x0/0x10 @ 1
169 usecs calling ci_hdrc_platform_register+0x0/0x1c @ 1
```
希望这能够满足您的需求。
阅读全文