Hi,
I configured SDHC2 port as a spi port in RCW for ls1012a.
Now I am going to test the spi functionality, the plan is to use spidev.
- enable spidev in menuconfig
- bind the driver with spi
- compile the linux kernel
- run user space program spidev_test to do the test
I enabled the SPI_SPIDEV in linux menuconfig (linux 5.1 from mainstream)
The next step is to bind the driver to the spi bus. But I do not know to to do this. The next screenshot show how to add a structure called spi_board_info and give the spidev to the .modalias.
I didn't find any file named mach-xxxx for ls1012a( I am using my hardware with ls1012a, that's why I need to test the spi), so i am stuck here, step 2.
Should I bind them with device tree? Anyone who knows how to do it?
Thank you
已解决! 转到解答。
Hello Kai Wu,
Please refer to the following dts definition.
&dspi {
bus-num = <0>;
status = "okay";
spidev@0 {
#address-cells = <1>;
#size-cells = <1>;
compatible = "spidev";
reg = <0>;
spi-max-frequency = <10000000>;
};
spidev@1 {
#address-cells = <1>;
#size-cells = <1>;
compatible = "spidev";
reg = <1>;
spi-max-frequency = <10000000>;
};
};
Thanks,
Yiping
Hello Kai Wu,
Please refer to the following dts definition.
&dspi {
bus-num = <0>;
status = "okay";
spidev@0 {
#address-cells = <1>;
#size-cells = <1>;
compatible = "spidev";
reg = <0>;
spi-max-frequency = <10000000>;
};
spidev@1 {
#address-cells = <1>;
#size-cells = <1>;
compatible = "spidev";
reg = <1>;
spi-max-frequency = <10000000>;
};
};
Thanks,
Yiping
Hi Yiping,
I have similar problem. I use dts as followed.
dspi@2100000 {
compatible = "fsl,ls1012a-dspi", "fsl,ls1021a-v1.0-dspi";
// compatible = "fsl,vf610-dspi";
#address-cells = <0x1>;
#size-cells = <0x0>;
reg = <0x0 0x2100000 0x0 0x10000>;
interrupts = <0x0 0x40 0x4>;
clock-names = "dspi";
clocks = <0x2 0x4 0x0>;
spi-num-chipselects = <0x3>;
big-endian;
bus-num = <0x01>;
status = "okay";
spidev@0 {
#address-cells = <0x01>;
#size-cells = <0x01>;
compatible = "spidev";
reg = <0x00>;
spi-max-frequency = <10000000>;
};
spidev@1 {
#address-cells = <0x01>;
#size-cells = <0x01>;
compatible = "spidev";
reg = <0x01>;
spi-max-frequency = <10000000>;
};
spidev@2 {
#address-cells = <0x01>;
#size-cells = <0x01>;
compatible = "spidev";
reg = <0x02>;
spi-max-frequency = <10000000>;
};
};
when I use compatible as "fsl,ls1012a-dspi", "fsl,ls1021a-v1.0-dspi" , I end up with kernel msg like this.
spidev spi1.2: setup mode 0, 8 bits/w, 10000000 Hz max --> 0
spidev spi1.2: spi mode 0
spidev spi1.2: setup mode 0, 8 bits/w, 10000000 Hz max --> 0
spidev spi1.2: 8 bits per word
spidev spi1.2: setup mode 0, 8 bits/w, 1000000 Hz max --> 0
fsl-dspi 2100000.dspi: wait transfer complete fail!
when I use compatible as compatible = "fsl,vf610-dspi", devices are note created as spidev1.x under /dev/.
fsl-dspi 2100000.spi: rx dma channel not available
fsl-dspi 2100000.spi: can't get dma channels
Can I get any help about this?
The problem was that I have used bootloader dspi code in kernel in order to read CPLD(external module).
so I believe there is a malfunction if I use tcfq_mode in user-mode and bootloader dspi code in kernel.
Maybe in HALT fields of register MCR(210_0000h) could be a problem.
Anyway I got another problem that when I use spidev(tcfq_mode) there is a gap between clock even they are in one chipselect. It happens every single 8 clock after. So I want to use dma mode.
I still get kernel msg as followed:
fsl-dspi 2100000.spi: rx dma channel not available
fsl-dspi 2100000.spi: can't get dma channels
could you give me any advice to solve this problem?