您的位置:首页 > 其它

ALSA声卡11_从零编写之调试——学习笔记

2017-12-27 09:06 288 查看
1、调试

(1)把程序拷贝到服务器上进行编译



(2)把程序放到内核上面去

重新配置内核,吧原来的声卡驱动程序去掉

a. 修改语法错误 11th_myalsa

b. 配置内核去掉原来的声卡驱动

-> Device Drivers

  -> Sound card support

    -> Advanced Linux Sound Architecture

       -> ALSA for SoC audio support

             

c. 使用新内核启动

d. 安装新驱动

insmod alsa/driver/myalsa/platform/s3c2440_iis.ko 

insmod alsa/driver/myalsa/platform/s3c2440_dma.ko 

insmod alsa/driver/myalsa/codec/uda1341.ko 

insmod alsa/driver/myalsa/machine/s3c2440_uda1341.ko 

mkdir /dev/snd

cd /dev/snd/

ln -s /dev/controlC0 

ln -s /dev/pcmC0D0p 

ln -s /dev/pcmC0D0c

cd /

e. aplay来测试

insmod ker_rw.ko

regeditor r32 0x4B000080 9

regeditor r32 0x55000000 5

(3)配置内核



原来声卡驱动的配置项

查看Makefile



查看对应的配置项







去掉配置项CONFIG_SND_SOC_SAMSUNG





修改后重新编译内核



拷贝到网络系统并修改内核的名字



2、启动内核安装驱动

(1)查看环境变量



(2)启动



没有发现声卡



(3)安装新驱动(查看之前编译好的驱动程序)



insmod alsa/driver/myalsa/platform/s3c2440_iis.ko 
insmod alsa/driver/myalsa/platform/s3c2440_dma.ko 
insmod alsa/driver/myalsa/codec/uda1341.ko 
insmod alsa/driver/myalsa/machine/s3c2440_uda1341.ko 



(4)查看设备节点(aplay使用的设备节点默认是/dev/snd目录下,所以要在/dev/snd目录下创建设备节点)



(5)测试



出现段错误

返回地址在snd_pcm_info,在内核里分析此函数,这个函数调用某个子函数后出错





snd_pcm_info函数的ops->ioctl函数没有被赋值。



这里lr是0



在数据传输的时候出错,看snd_pcm_lib_write_transfer函数



(6)测试2

名为myalsa  for playback的中断一次也没有发生,表明DMA传输一次都没有启动



使用寄存器编辑器读取IIS和DMA 的寄存器,看看有没有被正确设置(26th_debug_regeditor)



把编辑器拷贝到服务器编译,拷贝别的驱动程序的Makefile,修改Makefile





进行编译,然后编译测试程序

最后把寄存器编译器和测试程序都拷贝到网络问价系统上



查看寄存器编辑器的用法



寄存器地址



insmod ker_rw.ko
regeditor r32 0x4B000080 9  //读DMA寄存器,r32表示读32位数据,从地址0x4B000080开始读,总共读9个寄存器
regeditor r32 0x55000000 5 //读IIS寄存器,r32表示读32位数据,从地址0x55000000开始读,总共读5个寄存器



IIS寄存器的值全为0,因而存在问题(可能IIS控制器的时钟没有使能,裸板程序没有使能时钟,是因为一上电的时候,就执行裸板程序,2440的IIS模块等各种模块时钟默认是打开的),当我们启动内核后,为了省电,内核会把用不到的模块关闭掉,所以在驱动里面要把IIS打开




当打开IIS时钟后寄存器就会有值,但是这些值是否正确还有待分析

最后安装驱动,创建设备节点,然后用aplay播放音频数据

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: