sdk-ameba-v4.0c_180328/component/common/drivers/i2s/alc5660.c

184 lines
4.4 KiB
C
Raw Normal View History

2019-04-02 08:34:25 +00:00
#include <stdio.h>
#include "PinNames.h"
#include "basic_types.h"
#include "diag.h"
#include <osdep_api.h>
#include "i2c_api.h"
#include "pinmap.h"
#include "alc5660.h"
//#define I2C_MTR_SDA PC_4//PB_3
//#define I2C_MTR_SCL PC_5//PB_2
#define I2C_MTR_SDA PB_3
#define I2C_MTR_SCL PB_2
#define I2C_BUS_CLK 100000 //hz
#define I2C_ALC5660_ADDR (0x38/2)
#define RT5660_PRIV_INDEX 0x6a
#define RT5660_PRIV_DATA 0x6c
i2c_t alc5660_i2c;
#undef printf
#define printf DBG_8195A
static void alc5660_delay(void)
{
int i;
i=10000;
while (i) {
i--;
asm volatile ("nop\n\t");
}
}
void alc5660_reg_write(unsigned int reg, unsigned int value)
{
char buf[4];
buf[0] = (char)reg;
buf[1] = (char)(value>>8);
buf[2] = (char)(value&0xff);
i2c_write(&alc5660_i2c, I2C_ALC5660_ADDR, &buf[0], 3, 1);
alc5660_delay();
}
void alc5660_reg_read(unsigned int reg, unsigned int *value)
{
int tmp;
char *buf = (char*)&tmp;
buf[0] = (char)reg;
i2c_write(&alc5660_i2c, I2C_ALC5660_ADDR, &buf[0], 1, 1);
alc5660_delay();
buf[0] = 0xaa;
buf[1] = 0xaa;
i2c_read(&alc5660_i2c, I2C_ALC5660_ADDR, &buf[0], 2, 1);
alc5660_delay();
*value= ((buf[0]&0xFF)<<8)|(buf[1]&0xFF);
}
void alc5660_index_write(unsigned int reg, unsigned int value)
{
alc5660_reg_write(RT5660_PRIV_INDEX, reg);
alc5660_reg_write(RT5660_PRIV_DATA, value);
}
void alc5660_index_read(unsigned int reg, unsigned int *value)
{
alc5660_reg_write(RT5660_PRIV_INDEX, reg);
alc5660_reg_read(RT5660_PRIV_DATA, value);
}
void alc5660_reg_dump(void)
{
int i;
unsigned int value;
printf("alc5660 codec reg dump\n\r");
printf("------------------------\n\r");
for(i=0;i<=0xff;i++){
alc5660_reg_read(i, &value);
printf("%02x : %04x\n\r", i, (unsigned short)value);
}
printf("------------------------\n\r");
}
void alc5660_index_dump(void)
{
int i;
unsigned int value;
printf("alc5660 codec index dump\n\r");
printf("------------------------\n\r");
for(i=0;i<=0xff;i++){
alc5660_index_read(i, &value);
printf("%02x : %04x\n\r", i, (unsigned short)value);
}
printf("------------------------\n\r");
}
void alc5660_init(void)
{
i2c_init(&alc5660_i2c, I2C_MTR_SDA, I2C_MTR_SCL);
i2c_frequency(&alc5660_i2c, I2C_BUS_CLK);
}
void alc5660_set_word_len(int len_idx) // interface2
{
// 0: 16 1: 20 2: 24 3: 8
unsigned int val;
alc5660_reg_read(0x71,&val);
val &= (~(0x3<<2));
val |= (len_idx<<2);
alc5660_reg_write(0x71,val);
alc5660_reg_read(0x70,&val);
val &= (~(0x3<<2));
val |= (len_idx<<2);
alc5660_reg_write(0x70,val);
}
void alc5660_init_interface1(void)
{
alc5660_reg_write(0x00,0x0021);
alc5660_reg_write(0x63,0xA8F4);
alc5660_reg_write(0x61,0x5800);
alc5660_reg_write(0x62,0x0C00);
alc5660_reg_write(0x73,0x0000);
alc5660_reg_write(0x2A,0x4242);
alc5660_reg_write(0x45,0x2000);
alc5660_reg_write(0x02,0x4848);
alc5660_reg_write(0x8E,0x0019);
alc5660_reg_write(0x8F,0x3100);
alc5660_reg_write(0x91,0x0E00);
alc5660_index_write(0x3D,0x3E00);
alc5660_reg_write(0xFA,0x0821);
alc5660_reg_write(0x83,0x0800);
alc5660_reg_write(0x84,0xA000);
//alc5660_reg_write(0xFA,0x0C11);
alc5660_reg_write(0x64,0x4010);
alc5660_reg_write(0x65,0x0C00);
alc5660_reg_write(0x61,0x5806);
alc5660_reg_write(0x62,0xCC00);
alc5660_reg_write(0x3C,0x004F);
alc5660_reg_write(0x3E,0x004F);
alc5660_reg_write(0x27,0x3820);
alc5660_reg_write(0x77,0x0000);
}
void alc5660_init_interface2(void)
{
alc5660_reg_write(0x00,0x0001);
alc5660_reg_write(0xFA,0x0821);
alc5660_reg_write(0x63,0xA8F4);
//alc5660_reg_write(0x63,0xA814);
//alc5660_delay();
alc5660_reg_write(0x61,0x9807);
//alc5660_delay();
alc5660_reg_write(0x62,0x8800);
alc5660_reg_write(0x64,0x8a00);
alc5660_reg_write(0x65,0x0C00);
alc5660_reg_write(0x6A,0x003D);
alc5660_reg_write(0x6C,0x3600);
alc5660_reg_write(0x73,0x0004);
alc5660_reg_write(0x0D,0x9010);
alc5660_reg_write(0x3C,0x007D);
alc5660_reg_write(0x3E,0x007D);
alc5660_reg_write(0x27,0x2020);
alc5660_reg_write(0x02,0x4848);
alc5660_reg_write(0x45,0xA000);
alc5660_reg_write(0x2A,0x0202);
alc5660_reg_write(0x73,0x0000);
alc5660_reg_write(0x8E,0x0011);
alc5660_reg_write(0x29,0x8080);
alc5660_reg_write(0xEB,0x44C3);
alc5660_reg_write(0x48,0x9800);
alc5660_reg_write(0x01,0x4800);
}