当前位置:首页>Linux>Linux PCIe子系统 DPC(Downstream Port Containment)机制的驱动详解

Linux PCIe子系统 DPC(Downstream Port Containment)机制的驱动详解

  • 2026-04-19 07:24:53
Linux PCIe子系统 DPC(Downstream Port Containment)机制的驱动详解
PCIe DPC(Downstream Port Containment)机制是一种关键的错误隔离技术,通过软件与硬件协同工作,当检测到下游设备错误时自动隔离故障端口,防止错误传播影响整个系统,其软件实现主要围绕DPC能力结构、中断处理和错误恢复流程构建。

一、DPC机制核心概念与作用

1. 基本定义与定位

  • DPC(Downstream Port Containment)
     是PCIe协议中定义的下游端口隔离机制,作为PCIe端口的可选规范特性
  • 主要功能:当在端口或端口下游检测到未屏蔽的不可纠正错误时,DPC会停止Downstream Port下方的PCI Express流量,避免数据损坏的潜在传播
  • 依赖关系
    DPC机制依赖AER(Advanced Error Reporting)提供的错误信息来进行错误处理,两者通常结合使用以提供更全面的错误处理和容错机制

2. DPC的核心作用

  • 错误隔离
    自动隔离故障设备,限制错误影响范围
  • 系统保护
    防止错误通过PCIe链路传播到其他设备
  • 可靠性提升
    确保系统其他部分在部分设备故障时仍能继续正常工作
  • 错误恢复
    支持CER(Containment Error Recovery)机制,尝试恢复系统功能

二、DPC机制软件实现框架

1. DPC软件架构层次

  • 硬件层
    PCIe设备的DPC能力结构寄存器
  • 驱动层
    PCIe端口驱动中的DPC服务模块
  • 系统层
    操作系统错误处理和恢复机制
  • 用户层
    系统管理工具和监控接口

2. DPC能力结构关键组件

  • DPC Capability Register (Offset 04h)
    定义DPC功能支持情况
  • DPC Control Register (Offset 06h)
    配置DPC触发条件和行为
  • DPC Status Register (Offset 08h)
    记录DPC触发状态和原因
  • DPC Error Source ID Register (Offset 0Ah)
    记录错误源设备ID
  • RP PIO Error Controls
    Root Port特有错误控制机制

3. DPC控制寄存器关键字段

  • DPC Trigger Enable
    控制DPC触发条件
    • 00b:默认关闭
    • 01b:启用并在ERR_FATAL触发
    • 10b:启用并在ERR_NONFATAL/ERR_FATAL触发
  • DPC Interrupt Enable
    启用DPC中断通知
  • DPC ERR_COR Enable
    启用ERR_COR消息发送
  • DPC Software Trigger
    支持软件触发DPC功能

三、DPC驱动软件实现详解

1. DPC初始化流程

  • 驱动注册
    在Linux系统中,DPC服务作为PCIe端口服务驱动注册
staticvoiddpc_remove(struct pcie_device *dev){	struct pci_dev *pdev = dev->port;	u16 ctl;	pci_read_config_word(pdev, pdev->dpc_cap + PCI_EXP_DPC_CTL, &ctl);	ctl &= ~(PCI_EXP_DPC_CTL_EN_FATAL | PCI_EXP_DPC_CTL_INT_EN);	pci_write_config_word(pdev, pdev->dpc_cap + PCI_EXP_DPC_CTL, ctl);}static struct pcie_port_service_driver dpcdriver = {	.name		= "dpc",	.port_type	= PCIE_ANY_PORT,	.service	= PCIE_PORT_SERVICE_DPC,	.probe		= dpc_probe,	.remove		= dpc_remove,};int __initpcie_dpc_init(void){	return pcie_port_service_register(&dpcdriver);}
  • 中断配置
    设置DPC中断处理
    status = devm_request_threaded_irq(device, dev->irq, dpc_irq, dpc_handler,     IRQF_SHARED, "pcie-dpc", pdev);
  • DPC功能使能
    配置DPC控制寄存器
    ctl = (ctl & 0xfff4) | PCI_EXP_DPC_CTL_EN_FATAL | PCI_EXP_DPC_CTL_INT_EN;pci_write_config_word(pdev, pdev->dpc_cap + PCI_EXP_DPC_CTL, ctl);

2. DPC中断处理流程

  • 上半部处理(dpc_irq)
    1. 读取DPC状态寄存器,判断是否有DPC中断触发
    2. 清除中断标志位
    3. 如果检测到DPC触发,唤醒下半部处理
  • 下半部处理(dpc_handler)
    • RP PIO错误:调用dpc_process_rp_pio_error()
    • AER相关错误:获取AER错误信息并处理
    1. 读取DPC状态寄存器,确定DPC触发原因
    2. 读取DPC错误源ID寄存器,识别错误来源
    3. 根据错误类型执行相应处理:
    4. 清除DPC触发状态,准备链路恢复

3. DPC错误处理核心逻辑

