在17.2.20日的问题进行长达一天多的反复调试,终于在22日得到了解决。
以及oled的驱动的编写,在进行驱动的调试过程中,
spi_register_board_info注册硬件信息遇到了无法创建设备。
spi_register_board_info
spi_match_master_to_boardinfo
spi_new_device
spi_add_device
/* Chipselects are numbered 0..max; validate. */
if (spi->chip_select >= spi->master->num_chipselect) {
dev_err(dev, "cs%d >= max %d\n",
spi->chip_select,
spi->master->num_chipselect);
return -EINVAL;
}//打印错误信息,css>=max 1,意为用户的使用片选数量大于master的数量支持
阅读内核源码进行错误信息调试
错误调试过程:
首先通过打印log信息定位错误,但开始由于对整个文件不是很熟悉,因此问题的定位一直停留在对自己编写的设备文件和驱动文件,以及spi_master文件spi_s3c64xx.c文件中打印log。
1.发现spi__info.c文件的入口函数spi_register_board_info文件被调用,但是在master文件bus_num进行匹配成功文件创建过程spi_add_device中一直出现