畵影

畵影

2个粉丝

4

问答

0

专栏

0

资料

畵影  发布于  2023-06-29 09:55:50
采纳率 0%
4个问答
5291

海思hi3531a移植mcp2515

悬赏金¥ 10
已结题
 

查看过https://www.ebaina.com/articles/140000002855
其步骤如下:
1.注意RESET脚控制,为海思的控制方法
2.注意MCP2515使用的晶振,内核里面配置对应的时序
3.中断方式采用海思的控制方式
4.开启内核can支持及SPI的mcp2515驱动,mcp2515里面本身有个bug也一并修正了
5.修改驱动适配3521D,采用动态加载的方式
上面写得太简单,希望写出具体内容,特别是1和3复位脚控制,和中断控制。

我来回答
回答7个
时间排序
认可量排序

艾编程的鲁小班

19个粉丝

25

问答

17

专栏

32

资料

艾编程的鲁小班 2023-06-29 10:02:57
认可0

这个代码很久没有看了,代码比较简单,不同内核版本可能驱动会有一点点差异(代码写起来也比较简单),就是把spi转can的设备注册成一个网络设备。
复位和中断是需要自己去调试的。

畵影
畵影   回复   艾编程的鲁小班  2023-06-29 10:20:14
0
can0: can@0 {
    compatible = "microchip,mcp2515";
    reg = <3>;
    clocks = <&clk_16m>;
    spi-max-frequency = <2000000>;
    interrupt-parent = <&gpio_chip17>;
    interrupts = <5 0x2>;
    reset-gpios = <&gpio_chip17 6 0>;
    status = "okay";
};

请教一下这个gpio_chip17怎么定义的呢?

畵影

2个粉丝

4

问答

0

专栏

0

资料

畵影 2023-06-29 10:30:33
认可0

can0: can@0 {
compatible = “microchip,mcp2515”;
reg = <3>;
clocks = <&clk_16m>;
spi-max-frequency = <2000000>;
interrupt-parent = <&gpio_chip17>;
interrupts = <5 0x2>;
reset-gpios = <&gpio_chip17 6 0>;
status = “okay”;
};
目前迫切想知道gpio_chip17怎么定义的

UncleRoderick

35个粉丝

14

问答

1

专栏

14

资料

UncleRoderick 2023-06-29 11:23:20
认可0

这个看你的GPIO接的是啥呀,然后找到对应的设备树配置上去就行了

畵影
畵影   回复   UncleRoderick  2023-06-29 11:31:54
0

hi3531a的dts里没有gpio相关的。
/*

  • Copyright (c) 2013-2014 Linaro Ltd.
  • Copyright (c) 2015-2017 HiSilicon Technologies Co., Ltd.
    *
  • This program is free software; you can redistribute it and/or modify it
  • under the terms of the GNU General Public License as published by the
  • Free Software Foundation; either version 2 of the License, or (at your
  • option) any later version.
    *
  • This program is distributed in the hope that it will be useful,
  • but WITHOUT ANY WARRANTY; without even the implied warranty of
  • MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  • GNU General Public License for more details.
    *
  • You should have received a copy of the GNU General Public License
  • along with this program. If not, see http://www.gnu.org/licenses/.
    /

include

/ {

#address-cells = <1>;
#size-cells = <1>;

aliases {
    fmc = &fmc;
    serial0 = &uart0;
    serial1 = &uart1;
    serial2 = &uart2;
    serial3 = &uart3;
    i2c0 = &i2c_bus0;
    i2c1 = &i2c_bus1;
    spi0 = &spi_bus0;
};

gic: interrupt-controller@10300000 {
    compatible = "arm,cortex-a9-gic";
    #interrupt-cells = <3>;
    #address-cells = <0>;
    interrupt-controller;
    /* gic dist base, gic cpu base , no virtual support */
    reg = <0x10301000 0x1000>, <0x10300100 0x100>;
 };