void dpc_process_error(struct pci_dev *pdev) {    // 读取DPC状态寄存器    pci_read_config_word(pdev, cap + PCI_EXP_DPC_STATUS, &status);    // 读取错误源ID    pci_read_config_word(pdev, cap + PCI_EXP_DPC_SOURCE_ID, &source);    // 解析错误原因    reason = (status & PCI_EXP_DPC_STATUS_TRIGGER_RSN) >> 1;    ext_reason = (status & PCI_EXP_DPC_STATUS_TRIGGER_RSN_EXT) >> 5;    // 特殊错误处理分支    if (pdev->dpc_rp_extensions && reason == 3 && ext_reason == 0) {        dpc_process_rp_pio_error(pdev);    } else if (reason == 0 &&         dpc_get_aer_uncorrect_severity(pdev, &info) &&         aer_get_device_error_info(pdev, &info)) {        aer_print_error(pdev, &info);        pci_aer_clear_nonfatal_status(pdev);        pci_aer_clear_fatal_status(pdev);    }}

4. DPC恢复流程

  • DPC触发后
    1. 设置DPC Trigger Status和DPC Trigger Reason
    2. 将LTSSM状态机设置为Disable状态,禁用链路
    3. 发送中断或ERR_COR消息通知系统
  • 恢复过程
    1. 软件清除DPC状态
    2. LTSSM状态机转换到Detect状态
    3. 链路重新训练
    4. 恢复正常通信

四、DPC与AER的协同工作机制

1. 错误处理流程整合

  • AER角色
     检测和报告PCIe设备的错误详情
  • DPC角色
     根据AER提供的错误信息采取隔离措施
  • 协同方式
     当AER检测到不可纠正错误时,触发DPC机制进行端口隔离

2. 实际工作流程

  1. PCIe设备发生错误,AER机制检测到错误
  2. AER收集错误详细信息并记录到寄存器
  3. 如果错误满足DPC触发条件,DPC机制被激活
  4. DPC停止下游流量,隔离故障设备
  5. 系统通过AER获取错误详情,决定恢复策略
  6. 恢复成功后,重新启用PCIe链路

3. 错误类型处理策略

  • 可纠正错误
     AER记录日志,通常不触发DPC
  • 不可纠正非致命错误
     AER记录日志,可能触发DPC
  • 不可纠正致命错误
     AER记录日志,必定触发DPC进行端口隔离

五、DPC机制的实际应用场景

1. 服务器环境中的应用

  • 内存ECC错误
     通过PCIe RAS上报,自动隔离故障内存通道
  • NVMe硬盘故障
     检测到不可恢复错误时,自动隔离故障硬盘
  • GPU可靠性
     显卡驱动崩溃时触发DPC中断重置设备

2. 热插拔场景

  • 安全热插拔
     在热插拔PCIe设备时,DPC机制确保在移除设备前安全地停止数据传输
  • Surprise Down处理
     当PCIe设备在操作系统不知情的情况下突然停止响应,DPC机制自动隔离故障设备

3. 系统调试与验证

  • 软件触发DPC
     通过sysfs接口触发DPC流程,用于系统验证
    echo dpc_sw_trigger > reset_methodecho 1 > reset
  • 完成验证后可恢复默认设置:
    # echo default > reset_method

六、DPC机制软件实现的关键注意事项

1. 驱动开发要点

  • 中断处理
    DPC中断处理必须高效,避免长时间占用中断上下文
  • 错误恢复
    恢复流程需确保链路状态正确转换,避免数据损坏
  • 兼容性
    需考虑不同PCIe设备和平台的差异性

2. 系统集成考虑

  • AER配置同步
    DPC配置应与AER配置保持一致,确保错误处理连贯性
  • RP PIO管理
    Root Port特有错误需特殊处理,建议与AER配置同步
  • 软件触发机制
    用于系统验证的软件触发DPC功能需谨慎使用

3. 性能与可靠性平衡

  • DPC触发阈值
    合理配置DPC Trigger Enable,避免过度敏感或反应迟钝
  • 恢复策略
    根据系统需求选择合适的恢复策略,平衡系统可用性与数据完整性

七、总结与建议

1. 核心价值总结

  • DPC机制是PCIe系统可靠性保障的关键组件,通过自动隔离故障设备防止错误传播
  • 软件实现需紧密结合硬件特性
    充分利用PCIe协议定义的寄存器和机制
  • 与AER协同工作
    形成完整的错误检测、报告和恢复流程

2. 实践建议

  • 系统设计阶段
    在系统架构设计中充分考虑DPC机制的作用,合理规划错误处理流程
  • 驱动开发阶段
    严格按照PCIe规范实现DPC功能,确保与AER的协同工作
  • 系统部署阶段
    根据应用场景配置适当的DPC触发条件,平衡系统可用性与可靠性

3. 未来发展方向

  • 更智能的错误预测
    结合AI技术预测潜在错误,提前触发DPC机制
  • 更精细的恢复策略
    根据不同错误类型实现差异化恢复策略
  • 与虚拟化技术整合
    在虚拟化环境中更好地利用DPC机制提升系统可靠性

理解DPC机制的软件实现框架,有助于开发人员构建更可靠的PCIe系统,特别是在服务器、数据中心等对可靠性要求极高的场景中,DPC机制的有效实现能够显著提升系统的稳定性和可用性。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-20 06:03:37 HTTP/2.0 GET : https://f.mffb.com.cn/a/484916.html
  2. 运行时间 : 0.158260s [ 吞吐率:6.32req/s ] 内存消耗:4,711.58kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=a26ef96f8c06c49ea4e9ba4facd0aff2
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000632s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000812s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000356s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000296s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000519s ]
  6. SELECT * FROM `set` [ RunTime:0.000210s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000633s ]
  8. SELECT * FROM `article` WHERE `id` = 484916 LIMIT 1 [ RunTime:0.000621s ]
  9. UPDATE `article` SET `lasttime` = 1776636217 WHERE `id` = 484916 [ RunTime:0.006006s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.001278s ]
  11. SELECT * FROM `article` WHERE `id` < 484916 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000538s ]
  12. SELECT * FROM `article` WHERE `id` > 484916 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000818s ]
  13. SELECT * FROM `article` WHERE `id` < 484916 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.003148s ]
  14. SELECT * FROM `article` WHERE `id` < 484916 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.003485s ]
  15. SELECT * FROM `article` WHERE `id` < 484916 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.000910s ]
0.160039s