0

我正在使用 petalinux2020.2 和 RFSOC、zcu111 板构建一个项目,对于我的应用程序,我需要从 petalinux 保留一段内存以与 DMA 一起使用,在 FPGA 的可编程逻辑上实现。我尝试按照本教程进行操作,但在启动时出现错误。 在此处输入图像描述

它以内核恐慌而终止,如下所示: 在此处输入图像描述 我尝试使用 petalinux-config 命令修改内存大小,将内存大小设置为 0x70000000,但没有帮助。

设备树的条目如下所示:

/include/ "system-conf.dtsi"
/{
    reserved-memory {
        #address-cells = <2>;
        #size-cells = <2>;
        ranges;
 
        reserved: buffer@0 {
            no-map;
            reg = <0x0 0x70000000 0x0 0x10000000>;
        };
    };
    reserved-driver@0 {
        compatible = "xlnx,reserved-memory";
        memory-region = <&reserved>;
    };
};

我怎样才能使这项工作?

4

1 回答 1

1

我在 Zynq-7020 板上运行 PetaLinux 2018.1,并且可以成功地为我的 DMA 操作保留内存。虽然不是您的确切设置,但它应该足够相似。您需要调整内存地址以适应您的系统。

我正在使用 DMA API“shared-dma-pool”属性。这样我的设备驱动程序将使用我的保留空间而不是默认的 CMA 池。

另外,请注意,在将vmalloc=512M语句添加到 bootargs之前,我在保留内存时遇到了问题。虽然我只为 DMA 保留了 256MB,但我需要为 vmalloc 设置一个更大的值(在我的例子中是两倍)才能让事情正常工作。

我的设备树条目:

/include/ "system-conf.dtsi"
/ {
    chosen {
    bootargs = "console=ttyPS0,115200 earlyprintk vmalloc=512M";
    stdout-path = "serial0:115200n8";
    };

reserved-memory {
        #address-cells = <1>;
        #size-cells = <1>;
        ranges;
 
            dma_reserved: buffer@30000000 {
        compatible = "shared-dma-pool";
            no-map;
        reg = <0x30000000 0x10000000>;
            };
    };

    //Required properties: 
    // - dmas: a list of <[DMA device phandle] [Channel ID]> pairs, 
    //         where Channel ID is (if both channels are enabled):
    //      '0' for write/tx channel
    //      '1' for read/rx channel 
    //     If only one channel is enabled, either tx or rx: 
    //      Channel ID is '0'. 
    // - dma-names: a list of DMA channel names, one per "dmas" entry 
    dma_proxy@0 {
        compatible ="xlnx,dma_proxy";
        dmas = <&axi_dma_0 0;
        dma-names = "dma1";
    memory-region = <&dma_reserved>;
    };
}

显示保留内存的控制台:   一世

于 2021-04-12T14:54:06.070 回答