soc {
    #address-cells = <1>;
    #size-cells = <1>;
    compatible = "simple-bus";
    interrupt-parent = <&gic>;
    ranges;

    clock: clock@12040000 {
        compatible = "hisilicon,hi3531a-clock";
        reg = <0x12040000 0x1000>;
        #clock-cells = <1>;
        #reset-cells = <2>;
    };

    sysctrl: system-controller@12050000 {
        compatible = "hisilicon,hi3531a-sysctrl", "syscon";
        reg = <0x12050000 0x1000>;
        #clock-cells = <1>;
    };

    reboot {
        compatible = "syscon-reboot";
        regmap = <&sysctrl>;
        offset = <0x4>;
        mask = <0xdeadbeef>;
    };

    pmu {
        compatible = "arm,cortex-a9-pmu";
        interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>,
                <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
    };

    L2: l2-cache@10700000 {
        compatible = "arm,pl310-cache";
        reg = <0x10700000 0x10000>;
        interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
        cache-unified;
        cache-level = <2>;
    };

    hidmac: hidma-controller@10060000 {
        compatible = "hisilicon,hisi-dmac";
        reg = <0x10060000 0x1000>;
        interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_DMAC_CLK>;
        clock-names = "dmac_clk";
        resets = <&clock 0x144 0>;
        reset-names = "dma-reset";
        #dma-cells = <2>;
        status = "disabled";
    };

    uart0: uart@12080000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0x12080000 0x1000>;
        interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_UART0_CLK>;
        clock-names = "apb_pclk";
        status = "disabled";
    };

    uart1: uart@121090000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0x12090000 0x1000>;
        interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_UART1_CLK>;
        clock-names = "apb_pclk";
        status = "disabled";
    };

    uart2: uart@120a0000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0x120a0000 0x1000>;
        interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_UART2_CLK>;
        clock-names = "apb_pclk";
        status = "disabled";
    };

    uart3: uart@12130000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0x12130000 0x1000>;
        interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_UART3_CLK>;
        clock-names = "apb_pclk";
        status = "disabled";
    };

    usb_phy: phy {
        compatible = "hisilicon,hisi-usb-phy";
        reg = <0x12040000 0x10000>, <0x12120000 0x10000>;
        #phy-cells = <0>;
    };

    usb3_phy: phy3 {
        compatible = "hisilicon,hisi-usb3-phy";
        reg = <0x12040000 0x10000>, <0x12120000 0x10000>, <0x11000000 0x100000>;
        #phy-cells = <0>;
    };

    xhci@0x11000000 {
        compatible = "generic-xhci";
        reg = <0x11000000 0x10000>;
        interrupts = <0 22 4>;
    };

    ehci@0x100c0000 {
        compatible = "generic-ehci";
        reg = <0x100c0000 0x10000>;
        interrupts = <0 19 4>;
    };

    ohci@0x100b0000 {
        compatible = "generic-ohci";
        reg = <0x100b0000 0x10000>;
        interrupts = <0 18 4>;
    };

    i2c_bus0: i2c@120c0000 {
        compatible = "hisilicon,hisi-i2c-hisilicon";
        reg = <0x120c0000 0x100>;
        interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_PERIAXI_CLK>;
        clock-frequency = <100000>;
        io-size = <0x1000>;
        id = <0>;
        status = "disabled";
    };

    i2c_bus1: i2c@122e0000 {
        compatible = "hisilicon,hisi-i2c-hisilicon";
        reg = <0x122e0000 0x100>;
        interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_PERIAXI_CLK>;
        clock-frequency = <100000>;
        io-size = <0x1000>;
        id = <1>;
        status = "disabled";
    };

    spi_bus0: spi@120d0000 {
        compatible = "arm,pl022", "arm,primecell";
        arm,primecell-periphid = <0x00800022>;
        reg = <0x120d0000 0x1000>, <0x12120014 0x4>;
        interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&clock HI3531A_SPI0_CLK>;
        clock-names = "apb_pclk";
        status = "disabled";
        #address-cells = <1>;
        #size-cells = <0>;
        hisi,spi_cs_sb = <0>;
        hisi,spi_cs_mask_bit = <0x00000007>;
    };

    timer@hisp804 {
        compatible = "hisilicon,hisp804";
        /* timer0 & timer1 & timer2 */
        reg = <0x12000000 0x20>, /* clocksource */
              <0x12000020 0x20>, /* local timer for each cpu */
              <0x12010000 0x20>;
        interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>, /* irq of local timer */
                     <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
        clocks = <&sysctrl HI3531A_TIME0_0_CLK>,
                 <&sysctrl HI3531A_TIME0_1_CLK>,
                 <&sysctrl HI3531A_TIME1_2_CLK>;
        clock-names = "timer0", "timer1", "timer2";
    };

    dual_timer2: dual_timer@12020000 {
        compatible = "arm,sp804", "arm,primecell";
        /* timer4 & timer5 */
        interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x12020000 0x1000>;
        clocks = <&sysctrl HI3531A_TIME2_4_CLK>,
                <&sysctrl HI3531A_TIME2_5_CLK>,
                <&clock HI3531A_PERIAXI_CLK>;
        clock-names = "timer4", "timer5", "peri_pclk";
        status = "disabled";
    };

    dual_timer3: dual_timer@12030000 {
        compatible = "arm,sp804", "arm,primecell";
        /* timer6 & timer7 */
        interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x12030000 0x1000>;
        clocks = <&sysctrl HI3531A_TIME3_6_CLK>,
                <&sysctrl HI3531A_TIME3_7_CLK>,
                <&clock HI3531A_PERIAXI_CLK>;
        clock-names = "timer6", "timer7", "peri_pclk";
        status = "disabled";
    };

    fmc: flash-memory-controller@10000000 {
        compatible = "hisilicon,hisi-fmc";
        reg = <0x10000000 0x1000>, <0x14000000 0x10000>;
        reg-names = "control", "memory";
        clocks = <&clock HI3531A_FMC_CLK>;
        max-dma-size = <0x2000>;
        #address-cells = <1>;
        #size-cells = <0>;

        hisfc:spi_nor_controller {
            compatible = "hisilicon,fmc-spi-nor";
            assigned-clocks = <&clock HI3531A_FMC_CLK>;
            assigned-clock-rates = <24000000>;
            #address-cells = <1>;
            #size-cells = <0>;
        };

        hisnfc:spi_nand_controller {
            compatible = "hisilicon,fmc-spi-nand";
            assigned-clocks = <&clock HI3531A_FMC_CLK>;
            assigned-clock-rates = <24000000>;
            #address-cells = <1>;
            #size-cells = <0>;
        };
    };

    hinfc610: parallel-nand-controller@10010000 {
        compatible = "hisilicon,hisi-parallel-nand";
        reg = <0x10010000 0x10000>, <0x15000000 0x10000>;
        reg-names = "control", "memory";
        clocks = <&clock HI3531A_NFC_CLK>;
        #address-cells = <1>;
        #size-cells = <0>;
    };

    mdio: mdio@100a03c0 {
        compatible = "hisilicon,hisi-gemac-mdio";
        reg = <0x100a03c0 0x20>;
        clocks = <&clock HI3531A_ETH_CLK>,
                <&clock HI3531A_ETH_PHY_MUX>;
        assigned-clocks = <&clock HI3531A_ETH_PHY_MUX>;
        assigned-clock-rates = <25000000>;
        resets = <&clock 0x14c 5>;
        reset-names = "phy_reset";
        #address-cells = <1>;
        #size-cells = <0>;
    };

    higmac: ethernet@100a0000 {
        compatible = "hisilicon,higmac";
        reg = <0x100a0000 0x1000>,<0x1204015c 0x4>,
            <0x100a3014 0x4>;
        interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;

        clocks = <&clock HI3531A_ETH_CLK>,
                <&clock HI3531A_ETH_MACIF_CLK>;
        clock-names = "higmac_clk",
                "macif_clk";

        resets = <&clock 0x14c 0>,
                <&clock 0x14c 2>;
        reset-names = "port_reset",
                "macif_reset";

        mac-address = [00 00 00 00 00 00];
    };

    sata_phy: phy@11010000 {
        compatible = "hisilicon,hisi-sata-phy";
        reg = <0x11010000 0x10000>;
        ports_num_max = <4>;
        #phy-cells = <0>;
    };

    ahci: sata@11010000 {
        compatible = "hisilicon,hisi-ahci";
        reg = <0x11010000 0x1000>;
        interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
        phys = <&sata_phy>;
        phy-names = "sata-phy";
        #address-cells = <1>;
        #size-cells = <0>;
    };

    pcie0: pcie0@0x11020000 {
       device_type = "pci";
       compatible = "hisilicon,hisi-pcie";
       bus-range = <0x0 0xff>;
       #size-cells = <2>;
       #address-cells = <3>;
       ranges = <0x02000000 0x00 0x28000000 0x28000000 0x00 0x8000000>;
       #interrupt-cells = <1>;
       interrupt-map-mask = <0x0 0x0 0x0 0x4>;
       interrupt-map = <0x0 0x0 0x0 0x1 &gic GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
       pcie_controller = <0>;
       dev_mem_size = <0x8000000>;
       dev_conf_size = <0x8000000>;
       pcie_dbi_base = <0x11020000>;
       ep_conf_base = <0x20000000>;
    };

    pcie1: pcie1@0x11030000 {
       device_type = "pci";
       compatible = "hisilicon,hisi-pcie";
       bus-range = <0x0 0xff>;
       #size-cells = <2>;
       #address-cells = <3>;
       ranges = <0x02000000 0x00 0x38000000 0x38000000 0x00 0x8000000>;
       #interrupt-cells = <1>;
       interrupt-map-mask = <0x0 0x0 0x0 0x4>;
       interrupt-map = <0x0 0x0 0x0 0x1 &gic GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
       pcie_controller = <1>;
       dev_mem_size = <0x8000000>;
       dev_conf_size = <0x8000000>;
       pcie_dbi_base = <0x11030000>;
       ep_conf_base = <0x30000000>;
    };

    pcie_mcc: pcie_mcc@0x0 {
       compatible = "hisilicon,pcie_mcc";
       interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>,
                    <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
    };

    clk_16m: clk_16m {
        compatible = "fixed-clock";
        #clock-cells = <0>;
        clock-frequency = <16000000>;
    };
};

