es8311.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. #include "luat_base.h"
  2. #include "luat_gpio.h"
  3. #include "luat_i2c.h"
  4. #include "luat_audio_air101.h"
  5. #include "es8311.h"
  6. #define LUAT_LOG_TAG "es8311"
  7. #include "luat_log.h"
  8. static void es8311_write_reg(uint8_t addr, uint8_t data){
  9. uint8_t temp[] = {addr,data};
  10. luat_i2c_send(0, ES8311_ADDR, temp, 2 , 1);
  11. luat_timer_mdelay(1);
  12. }
  13. static uint8_t es8311_read_reg(uint8_t addr){
  14. uint8_t temp=0;
  15. luat_i2c_send(0, ES8311_ADDR, &addr, 1 , 0);
  16. luat_i2c_recv(0, ES8311_ADDR, &temp, 1);
  17. return temp;
  18. }
  19. static int es8311_codec_standby(void){
  20. es8311_write_reg(ES8311_DAC_REG32, 0x00);
  21. es8311_write_reg(ES8311_ADC_REG17, 0x00);
  22. es8311_write_reg(ES8311_SYSTEM_REG0E, 0xFF);
  23. es8311_write_reg(ES8311_SYSTEM_REG12, 0x02);
  24. es8311_write_reg(ES8311_SYSTEM_REG14, 0x00);
  25. es8311_write_reg(ES8311_SYSTEM_REG0D, 0xFA);
  26. es8311_write_reg(ES8311_RESET_REG00, 0x00);
  27. es8311_write_reg(ES8311_RESET_REG00, 0x1F);
  28. es8311_write_reg(ES8311_CLK_MANAGER_REG01, 0x30);
  29. es8311_write_reg(ES8311_CLK_MANAGER_REG01, 0x00);
  30. es8311_write_reg(ES8311_GP_REG45, 0x01);
  31. es8311_write_reg(ES8311_SYSTEM_REG0D, 0xFC);
  32. return 0;
  33. }
  34. static uint8_t es8311_codec_vol(uint8_t vol){
  35. if(vol < 0 || vol > 100){
  36. return -1;
  37. }
  38. int gain = vol == 0 ? -955 : (vol - 80) * 5;
  39. uint8_t reg_val = (uint8_t)((gain + 955) / 5);
  40. es8311_write_reg(ES8311_DAC_REG32, reg_val);
  41. return vol;
  42. }
  43. /*0---master, 1---slave*/
  44. static void es8311_codec_mode(uint8_t mode){
  45. if (mode == 0){
  46. es8311_write_reg(ES8311_RESET_REG00, 0xC0);
  47. }else{
  48. es8311_write_reg(ES8311_RESET_REG00, 0x80);
  49. }
  50. }
  51. static int es8311_codec_samplerate(uint16_t samplerate){
  52. if(samplerate != 8000 && samplerate != 16000 && samplerate != 32000 &&
  53. samplerate != 11025 && samplerate != 22050 && samplerate != 44100 &&
  54. samplerate != 12000 && samplerate != 24000 && samplerate != 48000)
  55. {
  56. LLOGE("samplerate error!\n");
  57. return -1;
  58. }
  59. // uint8_t i = 0;
  60. static int mclk = 0;
  61. static int switchflag = 0;
  62. switch(samplerate){
  63. case 8000:
  64. if (mclk == 0){
  65. mclk = 1;
  66. }
  67. es8311_write_reg(ES8311_CLK_MANAGER_REG02, 0x08);
  68. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x44);
  69. if (switchflag == 0){
  70. switchflag = 1;
  71. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x19);
  72. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x19);
  73. }
  74. break;
  75. case 16000:
  76. if (mclk == 0){
  77. mclk = 1;
  78. }
  79. es8311_write_reg(ES8311_CLK_MANAGER_REG02, 0x90);
  80. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  81. if (switchflag == 0){
  82. switchflag = 1;
  83. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x19);
  84. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x19);
  85. }
  86. break;
  87. case 32000:
  88. if (mclk == 0){
  89. mclk = 1;
  90. }
  91. es8311_write_reg(ES8311_CLK_MANAGER_REG02, 0x18);
  92. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x44);
  93. if (switchflag == 0){
  94. switchflag = 1;
  95. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x19);
  96. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x19);
  97. }
  98. break;
  99. case 44100:
  100. mclk = 0;
  101. switchflag = 0;
  102. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x03 << 3));
  103. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  104. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  105. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  106. break;
  107. case 22050:
  108. mclk = 0;
  109. switchflag = 0;
  110. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x02 << 3));
  111. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  112. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  113. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  114. break;
  115. case 11025:
  116. mclk = 0;
  117. switchflag = 0;
  118. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x01 << 3));
  119. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  120. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  121. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  122. break;
  123. case 48000:
  124. mclk = 0;
  125. switchflag = 0;
  126. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x03 << 3));
  127. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  128. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  129. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  130. break;
  131. case 24000:
  132. mclk = 0;
  133. switchflag = 0;
  134. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x02 << 3));
  135. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  136. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  137. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  138. break;
  139. case 12000:
  140. mclk = 0;
  141. switchflag = 0;
  142. es8311_write_reg(ES8311_CLK_MANAGER_REG02, (0x01 << 3));
  143. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  144. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x10);
  145. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x10);
  146. break;
  147. default:
  148. break;
  149. }
  150. return 0;
  151. }
  152. static int es8311_update_bits(uint8_t reg, uint8_t mask, uint8_t val){
  153. uint8_t old, new;
  154. old = es8311_read_reg(reg);
  155. new = (old & ~mask) | (val & mask);
  156. es8311_write_reg(reg, new);
  157. return 0;
  158. }
  159. static int es8311_codec_samplebits(uint8_t samplebits){
  160. if(samplebits != 8 && samplebits != 16 && samplebits != 24 && samplebits != 32){
  161. LLOGE("bit_width error!\n");
  162. return -1;
  163. }
  164. int wl;
  165. switch (samplebits)
  166. {
  167. case 16:
  168. wl = 3;
  169. break;
  170. case 18:
  171. wl = 2;
  172. break;
  173. case 20:
  174. wl = 1;
  175. break;
  176. case 24:
  177. wl = 0;
  178. break;
  179. case 32:
  180. wl = 4;
  181. break;
  182. default:
  183. return -1;
  184. }
  185. es8311_update_bits(ES8311_SDPIN_REG09,
  186. ES8311_SDPIN_REG09_DACWL_MASK,
  187. wl << ES8311_SDPIN_REG09_DACWL_SHIFT);
  188. es8311_update_bits(ES8311_SDPOUT_REG0A,
  189. ES8311_SDPOUT_REG0A_ADCWL_MASK,
  190. wl << ES8311_SDPOUT_REG0A_ADCWL_SHIFT);
  191. return 0;
  192. }
  193. static int es8311_codec_channels(uint8_t channels){
  194. return 0;
  195. }
  196. static int es8311_reg_init(void){
  197. /* reset codec */
  198. es8311_write_reg(ES8311_RESET_REG00, 0x1F);
  199. es8311_write_reg(ES8311_GP_REG45, 0x00);
  200. luat_timer_mdelay(10);
  201. // es8311_write_reg(ES8311_GPIO_REG44, 0x08);
  202. // luat_timer_mdelay(1);
  203. // es8311_write_reg(ES8311_GPIO_REG44, 0x08);
  204. /* set ADC/DAC CLK */
  205. /* MCLK from BCLK */
  206. es8311_write_reg(ES8311_CLK_MANAGER_REG01, 0x30);
  207. es8311_write_reg(ES8311_CLK_MANAGER_REG02, 0x90);
  208. es8311_write_reg(ES8311_CLK_MANAGER_REG03, 0x19);
  209. es8311_write_reg(ES8311_ADC_REG16, 0x02);// bit5:0~non standard audio clock
  210. es8311_write_reg(ES8311_CLK_MANAGER_REG04, 0x19);
  211. es8311_write_reg(ES8311_CLK_MANAGER_REG05, 0x00);
  212. /*new cfg*/
  213. es8311_write_reg(ES8311_CLK_MANAGER_REG06, BCLK_DIV);
  214. es8311_write_reg(ES8311_CLK_MANAGER_REG07, 0x01);
  215. es8311_write_reg(ES8311_CLK_MANAGER_REG08, 0xff);
  216. /* set system power up */
  217. es8311_write_reg(ES8311_SYSTEM_REG0B, 0x00);
  218. es8311_write_reg(ES8311_SYSTEM_REG0C, 0x00);
  219. es8311_write_reg(ES8311_SYSTEM_REG10, 0x1F);
  220. es8311_write_reg(ES8311_SYSTEM_REG11, 0x7F);
  221. /* chip powerup. slave mode */
  222. es8311_write_reg(ES8311_RESET_REG00, 0x80);
  223. luat_timer_mdelay(50);
  224. /* power up analog */
  225. es8311_write_reg(ES8311_SYSTEM_REG0D, 0x01);
  226. /* power up digital */
  227. es8311_write_reg(ES8311_CLK_MANAGER_REG01, 0x3F);
  228. // SET ADC
  229. es8311_write_reg(ES8311_SYSTEM_REG14, DADC_GAIN);
  230. // SET DAC
  231. es8311_write_reg(ES8311_SYSTEM_REG12, 0x00);
  232. // ENABLE HP DRIVE
  233. es8311_write_reg(ES8311_SYSTEM_REG13, 0x10);
  234. // SET ADC/DAC DATA FORMAT
  235. es8311_write_reg(ES8311_SDPIN_REG09, 0x0c);
  236. es8311_write_reg(ES8311_SDPOUT_REG0A, 0x0c);
  237. /* set normal power mode */
  238. es8311_write_reg(ES8311_SYSTEM_REG0E, 0x02);
  239. es8311_write_reg(ES8311_SYSTEM_REG0F, 0x44);
  240. // SET ADC
  241. /* set adc softramp */
  242. es8311_write_reg(ES8311_ADC_REG15, 0x00);
  243. /* set adc hpf */
  244. es8311_write_reg(ES8311_ADC_REG1B, 0x05);
  245. /* set adc hpf,ADC_EQ bypass */
  246. es8311_write_reg(ES8311_ADC_REG1C, 0x65);
  247. /* set adc digtal vol */
  248. es8311_write_reg(ES8311_ADC_REG17, ADC_VOLUME_GAIN);
  249. /* set dac softramp,disable DAC_EQ */
  250. es8311_write_reg(ES8311_DAC_REG37, 0x08);
  251. es8311_write_reg(ES8311_DAC_REG32, 0xBF);
  252. // /* set adc gain scale up */
  253. // es8311_write_reg(ES8311_ADC_REG16, 0x24);
  254. // /* set adc alc maxgain */
  255. // es8311_write_reg(ES8311_ADC_REG17, 0xBF);
  256. // /* adc alc disable,alc_winsize */
  257. // es8311_write_reg(ES8311_ADC_REG18, 0x07);
  258. // /* set alc target level */
  259. // es8311_write_reg(ES8311_ADC_REG19, 0xFB);
  260. // /* set adc_automute noise gate */
  261. // es8311_write_reg(ES8311_ADC_REG1A, 0x03);
  262. // /* set adc_automute vol */
  263. // es8311_write_reg(ES8311_ADC_REG1B, 0xEA);
  264. return 0;
  265. }
  266. static int es8311_codec_init(audio_codec_conf_t* conf){
  267. uint8_t temp1 = 0, temp2 = 0, temp3 = 0;
  268. if (conf->pa_pin != -1){
  269. luat_gpio_mode(conf->pa_pin, Luat_GPIO_OUTPUT, Luat_GPIO_DEFAULT, !conf->pa_on_level);
  270. luat_gpio_set(conf->pa_pin, !conf->pa_on_level);
  271. }
  272. luat_i2c_setup(0, I2C_REQ);
  273. temp1 = es8311_read_reg(ES8311_CHD1_REGFD);
  274. temp2 = es8311_read_reg(ES8311_CHD2_REGFE);
  275. temp3 = es8311_read_reg(ES8311_CHVER_REGFF);
  276. if(temp1 != 0x83 || temp2 != 0x11){
  277. LLOGE("codec err, id = 0x%x 0x%x ver = 0x%x", temp1, temp2, temp3);
  278. return -1;
  279. }
  280. es8311_reg_init();
  281. return 0;
  282. }
  283. static int es8311_codec_deinit(audio_codec_conf_t* conf){
  284. return 0;
  285. }
  286. static void es8311_codec_pa(audio_codec_conf_t* conf,uint8_t on){
  287. if (on){
  288. luat_timer_mdelay(conf->dummy_time_len);
  289. luat_gpio_set(conf->pa_pin, conf->pa_on_level);
  290. luat_timer_mdelay(conf->pa_delay_time);
  291. }else{
  292. luat_gpio_set(conf->pa_pin, !conf->pa_on_level);
  293. }
  294. }
  295. static int es8311_codec_control(audio_codec_conf_t* conf,uint8_t cmd,int data){
  296. switch (cmd)
  297. {
  298. case CODEC_CTL_MODE:
  299. es8311_codec_mode((uint8_t)data);
  300. break;
  301. case CODEC_CTL_VOLUME:
  302. es8311_codec_vol((uint8_t)data);
  303. break;
  304. case CODEC_CTL_RATE:
  305. es8311_codec_samplerate((uint16_t)data);
  306. break;
  307. case CODEC_CTL_BITS:
  308. es8311_codec_samplebits((uint8_t)data);
  309. break;
  310. case CODEC_CTL_CHANNEL:
  311. es8311_codec_channels((uint8_t)data);
  312. break;
  313. case CODEC_CTL_PA:
  314. es8311_codec_pa(conf,(uint8_t)data);
  315. break;
  316. default:
  317. break;
  318. }
  319. return 0;
  320. }
  321. static int es8311_codec_start(audio_codec_conf_t* conf){
  322. return 0;
  323. }
  324. static int es8311_codec_stop(audio_codec_conf_t* conf){
  325. return 0;
  326. }
  327. const audio_codec_opts_t codec_opts_es8311 = {
  328. .name = "es8311",
  329. .init = es8311_codec_init,
  330. .deinit = es8311_codec_deinit,
  331. .control = es8311_codec_control,
  332. .start = es8311_codec_start,
  333. .stop = es8311_codec_stop,
  334. };