recmgr.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. **********************************************************************
  3. * recmgr.c -- Recording manager for emu10k1 driver
  4. * Copyright 1999, 2000 Creative Labs, Inc.
  5. *
  6. **********************************************************************
  7. *
  8. * Date Author Summary of changes
  9. * ---- ------ ------------------
  10. * October 20, 1999 Bertrand Lee base code release
  11. *
  12. **********************************************************************
  13. *
  14. * This program is free software; you can redistribute it and/or
  15. * modify it under the terms of the GNU General Public License as
  16. * published by the Free Software Foundation; either version 2 of
  17. * the License, or (at your option) any later version.
  18. *
  19. * This program is distributed in the hope that it will be useful,
  20. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  21. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  22. * GNU General Public License for more details.
  23. *
  24. * You should have received a copy of the GNU General Public
  25. * License along with this program; if not, write to the Free
  26. * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139,
  27. * USA.
  28. *
  29. **********************************************************************
  30. */
  31. #include <asm/delay.h>
  32. #include "8010.h"
  33. #include "recmgr.h"
  34. void emu10k1_reset_record(struct emu10k1_card *card, struct wavein_buffer *buffer)
  35. {
  36. DPF(2, "emu10k1_reset_record()\n");
  37. sblive_writeptr(card, buffer->sizereg, 0, ADCBS_BUFSIZE_NONE);
  38. sblive_writeptr(card, buffer->sizereg, 0, buffer->sizeregval);
  39. while (sblive_readptr(card, buffer->idxreg, 0))
  40. udelay(5);
  41. }
  42. void emu10k1_start_record(struct emu10k1_card *card, struct wavein_buffer *buffer)
  43. {
  44. DPF(2, "emu10k1_start_record()\n");
  45. if (buffer->adcctl)
  46. sblive_writeptr(card, ADCCR, 0, buffer->adcctl);
  47. }
  48. void emu10k1_stop_record(struct emu10k1_card *card, struct wavein_buffer *buffer)
  49. {
  50. DPF(2, "emu10k1_stop_record()\n");
  51. /* Disable record transfer */
  52. if (buffer->adcctl)
  53. sblive_writeptr(card, ADCCR, 0, 0);
  54. }
  55. void emu10k1_set_record_src(struct emu10k1_card *card, struct wiinst *wiinst)
  56. {
  57. struct wavein_buffer *buffer = &wiinst->buffer;
  58. DPF(2, "emu10k1_set_record_src()\n");
  59. switch (wiinst->recsrc) {
  60. case WAVERECORD_AC97:
  61. DPF(2, "recording source: AC97\n");
  62. buffer->sizereg = ADCBS;
  63. buffer->addrreg = ADCBA;
  64. buffer->idxreg = card->is_audigy ? A_ADCIDX_IDX : ADCIDX_IDX;
  65. switch (wiinst->format.samplingrate) {
  66. case 0xBB80:
  67. buffer->adcctl = ADCCR_SAMPLERATE_48;
  68. break;
  69. case 0xAC44:
  70. buffer->adcctl = ADCCR_SAMPLERATE_44;
  71. break;
  72. case 0x7D00:
  73. buffer->adcctl = ADCCR_SAMPLERATE_32;
  74. break;
  75. case 0x5DC0:
  76. buffer->adcctl = ADCCR_SAMPLERATE_24;
  77. break;
  78. case 0x5622:
  79. buffer->adcctl = ADCCR_SAMPLERATE_22;
  80. break;
  81. case 0x3E80:
  82. buffer->adcctl = ADCCR_SAMPLERATE_16;
  83. break;
  84. // FIXME: audigy supports 12kHz recording
  85. /*
  86. case ????:
  87. buffer->adcctl = A_ADCCR_SAMPLERATE_12;
  88. break;
  89. */
  90. case 0x2B11:
  91. buffer->adcctl = card->is_audigy ? A_ADCCR_SAMPLERATE_11 : ADCCR_SAMPLERATE_11;
  92. break;
  93. case 0x1F40:
  94. buffer->adcctl = card->is_audigy ? A_ADCCR_SAMPLERATE_8 : ADCCR_SAMPLERATE_8;
  95. break;
  96. default:
  97. BUG();
  98. break;
  99. }
  100. buffer->adcctl |= card->is_audigy ? A_ADCCR_LCHANENABLE : ADCCR_LCHANENABLE;
  101. if (wiinst->format.channels == 2)
  102. buffer->adcctl |= card->is_audigy ? A_ADCCR_RCHANENABLE : ADCCR_RCHANENABLE;
  103. break;
  104. case WAVERECORD_MIC:
  105. DPF(2, "recording source: MIC\n");
  106. buffer->sizereg = MICBS;
  107. buffer->addrreg = MICBA;
  108. buffer->idxreg = MICIDX_IDX;
  109. buffer->adcctl = 0;
  110. break;
  111. case WAVERECORD_FX:
  112. DPF(2, "recording source: FX\n");
  113. buffer->sizereg = FXBS;
  114. buffer->addrreg = FXBA;
  115. buffer->idxreg = FXIDX_IDX;
  116. buffer->adcctl = 0;
  117. sblive_writeptr(card, FXWC, 0, wiinst->fxwc);
  118. break;
  119. default:
  120. BUG();
  121. break;
  122. }
  123. DPD(2, "bus addx: %#lx\n", (unsigned long) buffer->dma_handle);
  124. sblive_writeptr(card, buffer->addrreg, 0, (u32)buffer->dma_handle);
  125. }