media {
    #address-cells = <1>;
    #size-cells = <1>;
    compatible = "simple-bus";
    interrupt-parent = <&gic>;
    ranges;

    sys: sys@12040000 {
        compatible = "hisilicon,hi35xx_sys";
        reg = <0x12040000 0x10000>, <0x12050000 0x10000>,
              <0x12110000 0x10000>, <0x12120000 0x10000>;
        reg-names = "crg", "sys", "ddr", "misc";
    };

    rtc: rtc@120b0000 {
        compatible = "hisilicon,hi35xx_rtc";
        interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x120b0000 0x10000>;
    };

    hiir: hiir@0x12140000 {
        compatible = "hisilicon,hi35xx_ir";
        interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x12140000 0x10000>;
    };

    cipher: cipher@0x10070000 {
        compatible = "hisilicon,hi35xx_cipher";
        interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x10070000 0x2000>;
    };

    viu: viu@130C0000 {
        compatible = "hisilicon,hi35xx_viu";
        interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x130C0000 0x40000>;
    };

    vou: vou@13020000 {
        compatible = "hisilicon,hi35xx_vou";
        interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13020000 0x10000>;
    };

    vpss: vpss@13080000 {
        compatible = "hisilicon,hi35xx_vpss";
        interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>;
        interrupt-names = "vpss0", "vpss1", "vpss2";
        reg = <0x13080000 0x5000>,
              <0x13110000 0x5000>,
              <0x13180000 0x5000>;
        reg-names = "vpss0", "vpss1", "vpss2";
    };

    vgs: vgs@13150000 {
        compatible = "hisilicon,hi35xx_vgs";
        interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13150000 0x5000>;
    };

    vda: vda@13090000 {
        compatible = "hisilicon,hi35xx_vda";
        interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13090000 0x10000>;
    };

    tde: tde@13050000 {
        compatible = "hisilicon,hi35xx_tde";
        interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13050000 0x1000>;
    };

    avc: avc@13040000 {
        compatible = "hisilicon,hi35xx_avc";
        interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13040000 0x10000>,
              <0x13100000 0x10000>,
              <0x13170000 0x10000>,
              <0x13190000 0x10000>;
        reg-names = "vedu0", "vedu1", "vedu2", "vedu3";
    };

    jpege: jpege@13130000 {
        compatible = "hisilicon,hi35xx_jpege";
        interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13130000 0x10000>;
    };

    jpgd: jpgd@13070000 {
        compatible = "hisilicon,hi35xx_jpgd";
        interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
        interrupt-names = "jpgd";
        reg = <0x13070000 0x10000>;
        reg-names = "jpgd";
    };

    ive: ive@13060000 {
        compatible = "hisilicon,hi35xx_ive";
        interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13060000 0x10000>;
    };

    vdec: vdec@10080000 {
        compatible = "hisilicon,hi35xx_vdec";
        interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
        interrupt-names = "scd";
        reg = <0x10080000 0x4000>;
        reg-names = "scd";
    };

    audio: audio@13140000 {
        compatible = "hisilicon,hi35xx_aiao";
        interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13140000 0x10000>;
        reg-names = "aiao";
    };

    voie: audio@13120000 {
        compatible = "hisilicon,hi35xx_aenc";
        interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
        reg = <0x13120000 0x10000>;
        reg-names = "aenc";
    };

    hdmi: hdmi@13010000 {
        compatible = "hisilicon,hi35xx_hdmi";
        reg = <0x13010000 0x10000>;
        reg-names = "hdmi";
    };
};

};

