当前位置:首页>Linux>Linux DMA技术(一)介绍

Linux DMA技术(一)介绍

  • 2026-03-27 16:45:56
Linux DMA技术(一)介绍

大家好,我是小志。我们的口号是:学习、成长、应对未来风险。

什么是 DMA( (Direct Memory Access )?为什么需要它?

想象一下,如果没有 DMA,当你的 BMC 需要从网络接收一个大数据包,或者从 Flash 芯片读取固件镜像时,会发生什么?

CPU 需要像一个勤劳的搬运工,亲自一个字节一个字节地从外设(比如网卡)读取数据,然后写入到内存中。这个过程被称为可编程 I/O (PIO)。对于大数据量传输,这会极大地消耗 CPU 资源,导致系统整体性能下降,CPU 无法专注于更重要的任务,比如监控系统状态、处理 IPMI 命令等。

DMA 就是为了解决这个问题而生的。

 DMA 的核心思想是解放 CPU。它通过一个专门的硬件模块——DMA 控制器 (DMAC),让外设能够不经过 CPU,直接与系统内存进行高速数据交换。 

一个生动的比喻:

  • 没有 DMA (PIO 模式): CPU 是科学家,却被迫去做搬运砖块(数据)的工作,效率低下且浪费人才。

  • 有 DMA: CPU 是项目经理,它只需要告诉 DMA 控制器(专业的搬运队):“把 A 处的砖块搬到 B 处,一共 N 块”。然后 CPU 就可以去处理更复杂的计算和调度任务,等搬运队完成后,再来检查成果。

DMA的工作原理

 一个典型的 DMA 传输过程可以分为以下几个步骤: 

  1. 初始化:

     CPU 配置 DMA 控制器,告诉它三个关键信息:

    • 源地址: 数据从哪里来(例如,网卡的接收缓冲区地址)。

    • 目标地址: 数据到哪里去(例如,系统内存中的一块缓冲区地址)。

    • 传输长度: 需要搬运多少数据。

  2. 启动传输: CPU 发出启动命令,然后就可以“脱身”去处理其他任务了。

  3. 数据传输: 外设(如网卡)准备好数据后,向 DMA 控制器发出请求。DMA 控制器接管系统总线,直接在内存和外设之间进行数据搬运。

  4. 完成通知: 当所有数据搬运完毕后,DMA 控制器会向 CPU 发送一个中断信号,通知它传输已完成。

DMA 缓存一致性

在配备缓存的CPU上面,最近访问的内存区域的副本被缓存,甚至为DMA映射的内存区域也会被缓存。现实情况是两个独立设备之间的共享内存通常是产生缓存一致性问题的根源,缓存不一致源于其他设备可能不知道另一个设备的更新写入。另外,缓存一致性确保每个写操作似乎是即时发生的,这意味着共享同一内存区域的所有设备将看到完全相同的更改序列。

假设一个CPU配备了缓存以及一个可以通过DMA直接访问设备的外存,当CPU访问内存位置X时,当前值会存储在缓存中,对X的后续操作将更新X的缓存副本,但不会更新X的外存版本(假设是写回内存),如果在下一次设备试图访问X之前没有将缓存刷新到内存,则设备将收到X的旧值。同样,如果在设备写入新值到内存时,X的缓存副本没有被无效化,CPU将操作X的旧值。

这个问题有两种解决方案。

🟠  硬件解决方案。这些系统是一致性系统。

🟠  软件解决方案,其中操作系统负责确保缓存一致性。这些系统是非一致性系统。

Linux 内核中的 DMA 框架

Linux 内核为 DMA 操作提供了一套完善的子系统,以屏蔽不同硬件的差异,方便驱动开发者使用。其中两个最核心的概念是 DMA Mapping 和 DMA Engine

为DMA目的分配的内存缓冲区必须相应地被映射。DMA映射包括为DMA分配内存缓冲区,并为此缓冲区生成总线地址。为DMA分配内存缓冲区不是简单用kmalloc分配普通内存,而是分配满足 DMA 控制器苛刻要求的内存 —— 普通内存可能存在 “物理地址离散、缓存干扰、DMA 不可访问” 等问题,必须专门分配。DMA 控制器是独立于 CPU 的硬件,它访问内存的规则和 CPU 完全不同:

🟠  多数 DMA 控制器只认物理连续的地址(无法像 CPU 一样通过 MMU 访问离散物理页);

🟠  DMA 访问内存时绕开 CPU 缓存(直接读物理内存),缓冲区需禁用缓存或保证缓存一致性;

🟠  部分架构中,DMA 只能访问特定范围的物理地址(比如 ARM 的低端内存区)。

总线地址≠CPU物理地址,DMA控制器访问内存时用的地址由总线桥(如PCIE ,AXI)转换而来。

CPU 通过「内存总线」直接访问内存,用的是 “物理地址”;DMA 控制器通常挂在「PCIe/AXI/AMBA 总线」上,通过「总线桥」中转访问内存 —— 总线桥会对地址做 “重映射”(比如 CPU 物理地址 0x40000000,经过 PCIe 桥后,DMA 看到的总线地址是 0x80000000)。

1. DMA Mapping (DMA 映射)

它的主要任务是解决 CPU 和外设“看到的”内存地址不一致的问题

  • CPU 的视角: CPU 使用虚拟地址来访问内存。

  • 外设的视角: 外设(通过 DMA 控制器)只能识别物理地址或总线地址。

DMA Mapping API 的作用就是为驱动分配或映射一块内存,并返回一个外设能够直接访问的地址(DMA 地址)。它主要分为两种类型:

  • 一致性映射 (Coherent Mapping):

    • 特点: 分配一块 CPU 和外设都能访问的内存,并且保证两者看到的数据是完全一致的。内核会自动处理 CPU 缓存(Cache)与内存之间的同步。

    • API:dma_alloc_coherent()

    • 适用场景: 适用于需要频繁共享的小块数据,比如设备的描述符环(Descriptor Ring)、控制结构体等。在 OpenBMC 中,用于与外设进行命令和状态交互的共享内存区域就非常适合用这种方式。

  • 流式映射 (Streaming Mapping):

    • CPU -> 设备 (写操作): 传输前,CPU 需要调用 dma_sync_single_for_device(),确保 CPU 写入的数据从 Cache 刷新到主内存。

    • 设备 -> CPU (读操作): 传输后,CPU 需要调用 dma_sync_single_for_cpu(),确保 CPU 能从主内存中读取到设备写入的最新数据。

    • 特点: 用于单次或偶尔的大块数据传输。它不会自动维护缓存一致性,需要驱动程序在传输前后手动调用同步接口。

    • API:dma_map_single() / dma_unmap_single()

    • 适用场景:

       适用于一次性的大数据传输,比如网络数据包的收发、音视频帧的搬运。

2. DMA Engine (DMA 引擎)

这是一个更高层的框架,位于 drivers/dma/ 目录下。它提供了一套统一的 API,让驱动开发者可以方便地请求和使用 DMA 通道进行数据搬运,而无需深入了解底层 DMA 控制器的寄存器细节。

  • 功能: 它抽象了不同厂商的 DMA 硬件,支持链式传输 (Chain DMA) 和分散-聚集 (Scatter-Gather) 等高级功能。

  • Scatter-Gather DMA: 这是一种强大的模式,允许单次 DMA 操作处理多个在物理上不连续的内存块。这对于处理网络数据包等场景非常高效,因为数据包可以被分散存储在内存中,而无需先拷贝到一块连续的内存里。

典型应用场景

  1. 网络通信 (Ethernet MAC):

    • 这是 DMA 最经典的应用。当 OpenBMC 作为服务器管理控制器时,需要处理大量的网络请求(如 Redfish, IPMI over LAN)。

    • 网卡(MAC)控制器会利用 DMA,将接收到的网络数据包直接写入到由驱动程序通过 dma_map_single 或 dma_alloc_coherent 准备的内存缓冲区中,然后才通过中断通知 CPU 进行处理。发送数据包的过程则相反。

  2. Flash 存储读写 (FMC/QSPI Controller):

    • OpenBMC 的固件、日志、用户数据都存储在 SPI Flash 中。

    • 当系统需要读取或写入大量数据到 Flash 时,Flash 控制器会使用 DMA 来加速这个过程,避免 CPU 陷入低效的逐字节读写循环。

  3. 传感器数据采集 (ADC / I2C / SPI):

    • 在一些高性能或实时性要求高的场景下,如果需要通过 ADC 高速采集模拟信号,或者通过 I2C/SPI 总线从多个传感器批量读取数据,也可以使用 DMA。

    • DMA 可以将采集到的数据流直接搬运到内存缓冲区,CPU 只需在缓冲区满时进行一次处理,大大降低了中断频率和 CPU 负载。

  4. 视频捕获 (LPC/eSPI 总线):

    • 虽然不常见,但在某些需要获取主机 VGA 画面的场景(如 KVM over IP),BMC 会通过 LPC 或 eSPI 总线从主机获取视频数据。这个高带宽的数据流传输也严重依赖 DMA 技术。

基础篇:DMA Mapping (内存管理)

在任何 DMA 传输发生之前,驱动程序必须分配一块内存,并将其映射为设备可见的物理地址(DMA 地址)。

场景:为 SPI Flash 驱动分配一致性缓冲区

在 OpenBMC 中,SPI 控制器通常需要一块固定的内存区域来存放命令和状态描述符。

#include<linux/dma-mapping.h>#include<linux/device.h>struct my_spi_driver_data {    void *cpu_addr;      // CPU 看到的虚拟地址    dma_addr_t dma_addr; // 设备(DMA)看到的物理地址    size_t size;};intmy_spi_probe(struct platform_device *pdev){    struct device *dev = &pdev->dev;    struct my_spi_driver_data *ddata;    ddata = devm_kzalloc(dev, sizeof(*ddata), GFP_KERNEL);    if (!ddata) return -ENOMEM;    ddata->size = 4096// 4KB 缓冲区    // 【核心代码】分配一致性内存    // 1. 分配内存    // 2. 确保 CPU 和设备看到的是一致的 (不需要手动 flush cache)    ddata->cpu_addr = dma_alloc_coherent(dev, ddata->size,                                          &ddata->dma_addr,                                          GFP_KERNEL);    if (!ddata->cpu_addr) {        dev_err(dev, "DMA memory allocation failed\n");        return -ENOMEM;    }    dev_info(dev, "Allocated DMA mem: CPU Addr=0x%p, DMA Addr=0x%pad\n"             ddata->cpu_addr, &ddata->dma_addr);    // 将 dma_addr 写入硬件寄存器,告诉 DMA 控制器去哪里搬运数据    // writel(ddata->dma_addr, base_addr + DMA_START_ADDR_REG);    return 0;}// 释放资源voidmy_spi_remove(struct platform_device *pdev){    struct my_spi_driver_data *ddata = platform_get_drvdata(pdev);    // 必须配对释放    dma_free_coherent(&pdev->dev, ddata->size, ddata->cpu_addr, ddata->dma_addr);}

场景:网络包或大数据的流式映射 (Streaming)

当处理大数据块(如一次读取 64KB 的固件日志)且内存已经分配好时,使用流式映射更高效。

#include<linux/dma-mapping.h>inttransfer_large_data(struct device *dev, void *buffer, size_t len, int direction){    dma_addr_t dma_handle;    int ret;    // 【核心代码】映射现有的内存    // direction 可以是 DMA_TO_DEVICE (写Flash) 或 DMA_FROM_DEVICE (读Flash)    dma_handle = dma_map_single(dev, buffer, len, direction);    if (dma_mapping_error(dev, dma_handle)) {        dev_err(dev, "Failed to map DMA memory\n");        return -EIO;    }    // 1. 启动硬件传输 (使用 dma_handle)    // start_hardware_transfer(dma_handle, len);    // 2. 等待传输完成 (这里简化为同步等待,实际通常用中断)    // wait_for_completion();    // 【核心代码】手动同步缓存 (仅针对流式映射)    // 如果是设备写入内存,CPU 读取前必须失效(invalidate)缓存,确保读到新数据    if (direction == DMA_FROM_DEVICE) {        dma_sync_single_for_cpu(dev, dma_handle, len, DMA_FROM_DEVICE);    }    // 处理数据...    // 【核心代码】解除映射    dma_unmap_single(dev, dma_handle, len, direction);    return 0;}

进阶篇:DMA Engine (提交传输任务)

这是现代 Linux 驱动(包括 OpenBMC 中的 aspeed 系列驱动)最常用的方式。它让驱动无需操作具体的 DMA 寄存器,而是通过通用 API 提交任务。

场景:使用 DMA Engine 进行 I2C/SPI 数据搬运

假设我们要通过 DMA 将一块数据从内存搬运到外设(TX 传输)。

#include<linux/dmaengine.h>#include<linux/dma-mapping.h>struct my_dma_client {    struct dma_chan *chan;      // DMA 通道    struct device *dev;    struct completion cmp;      // 用于等待传输完成};// DMA 传输完成后的回调函数 (在中断上下文中执行)voiddma_transfer_complete(void *param){    struct my_dma_client *client = param;    complete(&client->cmp); // 唤醒等待的进程    dev_info(client->dev, "DMA Transfer Completed!\n");}intstart_dma_tx(struct my_dma_client *client, void *tx_buf, size_t len){    struct dma_device *dma_dev = client->chan->device;    struct dma_async_tx_descriptor *tx;    dma_cookie_t cookie;    dma_addr_t dma_src;    int ret;    // 1. 映射源内存 (流式映射)    dma_src = dma_map_single(client->dev, tx_buf, len, DMA_TO_DEVICE);    if (dma_mapping_error(client->dev, dma_src))        return -EINVAL;    // 2. 准备 DMA 传输请求 (Slave SG 模式)    // 这里假设是内存 -> 外设 (Slave)    tx = dmaengine_prep_slave_single(client->chan, dma_src, len,                                      DMA_MEM_TO_DEV,                                      DMA_PREP_INTERRUPT | DMA_CTRL_ACK);    if (!tx) {        dev_err(client->dev, "Failed to prepare DMA TX\n");        ret = -EIO;        goto err_unmap;    }    // 3. 设置回调函数    tx->callback = dma_transfer_complete;    tx->callback_param = client;    // 4. 提交事务    cookie = dmaengine_submit(tx);    if (dma_submit_error(cookie)) {        dev_err(client->dev, "Failed to submit DMA TX\n");        ret = -EIO;        goto err_unmap;    }    // 5. 启动 DMA 引擎 (Issue pending requests)    dma_async_issue_pending(client->chan);    // 6. 等待完成 (实际驱动中可能使用异步等待或超时等待)    wait_for_completion(&client->cmp);    // 7. 检查状态    ret = dma_async_is_tx_complete(client->chan, cookie, NULLNULL);    if (ret == DMA_COMPLETE) {        dev_info(client->dev, "DMA Success\n");    }    // 8. 清理    dma_unmap_single(client->dev, dma_src, len, DMA_TO_DEVICE);    return 0;err_unmap:    dma_unmap_single(client->dev, dma_src, len, DMA_TO_DEVICE);    return ret;}

场景:分散-聚集 (Scatter-Gather) 传输

在 OpenBMC 的网络驱动或高性能存储驱动中,数据往往不是连续的。DMA Engine 支持一次性搬运多个不连续的物理页。

// 假设我们有一个 scatterlist 数组,指向多个物理上不连续的内存页intstart_sg_dma(struct my_dma_client *client, struct scatterlist *sg, int nents, int direction){    struct dma_async_tx_descriptor *tx;    dma_cookie_t cookie;    // 1. 映射 SG 列表    int mapped_nents = dma_map_sg(client->dev, sg, nents, direction);    if (mapped_nents == 0return -ENOMEM;    // 2. 准备 SG 传输    // DMA Engine 会自动处理链式传输    tx = dmaengine_prep_slave_sg(client->chan, sg, mapped_nents,                                  direction,                                  DMA_PREP_INTERRUPT);    if (!tx) {        dma_unmap_sg(client->dev, sg, nents, direction);        return -EIO;    }    // 3. 提交并启动    tx->callback = dma_transfer_complete;    tx->callback_param = client;    cookie = dmaengine_submit(tx);    if (dma_submit_error(cookie)) {        dma_unmap_sg(client->dev, sg, nents, direction);        return -EIO;    }    dma_async_issue_pending(client->chan);    return 0;}

调试技巧

如果你发现 DMA 不工作,可以按照以下思路排查:

  1. 检查 IOMMU: 虽然嵌入式 通常不使用复杂的 IOMMU,但如果开启了,必须确保 dma_map 成功。

  2. 缓存一致性:

     这是最常见的 Bug 来源。

    • 如果你用了 dma_alloc_coherent,通常没问题。

    • 如果你用了 dma_map_single千万别忘了在传输前后调用 dma_sync_single_for_cpu 或 dma_sync_single_for_device。否则你会读到旧数据,或者设备读到垃圾数据。

  3. 地址转换: 打印 virt_to_phys() 和 dma_map_single() 返回的地址。在没有 IOMMU 的简单系统中,它们通常是一样的;在有 IOMMU 的系统中,它们是不同的。

  4. 设备树: 确保 dmas 属性正确指向了系统中存在的 DMA 控制器节点。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-28 00:44:21 HTTP/2.0 GET : https://f.mffb.com.cn/a/483363.html
  2. 运行时间 : 0.138662s [ 吞吐率:7.21req/s ] 内存消耗:4,703.05kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=0a54cf907e7b166184961606b38fc6c8
  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.000593s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000562s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.001023s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000384s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000592s ]
  6. SELECT * FROM `set` [ RunTime:0.002947s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000710s ]
  8. SELECT * FROM `article` WHERE `id` = 483363 LIMIT 1 [ RunTime:0.001853s ]
  9. UPDATE `article` SET `lasttime` = 1774629862 WHERE `id` = 483363 [ RunTime:0.002710s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.000285s ]
  11. SELECT * FROM `article` WHERE `id` < 483363 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.004800s ]
  12. SELECT * FROM `article` WHERE `id` > 483363 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.007603s ]
  13. SELECT * FROM `article` WHERE `id` < 483363 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.009335s ]
  14. SELECT * FROM `article` WHERE `id` < 483363 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.010863s ]
  15. SELECT * FROM `article` WHERE `id` < 483363 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.003896s ]
0.140220s