打印
[新唐音频]

新唐NAU881*系列codec驱动移植注意问题

[复制链接]
484|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
zzz1228|  楼主 | 2024-5-8 15:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 zzz1228 于 2024-5-8 15:54 编辑

        在新唐NAU881*系列codec的demo驱动中,是利用regmap_write, regmap_read, regmap_update_bits等函数读写I2C,但当SOC或者MCU不支持regmap函数读写I2C时,直接利用I2C的read、write函数经常会发现读写的数据出现问题,这主要的原因在于,新唐NAU881*系列codec的I2C采用了7位寄存器,9位数据位。
        在demo驱动中,有这个结构体
static const struct regmap_config nau8810_regmap_config = {
        .reg_bits = 7,
        .val_bits = 9,
        ......
}
regmap函数会自动处理7位寄存器,9位数据位的问题。
所以移植驱动时,改写I2C的读写函数,我们需要关注下面问题
WRITE函数:
                data[0]=reg<<1+(val>>8)&0x01, data[1]=val&0xFF;
READ函数:
           写操作时:data[0]=reg<<1;//这是最容易忽略的地方
           读操作时:会返回16位数据,val=((data[0]&0x01)<<8)+data[1];

使用特权

评论回复
沙发
Henryko| | 2024-5-8 21:00 | 只看该作者
这个移位是干嘛用的 啊

使用特权

评论回复
板凳
zzz1228|  楼主 | 2024-5-10 10:53 | 只看该作者
Henryko 发表于 2024-5-8 21:00
这个移位是干嘛用的 啊

这个移位,就是为了处理codec 7位寄存器位,9位数据位。codec接收到16bit的数据后,data[0]的8位数据会取高7位作为reg addr,最后一位和另外八位作为寄存器的值

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

12

主题

13

帖子

2

粉丝