UncleRoderick
UncleRoderick   回复   畵影  2023-06-29 13:40:49
0

没有就自己改驱动代码呗,设备树只是传递配置的一种方式,在你都知道硬件接的IO的前提下,驱动代码直接写死也行的

畵影

2个粉丝

4

问答

0

专栏

0

资料

畵影 2023-06-29 20:46:34
认可0
    gpio_chip0: gpio_chip@12150000 {
        compatible = "arm,pl061", "arm,primecell";
        reg = <0x12150000 0x10000>;
        interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
        #gpio-cells = <2>;
        clocks = <&clock HI3531A_PERIAXI_CLK>;
        clock-names = "apb_pclk";
        status = "okay";
    };
    gpio配置怎么错了
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币

Markdown 语法

  • 加粗**内容**
  • 斜体*内容*
  • 删除线~~内容~~
  • 引用> 引用内容
  • 代码`代码`
  • 代码块```编程语言↵代码```
  • 链接[链接标题](url)
  • 无序列表- 内容
  • 有序列表1. 内容
  • 缩进内容
  • 图片![alt](url)
+ 添加网盘链接/附件

Markdown 语法

  • 加粗**内容**
  • 斜体*内容*
  • 删除线~~内容~~
  • 引用> 引用内容
  • 代码`代码`
  • 代码块```编程语言↵代码```
  • 链接[链接标题](url)
  • 无序列表- 内容
  • 有序列表1. 内容
  • 缩进内容
  • 图片![alt](url)
相关问答
无更多相似问答 去提问
举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

易百纳技术社区