nm256_audio.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:42k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /* 
  2.  * Audio driver for the NeoMagic 256AV and 256ZX chipsets in native
  3.  * mode, with AC97 mixer support.
  4.  *
  5.  * Overall design and parts of this code stolen from vidc_*.c and
  6.  * skeleton.c.
  7.  *
  8.  * Yeah, there are a lot of magic constants in here.  You tell ME what
  9.  * they are.  I just get this stuff psychically, remember? 
  10.  *
  11.  * This driver was written by someone who wishes to remain anonymous. 
  12.  * It is in the public domain, so share and enjoy.  Try to make a profit
  13.  * off of it; go on, I dare you.  
  14.  *
  15.  * Changes:
  16.  * 11-10-2000 Bartlomiej Zolnierkiewicz <bkz@linux-ide.org>
  17.  * Added some __init
  18.  * 19-04-2001 Marcus Meissner <mm@caldera.de>
  19.  * Ported to 2.4 PCI API.
  20.  */
  21. #define __NO_VERSION__
  22. #include <linux/pci.h>
  23. #include <linux/init.h>
  24. #include <linux/module.h>
  25. #include <linux/pm.h>
  26. #include <linux/delay.h>
  27. #include "sound_config.h"
  28. #include "nm256.h"
  29. #include "nm256_coeff.h"
  30. int nm256_debug;
  31. static int force_load;
  32. /* 
  33.  * The size of the playback reserve.  When the playback buffer has less
  34.  * than NM256_PLAY_WMARK_SIZE bytes to output, we request a new
  35.  * buffer.
  36.  */
  37. #define NM256_PLAY_WMARK_SIZE 512
  38. static struct audio_driver nm256_audio_driver;
  39. static int nm256_grabInterrupt (struct nm256_info *card);
  40. static int nm256_releaseInterrupt (struct nm256_info *card);
  41. static void nm256_interrupt (int irq, void *dev_id, struct pt_regs *dummy);
  42. static void nm256_interrupt_zx (int irq, void *dev_id, struct pt_regs *dummy);
  43. static int handle_pm_event (struct pm_dev *dev, pm_request_t rqst, void *data);
  44. /* These belong in linux/pci.h. */
  45. #define PCI_DEVICE_ID_NEOMAGIC_NM256AV_AUDIO 0x8005
  46. #define PCI_DEVICE_ID_NEOMAGIC_NM256ZX_AUDIO 0x8006
  47. /* List of cards.  */
  48. static struct nm256_info *nmcard_list;
  49. /* Release the mapped-in memory for CARD.  */
  50. static void
  51. nm256_release_ports (struct nm256_info *card)
  52. {
  53.     int x;
  54.     for (x = 0; x < 2; x++) {
  55. if (card->port[x].ptr != NULL) {
  56.     iounmap (card->port[x].ptr);
  57.     card->port[x].ptr = NULL;
  58. }
  59.     }
  60. }
  61. /* 
  62.  * Map in the memory ports for CARD, if they aren't already mapped in
  63.  * and have been configured.  If successful, a zero value is returned;
  64.  * otherwise any previously mapped-in areas are released and a non-zero
  65.  * value is returned.
  66.  *
  67.  * This is invoked twice, once for each port.  Ideally it would only be
  68.  * called once, but we now need to map in the second port in order to
  69.  * check how much memory the card has on the 256ZX.
  70.  */
  71. static int
  72. nm256_remap_ports (struct nm256_info *card)
  73. {
  74.     int x;
  75.     for (x = 0; x < 2; x++) {
  76. if (card->port[x].ptr == NULL && card->port[x].end_offset > 0) {
  77.     u32 physaddr 
  78. = card->port[x].physaddr + card->port[x].start_offset;
  79.     u32 size 
  80. = card->port[x].end_offset - card->port[x].start_offset;
  81.     card->port[x].ptr = ioremap_nocache (physaddr, size);
  82.   
  83.     if (card->port[x].ptr == NULL) {
  84. printk (KERN_ERR "NM256: Unable to remap port %dn", x + 1);
  85. nm256_release_ports (card);
  86. return -1;
  87.     }
  88. }
  89.     }
  90.     return 0;
  91. }
  92. /* Locate the card in our list. */
  93. static struct nm256_info *
  94. nm256_find_card (int dev)
  95. {
  96.     struct nm256_info *card;
  97.     for (card = nmcard_list; card != NULL; card = card->next_card)
  98. if (card->dev[0] == dev || card->dev[1] == dev)
  99.     return card;
  100.     return NULL;
  101. }
  102. /*
  103.  * Ditto, but find the card struct corresponding to the mixer device DEV 
  104.  * instead. 
  105.  */
  106. static struct nm256_info *
  107. nm256_find_card_for_mixer (int dev)
  108. {
  109.     struct nm256_info *card;
  110.     for (card = nmcard_list; card != NULL; card = card->next_card)
  111. if (card->mixer_oss_dev == dev)
  112.     return card;
  113.     return NULL;
  114. }
  115. static int usecache;
  116. static int buffertop;
  117. /* Check to see if we're using the bank of cached coefficients. */
  118. int
  119. nm256_cachedCoefficients (struct nm256_info *card)
  120. {
  121.     return usecache;
  122. }
  123. /* The actual rates supported by the card. */
  124. static int samplerates[9] = {
  125.     8000, 11025, 16000, 22050, 24000, 32000, 44100, 48000, 99999999
  126. };
  127. /*
  128.  * Set the card samplerate, word size and stereo mode to correspond to
  129.  * the settings in the CARD struct for the specified device in DEV.
  130.  * We keep two separate sets of information, one for each device; the
  131.  * hardware is not actually configured until a read or write is
  132.  * attempted.
  133.  */
  134. int
  135. nm256_setInfo (int dev, struct nm256_info *card)
  136. {
  137.     int x;
  138.     int w;
  139.     int targetrate;
  140.     if (card->dev[0] == dev)
  141. w = 0;
  142.     else if (card->dev[1] == dev)
  143. w = 1;
  144.     else
  145. return -ENODEV;
  146.     targetrate = card->sinfo[w].samplerate;
  147.     if ((card->sinfo[w].bits != 8 && card->sinfo[w].bits != 16)
  148. || targetrate < samplerates[0]
  149. || targetrate > samplerates[7])
  150. return -EINVAL;
  151.     for (x = 0; x < 8; x++)
  152. if (targetrate < ((samplerates[x] + samplerates[x + 1]) / 2))
  153.     break;
  154.     if (x < 8) {
  155. u8 ratebits = ((x << 4) & NM_RATE_MASK);
  156. if (card->sinfo[w].bits == 16)
  157.     ratebits |= NM_RATE_BITS_16;
  158. if (card->sinfo[w].stereo)
  159.     ratebits |= NM_RATE_STEREO;
  160. card->sinfo[w].samplerate = samplerates[x];
  161. if (card->dev_for_play == dev && card->playing) {
  162.     if (nm256_debug)
  163. printk (KERN_DEBUG "Setting play ratebits to 0x%xn",
  164. ratebits);
  165.     nm256_loadCoefficient (card, 0, x);
  166.     nm256_writePort8 (card, 2,
  167.       NM_PLAYBACK_REG_OFFSET + NM_RATE_REG_OFFSET,
  168.       ratebits);
  169. }
  170. if (card->dev_for_record == dev && card->recording) {
  171.     if (nm256_debug)
  172. printk (KERN_DEBUG "Setting record ratebits to 0x%xn",
  173. ratebits);
  174.     nm256_loadCoefficient (card, 1, x);
  175.     nm256_writePort8 (card, 2,
  176.       NM_RECORD_REG_OFFSET + NM_RATE_REG_OFFSET,
  177.       ratebits);
  178. }
  179. return 0;
  180.     }
  181.     else
  182. return -EINVAL;
  183. }
  184. /* Start the play process going. */
  185. static void
  186. startPlay (struct nm256_info *card)
  187. {
  188.     if (! card->playing) {
  189. card->playing = 1;
  190. if (nm256_grabInterrupt (card) == 0) {
  191.     nm256_setInfo (card->dev_for_play, card);
  192.     /* Enable playback engine and interrupts. */
  193.     nm256_writePort8 (card, 2, NM_PLAYBACK_ENABLE_REG,
  194.       NM_PLAYBACK_ENABLE_FLAG | NM_PLAYBACK_FREERUN);
  195.     /* Enable both channels. */
  196.     nm256_writePort16 (card, 2, NM_AUDIO_MUTE_REG, 0x0);
  197. }
  198.     }
  199. }
  200. /* 
  201.  * Request one chunk of AMT bytes from the recording device.  When the
  202.  * operation is complete, the data will be copied into BUFFER and the
  203.  * function DMAbuf_inputintr will be invoked.
  204.  */
  205. static void
  206. nm256_startRecording (struct nm256_info *card, char *buffer, u32 amt)
  207. {
  208.     u32 endpos;
  209.     int enableEngine = 0;
  210.     u32 ringsize = card->recordBufferSize;
  211.     unsigned long flags;
  212.     if (amt > (ringsize / 2)) {
  213. /*
  214.  * Of course this won't actually work right, because the
  215.  * caller is going to assume we will give what we got asked
  216.  * for.
  217.  */
  218. printk (KERN_ERR "NM256: Read request too large: %dn", amt);
  219. amt = ringsize / 2;
  220.     }
  221.     if (amt < 8) {
  222. printk (KERN_ERR "NM256: Read request too small; %dn", amt);
  223. return;
  224.     }
  225.     save_flags (flags);
  226.     cli ();
  227.     /*
  228.      * If we're not currently recording, set up the start and end registers
  229.      * for the recording engine.
  230.      */
  231.     if (! card->recording) {
  232. card->recording = 1;
  233. if (nm256_grabInterrupt (card) == 0) {
  234.     card->curRecPos = 0;
  235.     nm256_setInfo (card->dev_for_record, card);
  236.     nm256_writePort32 (card, 2, NM_RBUFFER_START, card->abuf2);
  237.     nm256_writePort32 (card, 2, NM_RBUFFER_END,
  238.  card->abuf2 + ringsize);
  239.     nm256_writePort32 (card, 2, NM_RBUFFER_CURRP,
  240.  card->abuf2 + card->curRecPos);
  241.     enableEngine = 1;
  242. }
  243. else {
  244.     /* Not sure what else to do here.  */
  245.     restore_flags (flags);
  246.     return;
  247. }
  248.     }
  249.     /* 
  250.      * If we happen to go past the end of the buffer a bit (due to a
  251.      * delayed interrupt) it's OK.  So might as well set the watermark
  252.      * right at the end of the data we want.
  253.      */
  254.     endpos = card->abuf2 + ((card->curRecPos + amt) % ringsize);
  255.     card->recBuf = buffer;
  256.     card->requestedRecAmt = amt;
  257.     nm256_writePort32 (card, 2, NM_RBUFFER_WMARK, endpos);
  258.     /* Enable recording engine and interrupts. */
  259.     if (enableEngine)
  260. nm256_writePort8 (card, 2, NM_RECORD_ENABLE_REG,
  261.     NM_RECORD_ENABLE_FLAG | NM_RECORD_FREERUN);
  262.     restore_flags (flags);
  263. }
  264. /* Stop the play engine. */
  265. static void
  266. stopPlay (struct nm256_info *card)
  267. {
  268.     /* Shut off sound from both channels. */
  269.     nm256_writePort16 (card, 2, NM_AUDIO_MUTE_REG,
  270.        NM_AUDIO_MUTE_LEFT | NM_AUDIO_MUTE_RIGHT);
  271.     /* Disable play engine. */
  272.     nm256_writePort8 (card, 2, NM_PLAYBACK_ENABLE_REG, 0);
  273.     if (card->playing) {
  274. nm256_releaseInterrupt (card);
  275. /* Reset the relevant state bits. */
  276. card->playing = 0;
  277. card->curPlayPos = 0;
  278.     }
  279. }
  280. /* Stop recording. */
  281. static void
  282. stopRecord (struct nm256_info *card)
  283. {
  284.     /* Disable recording engine. */
  285.     nm256_writePort8 (card, 2, NM_RECORD_ENABLE_REG, 0);
  286.     if (card->recording) {
  287. nm256_releaseInterrupt (card);
  288. card->recording = 0;
  289. card->curRecPos = 0;
  290.     }
  291. }
  292. /*
  293.  * Ring buffers, man.  That's where the hip-hop, wild-n-wooly action's at.
  294.  * 1972?  (Well, I suppose it was cheep-n-easy to implement.)
  295.  *
  296.  * Write AMT bytes of BUFFER to the playback ring buffer, and start the
  297.  * playback engine running.  It will only accept up to 1/2 of the total
  298.  * size of the ring buffer.  No check is made that we're about to overwrite
  299.  * the currently-playing sample.
  300.  */
  301. static void
  302. nm256_write_block (struct nm256_info *card, char *buffer, u32 amt)
  303. {
  304.     u32 ringsize = card->playbackBufferSize;
  305.     u32 endstop;
  306.     unsigned long flags;
  307.     if (amt > (ringsize / 2)) {
  308. printk (KERN_ERR "NM256: Write request too large: %dn", amt);
  309. amt = (ringsize / 2);
  310.     }
  311.     if (amt < NM256_PLAY_WMARK_SIZE) {
  312. printk (KERN_ERR "NM256: Write request too small: %dn", amt);
  313. return;
  314.     }
  315.     card->curPlayPos %= ringsize;
  316.     card->requested_amt = amt;
  317.     save_flags (flags);
  318.     cli ();
  319.     if ((card->curPlayPos + amt) >= ringsize) {
  320. u32 rem = ringsize - card->curPlayPos;
  321. nm256_writeBuffer8 (card, buffer, 1,
  322.       card->abuf1 + card->curPlayPos,
  323.       rem);
  324. if (amt > rem)
  325.     nm256_writeBuffer8 (card, buffer + rem, 1, card->abuf1,
  326.   amt - rem);
  327.     } 
  328.     else
  329. nm256_writeBuffer8 (card, buffer, 1,
  330.       card->abuf1 + card->curPlayPos,
  331.       amt);
  332.     /*
  333.      * Setup the start-n-stop-n-limit registers, and start that engine
  334.      * goin'. 
  335.      *
  336.      * Normally we just let it wrap around to avoid the click-click
  337.      * action scene.
  338.      */
  339.     if (! card->playing) {
  340. /* The PBUFFER_END register in this case points to one sample
  341.    before the end of the buffer. */
  342. int w = (card->dev_for_play == card->dev[0] ? 0 : 1);
  343. int sampsize = (card->sinfo[w].bits == 16 ? 2 : 1);
  344. if (card->sinfo[w].stereo)
  345.     sampsize *= 2;
  346. /* Need to set the not-normally-changing-registers up. */
  347. nm256_writePort32 (card, 2, NM_PBUFFER_START,
  348.      card->abuf1 + card->curPlayPos);
  349. nm256_writePort32 (card, 2, NM_PBUFFER_END,
  350.      card->abuf1 + ringsize - sampsize);
  351. nm256_writePort32 (card, 2, NM_PBUFFER_CURRP,
  352.      card->abuf1 + card->curPlayPos);
  353.     }
  354.     endstop = (card->curPlayPos + amt - NM256_PLAY_WMARK_SIZE) % ringsize;
  355.     nm256_writePort32 (card, 2, NM_PBUFFER_WMARK, card->abuf1 + endstop);
  356.     if (! card->playing)
  357. startPlay (card);
  358.     restore_flags (flags);
  359. }
  360. /*  We just got a card playback interrupt; process it.  */
  361. static void
  362. nm256_get_new_block (struct nm256_info *card)
  363. {
  364.     /* Check to see how much got played so far. */
  365.     u32 amt = nm256_readPort32 (card, 2, NM_PBUFFER_CURRP) - card->abuf1;
  366.     if (amt >= card->playbackBufferSize) {
  367. printk (KERN_ERR "NM256: Sound playback pointer invalid!n");
  368. amt = 0;
  369.     }
  370.     if (amt < card->curPlayPos)
  371. amt = (card->playbackBufferSize - card->curPlayPos) + amt;
  372.     else
  373. amt -= card->curPlayPos;
  374.     if (card->requested_amt > (amt + NM256_PLAY_WMARK_SIZE)) {
  375. u32 endstop =
  376.     card->curPlayPos + card->requested_amt - NM256_PLAY_WMARK_SIZE;
  377. nm256_writePort32 (card, 2, NM_PBUFFER_WMARK, card->abuf1 + endstop);
  378.     } 
  379.     else {
  380. card->curPlayPos += card->requested_amt;
  381. /* Get a new block to write.  This will eventually invoke
  382.    nm256_write_block () or stopPlay ().  */
  383. DMAbuf_outputintr (card->dev_for_play, 1);
  384.     }
  385. }
  386. /* Ultra cheez-whiz.  But I'm too lazy to grep headers. */
  387. #define MIN(X,Y) ((X) < (Y) ? (X) : (Y))
  388. /* 
  389.  * Read the last-recorded block from the ring buffer, copy it into the
  390.  * saved buffer pointer, and invoke DMAuf_inputintr() with the recording
  391.  * device. 
  392.  */
  393. static void
  394. nm256_read_block (struct nm256_info *card)
  395. {
  396.     /* Grab the current position of the recording pointer. */
  397.     u32 currptr = nm256_readPort32 (card, 2, NM_RBUFFER_CURRP) - card->abuf2;
  398.     u32 amtToRead = card->requestedRecAmt;
  399.     u32 ringsize = card->recordBufferSize;
  400.     if (currptr >= card->recordBufferSize) {
  401. printk (KERN_ERR "NM256: Sound buffer record pointer invalid!n");
  402.         currptr = 0;
  403.     }
  404.     /*
  405.      * This test is probably redundant; we shouldn't be here unless
  406.      * it's true.
  407.      */
  408.     if (card->recording) {
  409. /* If we wrapped around, copy everything from the start of our
  410.    recording buffer to the end of the buffer. */
  411. if (currptr < card->curRecPos) {
  412.     u32 amt = MIN (ringsize - card->curRecPos, amtToRead);
  413.     nm256_readBuffer8 (card, card->recBuf, 1,
  414.  card->abuf2 + card->curRecPos,
  415.  amt);
  416.     amtToRead -= amt;
  417.     card->curRecPos += amt;
  418.     card->recBuf += amt;
  419.     if (card->curRecPos == ringsize)
  420. card->curRecPos = 0;
  421. }
  422. if ((card->curRecPos < currptr) && (amtToRead > 0)) {
  423.     u32 amt = MIN (currptr - card->curRecPos, amtToRead);
  424.     nm256_readBuffer8 (card, card->recBuf, 1,
  425.  card->abuf2 + card->curRecPos, amt);
  426.     card->curRecPos = ((card->curRecPos + amt) % ringsize);
  427. }
  428. card->recBuf = NULL;
  429. card->requestedRecAmt = 0;
  430. DMAbuf_inputintr (card->dev_for_record);
  431.     }
  432. }
  433. #undef MIN
  434. /* 
  435.  * Initialize the hardware. 
  436.  */
  437. static void
  438. nm256_initHw (struct nm256_info *card)
  439. {
  440.     /* Reset everything. */
  441.     nm256_writePort8 (card, 2, 0x0, 0x11);
  442.     nm256_writePort16 (card, 2, 0x214, 0);
  443.     stopRecord (card);
  444.     stopPlay (card);
  445. }
  446. /* 
  447.  * Handle a potential interrupt for the device referred to by DEV_ID. 
  448.  *
  449.  * I don't like the cut-n-paste job here either between the two routines,
  450.  * but there are sufficient differences between the two interrupt handlers
  451.  * that parameterizing it isn't all that great either.  (Could use a macro,
  452.  * I suppose...yucky bleah.)
  453.  */
  454. static void
  455. nm256_interrupt (int irq, void *dev_id, struct pt_regs *dummy)
  456. {
  457.     struct nm256_info *card = (struct nm256_info *)dev_id;
  458.     u16 status;
  459.     static int badintrcount = 0;
  460.     if ((card == NULL) || (card->magsig != NM_MAGIC_SIG)) {
  461. printk (KERN_ERR "NM256: Bad card pointern");
  462. return;
  463.     }
  464.     status = nm256_readPort16 (card, 2, NM_INT_REG);
  465.     /* Not ours. */
  466.     if (status == 0) {
  467. if (badintrcount++ > 1000) {
  468.     /*
  469.      * I'm not sure if the best thing is to stop the card from
  470.      * playing or just release the interrupt (after all, we're in
  471.      * a bad situation, so doing fancy stuff may not be such a good
  472.      * idea).
  473.      *
  474.      * I worry about the card engine continuing to play noise
  475.      * over and over, however--that could become a very
  476.      * obnoxious problem.  And we know that when this usually
  477.      * happens things are fairly safe, it just means the user's
  478.      * inserted a PCMCIA card and someone's spamming us with IRQ 9s.
  479.      */
  480.     if (card->playing)
  481. stopPlay (card);
  482.     if (card->recording)
  483. stopRecord (card);
  484.     badintrcount = 0;
  485. }
  486. return;
  487.     }
  488.     badintrcount = 0;
  489.     /* Rather boring; check for individual interrupts and process them. */
  490.     if (status & NM_PLAYBACK_INT) {
  491. status &= ~NM_PLAYBACK_INT;
  492. NM_ACK_INT (card, NM_PLAYBACK_INT);
  493. if (card->playing)
  494.     nm256_get_new_block (card);
  495.     }
  496.     if (status & NM_RECORD_INT) {
  497. status &= ~NM_RECORD_INT;
  498. NM_ACK_INT (card, NM_RECORD_INT);
  499. if (card->recording)
  500.     nm256_read_block (card);
  501.     }
  502.     if (status & NM_MISC_INT_1) {
  503. u8 cbyte;
  504. status &= ~NM_MISC_INT_1;
  505. printk (KERN_ERR "NM256: Got misc interrupt #1n");
  506. NM_ACK_INT (card, NM_MISC_INT_1);
  507. nm256_writePort16 (card, 2, NM_INT_REG, 0x8000);
  508. cbyte = nm256_readPort8 (card, 2, 0x400);
  509. nm256_writePort8 (card, 2, 0x400, cbyte | 2);
  510.     }
  511.     if (status & NM_MISC_INT_2) {
  512. u8 cbyte;
  513. status &= ~NM_MISC_INT_2;
  514. printk (KERN_ERR "NM256: Got misc interrupt #2n");
  515. NM_ACK_INT (card, NM_MISC_INT_2);
  516. cbyte = nm256_readPort8 (card, 2, 0x400);
  517. nm256_writePort8 (card, 2, 0x400, cbyte & ~2);
  518.     }
  519.     /* Unknown interrupt. */
  520.     if (status) {
  521. printk (KERN_ERR "NM256: Fire in the hole! Unknown status 0x%xn",
  522. status);
  523. /* Pray. */
  524. NM_ACK_INT (card, status);
  525.     }
  526. }
  527. /*
  528.  * Handle a potential interrupt for the device referred to by DEV_ID.
  529.  * This handler is for the 256ZX, and is very similar to the non-ZX
  530.  * routine.
  531.  */
  532. static void
  533. nm256_interrupt_zx (int irq, void *dev_id, struct pt_regs *dummy)
  534. {
  535.     struct nm256_info *card = (struct nm256_info *)dev_id;
  536.     u32 status;
  537.     static int badintrcount = 0;
  538.     if ((card == NULL) || (card->magsig != NM_MAGIC_SIG)) {
  539. printk (KERN_ERR "NM256: Bad card pointern");
  540. return;
  541.     }
  542.     status = nm256_readPort32 (card, 2, NM_INT_REG);
  543.     /* Not ours. */
  544.     if (status == 0) {
  545. if (badintrcount++ > 1000) {
  546.     printk (KERN_ERR "NM256: Releasing interrupt, over 1000 invalid interruptsn");
  547.     /*
  548.      * I'm not sure if the best thing is to stop the card from
  549.      * playing or just release the interrupt (after all, we're in
  550.      * a bad situation, so doing fancy stuff may not be such a good
  551.      * idea).
  552.      *
  553.      * I worry about the card engine continuing to play noise
  554.      * over and over, however--that could become a very
  555.      * obnoxious problem.  And we know that when this usually
  556.      * happens things are fairly safe, it just means the user's
  557.      * inserted a PCMCIA card and someone's spamming us with 
  558.      * IRQ 9s.
  559.      */
  560.     if (card->playing)
  561. stopPlay (card);
  562.     if (card->recording)
  563. stopRecord (card);
  564.     badintrcount = 0;
  565. }
  566. return;
  567.     }
  568.     badintrcount = 0;
  569.     /* Rather boring; check for individual interrupts and process them. */
  570.     if (status & NM2_PLAYBACK_INT) {
  571. status &= ~NM2_PLAYBACK_INT;
  572. NM2_ACK_INT (card, NM2_PLAYBACK_INT);
  573. if (card->playing)
  574.     nm256_get_new_block (card);
  575.     }
  576.     if (status & NM2_RECORD_INT) {
  577. status &= ~NM2_RECORD_INT;
  578. NM2_ACK_INT (card, NM2_RECORD_INT);
  579. if (card->recording)
  580.     nm256_read_block (card);
  581.     }
  582.     if (status & NM2_MISC_INT_1) {
  583. u8 cbyte;
  584. status &= ~NM2_MISC_INT_1;
  585. printk (KERN_ERR "NM256: Got misc interrupt #1n");
  586. NM2_ACK_INT (card, NM2_MISC_INT_1);
  587. cbyte = nm256_readPort8 (card, 2, 0x400);
  588. nm256_writePort8 (card, 2, 0x400, cbyte | 2);
  589.     }
  590.     if (status & NM2_MISC_INT_2) {
  591. u8 cbyte;
  592. status &= ~NM2_MISC_INT_2;
  593. printk (KERN_ERR "NM256: Got misc interrupt #2n");
  594. NM2_ACK_INT (card, NM2_MISC_INT_2);
  595. cbyte = nm256_readPort8 (card, 2, 0x400);
  596. nm256_writePort8 (card, 2, 0x400, cbyte & ~2);
  597.     }
  598.     /* Unknown interrupt. */
  599.     if (status) {
  600. printk (KERN_ERR "NM256: Fire in the hole! Unknown status 0x%xn",
  601. status);
  602. /* Pray. */
  603. NM2_ACK_INT (card, status);
  604.     }
  605. }
  606. /* 
  607.  * Request our interrupt.
  608.  */
  609. static int
  610. nm256_grabInterrupt (struct nm256_info *card)
  611. {
  612.     if (card->has_irq++ == 0) {
  613. if (request_irq (card->irq, card->introutine, SA_SHIRQ,
  614.  "NM256_audio", card) < 0) {
  615.     printk (KERN_ERR "NM256: can't obtain IRQ %dn", card->irq);
  616.     return -1;
  617. }
  618.     }
  619.     return 0;
  620. }
  621. /* 
  622.  * Release our interrupt. 
  623.  */
  624. static int
  625. nm256_releaseInterrupt (struct nm256_info *card)
  626. {
  627.     if (card->has_irq <= 0) {
  628. printk (KERN_ERR "nm256: too many calls to releaseInterruptn");
  629. return -1;
  630.     }
  631.     card->has_irq--;
  632.     if (card->has_irq == 0) {
  633. free_irq (card->irq, card);
  634.     }
  635.     return 0;
  636. }
  637. /*
  638.  * Waits for the mixer to become ready to be written; returns a zero value
  639.  * if it timed out.
  640.  */
  641. static int
  642. nm256_isReady (struct ac97_hwint *dev)
  643. {
  644.     struct nm256_info *card = (struct nm256_info *)dev->driver_private;
  645.     int t2 = 10;
  646.     u32 testaddr;
  647.     u16 testb;
  648.     int done = 0;
  649.     if (card->magsig != NM_MAGIC_SIG) {
  650. printk (KERN_ERR "NM256: Bad magic signature in isReady!n");
  651. return 0;
  652.     }
  653.     testaddr = card->mixer_status_offset;
  654.     testb = card->mixer_status_mask;
  655.     /* 
  656.      * Loop around waiting for the mixer to become ready. 
  657.      */
  658.     while (! done && t2-- > 0) {
  659. if ((nm256_readPort16 (card, 2, testaddr) & testb) == 0)
  660.     done = 1;
  661. else
  662.     udelay (100);
  663.     }
  664.     return done;
  665. }
  666. /*
  667.  * Return the contents of the AC97 mixer register REG.  Returns a positive
  668.  * value if successful, or a negative error code.
  669.  */
  670. static int
  671. nm256_readAC97Reg (struct ac97_hwint *dev, u8 reg)
  672. {
  673.     struct nm256_info *card = (struct nm256_info *)dev->driver_private;
  674.     if (card->magsig != NM_MAGIC_SIG) {
  675. printk (KERN_ERR "NM256: Bad magic signature in readAC97Reg!n");
  676. return -EINVAL;
  677.     }
  678.     if (reg < 128) {
  679. int res;
  680. nm256_isReady (dev);
  681. res = nm256_readPort16 (card, 2, card->mixer + reg);
  682. /* Magic delay.  Bleah yucky.  */
  683.         udelay (1000);
  684. return res;
  685.     }
  686.     else
  687. return -EINVAL;
  688. }
  689. /* 
  690.  * Writes VALUE to AC97 mixer register REG.  Returns 0 if successful, or
  691.  * a negative error code. 
  692.  */
  693. static int
  694. nm256_writeAC97Reg (struct ac97_hwint *dev, u8 reg, u16 value)
  695. {
  696.     unsigned long flags;
  697.     int tries = 2;
  698.     int done = 0;
  699.     u32 base;
  700.     struct nm256_info *card = (struct nm256_info *)dev->driver_private;
  701.     if (card->magsig != NM_MAGIC_SIG) {
  702. printk (KERN_ERR "NM256: Bad magic signature in writeAC97Reg!n");
  703. return -EINVAL;
  704.     }
  705.     base = card->mixer;
  706.     save_flags (flags);
  707.     cli ();
  708.     nm256_isReady (dev);
  709.     /* Wait for the write to take, too. */
  710.     while ((tries-- > 0) && !done) {
  711. nm256_writePort16 (card, 2, base + reg, value);
  712. if (nm256_isReady (dev)) {
  713.     done = 1;
  714.     break;
  715. }
  716.     }
  717.     restore_flags (flags);
  718.     udelay (1000);
  719.     return ! done;
  720. }
  721. /* 
  722.  * Initial register values to be written to the AC97 mixer.
  723.  * While most of these are identical to the reset values, we do this
  724.  * so that we have most of the register contents cached--this avoids
  725.  * reading from the mixer directly (which seems to be problematic,
  726.  * probably due to ignorance).
  727.  */
  728. struct initialValues 
  729. {
  730.     unsigned short port;
  731.     unsigned short value;
  732. };
  733. static struct initialValues nm256_ac97_initial_values[] = 
  734. {
  735.     { AC97_MASTER_VOL_STEREO, 0x8000 },
  736.     { AC97_HEADPHONE_VOL,     0x8000 },
  737.     { AC97_MASTER_VOL_MONO,   0x0000 },
  738.     { AC97_PCBEEP_VOL,        0x0000 },
  739.     { AC97_PHONE_VOL,         0x0008 },
  740.     { AC97_MIC_VOL,           0x8000 },
  741.     { AC97_LINEIN_VOL,        0x8808 },
  742.     { AC97_CD_VOL,            0x8808 },
  743.     { AC97_VIDEO_VOL,         0x8808 },
  744.     { AC97_AUX_VOL,           0x8808 },
  745.     { AC97_PCMOUT_VOL,        0x0808 },
  746.     { AC97_RECORD_SELECT,     0x0000 },
  747.     { AC97_RECORD_GAIN,       0x0B0B },
  748.     { AC97_GENERAL_PURPOSE,   0x0000 },
  749.     { 0xffff, 0xffff }
  750. };
  751. /* Initialize the AC97 into a known state.  */
  752. static int
  753. nm256_resetAC97 (struct ac97_hwint *dev)
  754. {
  755.     struct nm256_info *card = (struct nm256_info *)dev->driver_private;
  756.     int x;
  757.     if (card->magsig != NM_MAGIC_SIG) {
  758. printk (KERN_ERR "NM256: Bad magic signature in resetAC97!n");
  759. return -EINVAL;
  760.     }
  761.     /* Reset the mixer.  'Tis magic!  */
  762.     nm256_writePort8 (card, 2, 0x6c0, 1);
  763. //  nm256_writePort8 (card, 2, 0x6cc, 0x87); /* This crashes Dell latitudes */
  764.     nm256_writePort8 (card, 2, 0x6cc, 0x80);
  765.     nm256_writePort8 (card, 2, 0x6cc, 0x0);
  766.     if (! card->mixer_values_init) {
  767. for (x = 0; nm256_ac97_initial_values[x].port != 0xffff; x++) {
  768.     ac97_put_register (dev,
  769.        nm256_ac97_initial_values[x].port,
  770.        nm256_ac97_initial_values[x].value);
  771.     card->mixer_values_init = 1;
  772. }
  773.     }
  774.     return 0;
  775. }
  776. /*
  777.  * We don't do anything particularly special here; it just passes the
  778.  * mixer ioctl to the AC97 driver.
  779.  */
  780. static int
  781. nm256_default_mixer_ioctl (int dev, unsigned int cmd, caddr_t arg)
  782. {
  783.     struct nm256_info *card = nm256_find_card_for_mixer (dev);
  784.     if (card != NULL)
  785. return ac97_mixer_ioctl (&(card->mdev), cmd, arg);
  786.     else
  787. return -ENODEV;
  788. }
  789. static struct mixer_operations nm256_mixer_operations = {
  790.     owner: THIS_MODULE,
  791.     id: "NeoMagic",
  792.     name: "NM256AC97Mixer",
  793.     ioctl: nm256_default_mixer_ioctl
  794. };
  795. /*
  796.  * Default settings for the OSS mixer.  These are set last, after the
  797.  * mixer is initialized.
  798.  *
  799.  * I "love" C sometimes.  Got braces?
  800.  */
  801. static struct ac97_mixer_value_list mixer_defaults[] = {
  802.     { SOUND_MIXER_VOLUME,  { { 85, 85 } } },
  803.     { SOUND_MIXER_SPEAKER, { { 100 } } },
  804.     { SOUND_MIXER_PCM,     { { 65, 65 } } },
  805.     { SOUND_MIXER_CD,      { { 65, 65 } } },
  806.     { -1,                  {  { 0,  0 } } }
  807. };
  808. /* Installs the AC97 mixer into CARD.  */
  809. static int __init
  810. nm256_install_mixer (struct nm256_info *card)
  811. {
  812.     int mixer;
  813.     card->mdev.reset_device = nm256_resetAC97;
  814.     card->mdev.read_reg = nm256_readAC97Reg;
  815.     card->mdev.write_reg = nm256_writeAC97Reg;
  816.     card->mdev.driver_private = (void *)card;
  817.     if (ac97_init (&(card->mdev)))
  818. return -1;
  819.     mixer = sound_alloc_mixerdev();
  820.     if (num_mixers >= MAX_MIXER_DEV) {
  821. printk ("NM256 mixer: Unable to alloc mixerdevn");
  822. return -1;
  823.     }
  824.     mixer_devs[mixer] = &nm256_mixer_operations;
  825.     card->mixer_oss_dev = mixer;
  826.     /* Some reasonable default values.  */
  827.     ac97_set_values (&(card->mdev), mixer_defaults);
  828.     printk(KERN_INFO "Initialized AC97 mixern");
  829.     return 0;
  830. }
  831. /* Perform a full reset on the hardware; this is invoked when an APM
  832.    resume event occurs.  */
  833. static void
  834. nm256_full_reset (struct nm256_info *card)
  835. {
  836.     nm256_initHw (card);
  837.     ac97_reset (&(card->mdev));
  838. }
  839. /* 
  840.  * See if the signature left by the NM256 BIOS is intact; if so, we use
  841.  * the associated address as the end of our audio buffer in the video
  842.  * RAM.
  843.  */
  844. static void __init
  845. nm256_peek_for_sig (struct nm256_info *card)
  846. {
  847.     u32 port1offset 
  848. = card->port[0].physaddr + card->port[0].end_offset - 0x0400;
  849.     /* The signature is located 1K below the end of video RAM.  */
  850.     char *temp = ioremap_nocache (port1offset, 16);
  851.     /* Default buffer end is 5120 bytes below the top of RAM.  */
  852.     u32 default_value = card->port[0].end_offset - 0x1400;
  853.     u32 sig;
  854.     /* Install the default value first, so we don't have to repeatedly
  855.        do it if there is a problem.  */
  856.     card->port[0].end_offset = default_value;
  857.     if (temp == NULL) {
  858. printk (KERN_ERR "NM256: Unable to scan for card signature in video RAMn");
  859. return;
  860.     }
  861.     sig = readl (temp);
  862.     if ((sig & NM_SIG_MASK) == NM_SIGNATURE) {
  863. u32 pointer = readl (temp + 4);
  864. /*
  865.  * If it's obviously invalid, don't use it (the port already has a
  866.  * suitable default value set).
  867.  */
  868. if (pointer != 0xffffffff)
  869.     card->port[0].end_offset = pointer;
  870. printk (KERN_INFO "NM256: Found card signature in video RAM: 0x%xn",
  871. pointer);
  872.     }
  873.     iounmap (temp);
  874. }
  875. /* 
  876.  * Install a driver for the PCI device referenced by PCIDEV.
  877.  * VERSTR is a human-readable version string.
  878.  */
  879. static int __init
  880. nm256_install(struct pci_dev *pcidev, enum nm256rev rev, char *verstr)
  881. {
  882.     struct nm256_info *card;
  883.     struct pm_dev *pmdev;
  884.     int x;
  885.     if (pci_enable_device(pcidev))
  886.     return 0;
  887.     card = kmalloc (sizeof (struct nm256_info), GFP_KERNEL);
  888.     if (card == NULL) {
  889. printk (KERN_ERR "NM256: out of memory!n");
  890. return 0;
  891.     }
  892.     card->magsig = NM_MAGIC_SIG;
  893.     card->playing  = 0;
  894.     card->recording = 0;
  895.     card->rev = rev;
  896.     /* Init the memory port info.  */
  897.     for (x = 0; x < 2; x++) {
  898. card->port[x].physaddr = pci_resource_start (pcidev, x);
  899. card->port[x].ptr = NULL;
  900. card->port[x].start_offset = 0;
  901. card->port[x].end_offset = 0;
  902.     }
  903.     /* Port 2 is easy.  */
  904.     card->port[1].start_offset = 0;
  905.     card->port[1].end_offset = NM_PORT2_SIZE;
  906.     /* Yuck.  But we have to map in port 2 so we can check how much RAM the
  907.        card has.  */
  908.     if (nm256_remap_ports (card)) {
  909. kfree (card);
  910. return 0;
  911.     }
  912.     /* 
  913.      * The NM256 has two memory ports.  The first port is nothing
  914.      * more than a chunk of video RAM, which is used as the I/O ring
  915.      * buffer.  The second port has the actual juicy stuff (like the
  916.      * mixer and the playback engine control registers).
  917.      */
  918.     if (card->rev == REV_NM256AV) {
  919. /* Ok, try to see if this is a non-AC97 version of the hardware. */
  920. int pval = nm256_readPort16 (card, 2, NM_MIXER_PRESENCE);
  921. if ((pval & NM_PRESENCE_MASK) != NM_PRESENCE_VALUE) {
  922.     if (! force_load) {
  923. printk (KERN_ERR "NM256: This doesn't look to me like the AC97-compatible version.n");
  924. printk (KERN_ERR "       You can force the driver to load by passing in the modulen");
  925. printk (KERN_ERR "       parameter:n");
  926. printk (KERN_ERR "              force_ac97 = 1n");
  927. printk (KERN_ERR "n");
  928. printk (KERN_ERR "       More likely, you should be using the appropriate SB-16 orn");
  929. printk (KERN_ERR "       CS4232 driver instead.  (If your BIOS has settings forn");
  930. printk (KERN_ERR "       IRQ and/or DMA for the sound card, this is *not* the correctn");
  931. printk (KERN_ERR "       driver to use.)n");
  932. nm256_release_ports (card);
  933. kfree (card);
  934. return 0;
  935.     }
  936.     else {
  937. printk (KERN_INFO "NM256: Forcing driver load as per user request.n");
  938.     }
  939. }
  940. else {
  941.  /*   printk (KERN_INFO "NM256: Congratulations. You're not running Eunice.n")*/;
  942. }
  943. card->port[0].end_offset = 2560 * 1024;
  944. card->introutine = nm256_interrupt;
  945. card->mixer_status_offset = NM_MIXER_STATUS_OFFSET;
  946. card->mixer_status_mask = NM_MIXER_READY_MASK;
  947.     } 
  948.     else {
  949. /* Not sure if there is any relevant detect for the ZX or not.  */
  950. if (nm256_readPort8 (card, 2, 0xa0b) != 0)
  951.     card->port[0].end_offset = 6144 * 1024;
  952. else
  953.     card->port[0].end_offset = 4096 * 1024;
  954. card->introutine = nm256_interrupt_zx;
  955. card->mixer_status_offset = NM2_MIXER_STATUS_OFFSET;
  956. card->mixer_status_mask = NM2_MIXER_READY_MASK;
  957.     }
  958.     if (buffertop >= 98304 && buffertop < card->port[0].end_offset)
  959. card->port[0].end_offset = buffertop;
  960.     else
  961. nm256_peek_for_sig (card);
  962.     card->port[0].start_offset = card->port[0].end_offset - 98304;
  963.     printk (KERN_INFO "NM256: Mapping port 1 from 0x%x - 0x%xn",
  964.     card->port[0].start_offset, card->port[0].end_offset);
  965.     if (nm256_remap_ports (card)) {
  966. kfree (card);
  967. return 0;
  968.     }
  969.     /* See if we can get the interrupt. */
  970.     card->irq = pcidev->irq;
  971.     card->has_irq = 0;
  972.     if (nm256_grabInterrupt (card) != 0) {
  973. nm256_release_ports (card);
  974. kfree (card);
  975. return 0;
  976.     }
  977.     nm256_releaseInterrupt (card);
  978.     /*
  979.      * Init the board.
  980.      */
  981.     card->playbackBufferSize = 16384;
  982.     card->recordBufferSize = 16384;
  983.     card->coeffBuf = card->port[0].end_offset - NM_MAX_COEFFICIENT;
  984.     card->abuf2 = card->coeffBuf - card->recordBufferSize;
  985.     card->abuf1 = card->abuf2 - card->playbackBufferSize;
  986.     card->allCoeffBuf = card->abuf2 - (NM_TOTAL_COEFF_COUNT * 4);
  987.     /* Fixed setting. */
  988.     card->mixer = NM_MIXER_OFFSET;
  989.     card->mixer_values_init = 0;
  990.     card->is_open_play = 0;
  991.     card->is_open_record = 0;
  992.     card->coeffsCurrent = 0;
  993.     card->opencnt[0] = 0; card->opencnt[1] = 0;
  994.     /* Reasonable default settings, but largely unnecessary. */
  995.     for (x = 0; x < 2; x++) {
  996. card->sinfo[x].bits = 8;
  997. card->sinfo[x].stereo = 0;
  998. card->sinfo[x].samplerate = 8000;
  999.     }
  1000.     nm256_initHw (card);
  1001.     for (x = 0; x < 2; x++) {
  1002. if ((card->dev[x] =
  1003.      sound_install_audiodrv(AUDIO_DRIVER_VERSION,
  1004.     "NM256", &nm256_audio_driver,
  1005.     sizeof(struct audio_driver),
  1006.     DMA_NODMA, AFMT_U8 | AFMT_S16_LE,
  1007.     NULL, -1, -1)) >= 0) {
  1008.     /* 1K minimum buffer size. */
  1009.     audio_devs[card->dev[x]]->min_fragment = 10;
  1010.     /* Maximum of 8K buffer size. */
  1011.     audio_devs[card->dev[x]]->max_fragment = 13;
  1012. }
  1013. else {
  1014.     printk(KERN_ERR "NM256: Too many PCM devices availablen");
  1015.     nm256_release_ports (card);
  1016.     kfree (card);
  1017.     return 0;
  1018. }
  1019.     }
  1020.     pci_set_drvdata(pcidev,card);
  1021.     /* Insert the card in the list.  */
  1022.     card->next_card = nmcard_list;
  1023.     nmcard_list = card;
  1024.     printk(KERN_INFO "Initialized NeoMagic %s audio in PCI native moden",
  1025.    verstr);
  1026.     /* 
  1027.      * And our mixer.  (We should allow support for other mixers, maybe.)
  1028.      */
  1029.     nm256_install_mixer (card);
  1030.     pmdev = pm_register(PM_PCI_DEV, PM_PCI_ID(pcidev), handle_pm_event);
  1031.     if (pmdev)
  1032.         pmdev->data = card;
  1033.     return 1;
  1034. }
  1035. /*
  1036.  * PM event handler, so the card is properly reinitialized after a power
  1037.  * event.
  1038.  */
  1039. static int
  1040. handle_pm_event (struct pm_dev *dev, pm_request_t rqst, void *data)
  1041. {
  1042.     struct nm256_info *crd = (struct nm256_info*) dev->data;
  1043.     if (crd) {
  1044.         switch (rqst) {
  1045. case PM_SUSPEND:
  1046.     break;
  1047. case PM_RESUME:
  1048.             {
  1049.                 int playing = crd->playing;
  1050.                 nm256_full_reset (crd);
  1051.                 /*
  1052.                  * A little ugly, but that's ok; pretend the
  1053.                  * block we were playing is done. 
  1054.                  */
  1055.                 if (playing)
  1056.                     DMAbuf_outputintr (crd->dev_for_play, 1);
  1057.             }
  1058.     break;
  1059. }
  1060.     }
  1061.     return 0;
  1062. }
  1063. static int __devinit
  1064. nm256_probe(struct pci_dev *pcidev,const struct pci_device_id *pciid)
  1065. {
  1066.     if (pcidev->device == PCI_DEVICE_ID_NEOMAGIC_NM256AV_AUDIO)
  1067. return nm256_install(pcidev, REV_NM256AV, "256AV");
  1068.     if (pcidev->device == PCI_DEVICE_ID_NEOMAGIC_NM256ZX_AUDIO)
  1069. return nm256_install(pcidev, REV_NM256ZX, "256ZX");
  1070.     return -1; /* should not come here ... */
  1071. }
  1072. static void __devinit
  1073. nm256_remove(struct pci_dev *pcidev) {
  1074.     struct nm256_info *xcard = pci_get_drvdata(pcidev);
  1075.     struct nm256_info *card,*next_card = NULL;
  1076.     for (card = nmcard_list; card != NULL; card = next_card) {
  1077. next_card = card->next_card;
  1078. if (card == xcard) {
  1079.     stopPlay (card);
  1080.     stopRecord (card);
  1081.     if (card->has_irq)
  1082. free_irq (card->irq, card);
  1083.     nm256_release_ports (card);
  1084.     sound_unload_mixerdev (card->mixer_oss_dev);
  1085.     sound_unload_audiodev (card->dev[0]);
  1086.     sound_unload_audiodev (card->dev[1]);
  1087.     kfree (card);
  1088.     break;
  1089. }
  1090.     }
  1091.     if (nmcard_list == card)
  1092.      nmcard_list = next_card;
  1093. }
  1094. /*
  1095.  * Open the device
  1096.  *
  1097.  * DEV  - device
  1098.  * MODE - mode to open device (logical OR of OPEN_READ and OPEN_WRITE)
  1099.  *
  1100.  * Called when opening the DMAbuf               (dmabuf.c:259)
  1101.  */
  1102. static int
  1103. nm256_audio_open(int dev, int mode)
  1104. {
  1105.     struct nm256_info *card = nm256_find_card (dev);
  1106.     int w;
  1107.     if (card == NULL)
  1108. return -ENODEV;
  1109.     if (card->dev[0] == dev)
  1110. w = 0;
  1111.     else if (card->dev[1] == dev)
  1112. w = 1;
  1113.     else
  1114. return -ENODEV;
  1115.     if (card->opencnt[w] > 0)
  1116. return -EBUSY;
  1117.     /* No bits set? Huh? */
  1118.     if (! ((mode & OPEN_READ) || (mode & OPEN_WRITE)))
  1119. return -EIO;
  1120.     /*
  1121.      * If it's open for both read and write, and the card's currently
  1122.      * being read or written to, then do the opposite of what has
  1123.      * already been done.  Otherwise, don't specify any mode until the
  1124.      * user actually tries to do I/O.  (Some programs open the device
  1125.      * for both read and write, but only actually do reading or writing.)
  1126.      */
  1127.     if ((mode & OPEN_WRITE) && (mode & OPEN_READ)) {
  1128. if (card->is_open_play)
  1129.     mode = OPEN_WRITE;
  1130. else if (card->is_open_record)
  1131.     mode = OPEN_READ;
  1132. else mode = 0;
  1133.     }
  1134.     if (mode & OPEN_WRITE) {
  1135. if (card->is_open_play == 0) {
  1136.     card->dev_for_play = dev;
  1137.     card->is_open_play = 1;
  1138. }
  1139. else
  1140.     return -EBUSY;
  1141.     }
  1142.     if (mode & OPEN_READ) {
  1143. if (card->is_open_record == 0) {
  1144.     card->dev_for_record = dev;
  1145.     card->is_open_record = 1;
  1146. }
  1147. else
  1148.     return -EBUSY;
  1149.     }
  1150.     card->opencnt[w]++;
  1151.     return 0;
  1152. }
  1153. /*
  1154.  * Close the device
  1155.  *
  1156.  * DEV  - device
  1157.  *
  1158.  * Called when closing the DMAbuf               (dmabuf.c:477)
  1159.  *      after halt_xfer
  1160.  */
  1161. static void
  1162. nm256_audio_close(int dev)
  1163. {
  1164.     struct nm256_info *card = nm256_find_card (dev);
  1165.     if (card != NULL) {
  1166. int w;
  1167. if (card->dev[0] == dev)
  1168.     w = 0;
  1169. else if (card->dev[1] == dev)
  1170.     w = 1;
  1171. else
  1172.     return;
  1173. card->opencnt[w]--;
  1174. if (card->opencnt[w] <= 0) {
  1175.     card->opencnt[w] = 0;
  1176.     if (card->dev_for_play == dev) {
  1177. stopPlay (card);
  1178. card->is_open_play = 0;
  1179. card->dev_for_play = -1;
  1180.     }
  1181.     if (card->dev_for_record == dev) {
  1182. stopRecord (card);
  1183. card->is_open_record = 0;
  1184. card->dev_for_record = -1;
  1185.     }
  1186. }
  1187.     }
  1188. }
  1189. /* Standard ioctl handler. */
  1190. static int
  1191. nm256_audio_ioctl(int dev, unsigned int cmd, caddr_t arg)
  1192. {
  1193.     int ret;
  1194.     u32 oldinfo;
  1195.     int w;
  1196.     struct nm256_info *card = nm256_find_card (dev);
  1197.     if (card == NULL)
  1198. return -ENODEV;
  1199.     if (dev == card->dev[0])
  1200. w = 0;
  1201.     else
  1202. w = 1;
  1203.     /* 
  1204.      * The code here is messy.  There are probably better ways to do
  1205.      * it.  (It should be possible to handle it the same way the AC97 mixer 
  1206.      * is done.)
  1207.      */
  1208.     switch (cmd)
  1209. {
  1210. case SOUND_PCM_WRITE_RATE:
  1211.     if (get_user(ret, (int *) arg))
  1212. return -EFAULT;
  1213.     if (ret != 0) {
  1214. oldinfo = card->sinfo[w].samplerate;
  1215. card->sinfo[w].samplerate = ret;
  1216. ret = nm256_setInfo(dev, card);
  1217. if (ret != 0)
  1218.     card->sinfo[w].samplerate = oldinfo;
  1219.     }
  1220.     if (ret == 0)
  1221. ret = card->sinfo[w].samplerate;
  1222.     break;
  1223. case SOUND_PCM_READ_RATE:
  1224.     ret = card->sinfo[w].samplerate;
  1225.     break;
  1226. case SNDCTL_DSP_STEREO:
  1227.     if (get_user(ret, (int *) arg))
  1228. return -EFAULT;
  1229.     card->sinfo[w].stereo = ret ? 1 : 0;
  1230.     ret = nm256_setInfo (dev, card);
  1231.     if (ret == 0)
  1232. ret = card->sinfo[w].stereo;
  1233.     break;
  1234. case SOUND_PCM_WRITE_CHANNELS:
  1235.     if (get_user(ret, (int *) arg))
  1236. return -EFAULT;
  1237.     if (ret < 1 || ret > 3)
  1238. ret = card->sinfo[w].stereo + 1;
  1239.     else {
  1240. card->sinfo[w].stereo = ret - 1;
  1241. ret = nm256_setInfo (dev, card);
  1242. if (ret == 0)
  1243.     ret = card->sinfo[w].stereo + 1;
  1244.     }
  1245.     break;
  1246. case SOUND_PCM_READ_CHANNELS:
  1247.     ret = card->sinfo[w].stereo + 1;
  1248.     break;
  1249. case SNDCTL_DSP_SETFMT:
  1250.     if (get_user(ret, (int *) arg))
  1251. return -EFAULT;
  1252.     if (ret != 0) {
  1253. oldinfo = card->sinfo[w].bits;
  1254. card->sinfo[w].bits = ret;
  1255. ret = nm256_setInfo (dev, card);
  1256. if (ret != 0)
  1257.     card->sinfo[w].bits = oldinfo;
  1258.     }
  1259.     if (ret == 0)
  1260. ret = card->sinfo[w].bits;
  1261.     break;
  1262. case SOUND_PCM_READ_BITS:
  1263.     ret = card->sinfo[w].bits;
  1264.     break;
  1265. default:
  1266.     return -EINVAL;
  1267. }
  1268.     return put_user(ret, (int *) arg);
  1269. }
  1270. /*
  1271.  * Given the sound device DEV and an associated physical buffer PHYSBUF, 
  1272.  * return a pointer to the actual buffer in kernel space. 
  1273.  *
  1274.  * This routine should exist as part of the soundcore routines.
  1275.  */
  1276. static char *
  1277. nm256_getDMAbuffer (int dev, unsigned long physbuf)
  1278. {
  1279.     struct audio_operations *adev = audio_devs[dev];
  1280.     struct dma_buffparms *dmap = adev->dmap_out;
  1281.     char *dma_start =
  1282. (char *)(physbuf - (unsigned long)dmap->raw_buf_phys 
  1283.  + (unsigned long)dmap->raw_buf);
  1284.     return dma_start;
  1285. }
  1286. /*
  1287.  * Output a block to sound device
  1288.  *
  1289.  * dev          - device number
  1290.  * buf          - physical address of buffer
  1291.  * total_count  - total byte count in buffer
  1292.  * intrflag     - set if this has been called from an interrupt 
  1293.  *   (via DMAbuf_outputintr)
  1294.  * restart_dma  - set if engine needs to be re-initialised
  1295.  *
  1296.  * Called when:
  1297.  *  1. Starting output                                  (dmabuf.c:1327)
  1298.  *  2.                                                  (dmabuf.c:1504)
  1299.  *  3. A new buffer needs to be sent to the device      (dmabuf.c:1579)
  1300.  */
  1301. static void
  1302. nm256_audio_output_block(int dev, unsigned long physbuf,
  1303.        int total_count, int intrflag)
  1304. {
  1305.     struct nm256_info *card = nm256_find_card (dev);
  1306.     if (card != NULL) {
  1307. char *dma_buf = nm256_getDMAbuffer (dev, physbuf);
  1308. card->is_open_play = 1;
  1309. card->dev_for_play = dev;
  1310. nm256_write_block (card, dma_buf, total_count);
  1311.     }
  1312. }
  1313. /* Ditto, but do recording instead.  */
  1314. static void
  1315. nm256_audio_start_input(int dev, unsigned long physbuf, int count,
  1316. int intrflag)
  1317. {
  1318.     struct nm256_info *card = nm256_find_card (dev);
  1319.     if (card != NULL) {
  1320. char *dma_buf = nm256_getDMAbuffer (dev, physbuf);
  1321. card->is_open_record = 1;
  1322. card->dev_for_record = dev;
  1323. nm256_startRecording (card, dma_buf, count);
  1324.     }
  1325. }
  1326. /* 
  1327.  * Prepare for inputting samples to DEV. 
  1328.  * Each requested buffer will be BSIZE byes long, with a total of
  1329.  * BCOUNT buffers. 
  1330.  */
  1331. static int
  1332. nm256_audio_prepare_for_input(int dev, int bsize, int bcount)
  1333. {
  1334.     struct nm256_info *card = nm256_find_card (dev);
  1335.     if (card == NULL) 
  1336. return -ENODEV;
  1337.     if (card->is_open_record && card->dev_for_record != dev)
  1338. return -EBUSY;
  1339.     audio_devs[dev]->dmap_in->flags |= DMA_NODMA;
  1340.     return 0;
  1341. }
  1342. /*
  1343.  * Prepare for outputting samples to `dev'
  1344.  *
  1345.  * Each buffer that will be passed will be `bsize' bytes long,
  1346.  * with a total of `bcount' buffers.
  1347.  *
  1348.  * Called when:
  1349.  *  1. A trigger enables audio output                   (dmabuf.c:978)
  1350.  *  2. We get a write buffer without dma_mode setup     (dmabuf.c:1152)
  1351.  *  3. We restart a transfer                            (dmabuf.c:1324)
  1352.  */
  1353. static int
  1354. nm256_audio_prepare_for_output(int dev, int bsize, int bcount)
  1355. {
  1356.     struct nm256_info *card = nm256_find_card (dev);
  1357.     if (card == NULL)
  1358. return -ENODEV;
  1359.     if (card->is_open_play && card->dev_for_play != dev)
  1360. return -EBUSY;
  1361.     audio_devs[dev]->dmap_out->flags |= DMA_NODMA;
  1362.     return 0;
  1363. }
  1364. /* Stop the current operations associated with DEV.  */
  1365. static void
  1366. nm256_audio_reset(int dev)
  1367. {
  1368.     struct nm256_info *card = nm256_find_card (dev);
  1369.     if (card != NULL) {
  1370. if (card->dev_for_play == dev)
  1371.     stopPlay (card);
  1372. if (card->dev_for_record == dev)
  1373.     stopRecord (card);
  1374.     }
  1375. }
  1376. static int
  1377. nm256_audio_local_qlen(int dev)
  1378. {
  1379.     return 0;
  1380. }
  1381. static struct audio_driver nm256_audio_driver =
  1382. {
  1383.     owner: THIS_MODULE,
  1384.     open: nm256_audio_open,
  1385.     close: nm256_audio_close,
  1386.     output_block: nm256_audio_output_block,
  1387.     start_input: nm256_audio_start_input,
  1388.     ioctl: nm256_audio_ioctl,
  1389.     prepare_for_input: nm256_audio_prepare_for_input,
  1390.     prepare_for_output:nm256_audio_prepare_for_output,
  1391.     halt_io: nm256_audio_reset,
  1392.     local_qlen: nm256_audio_local_qlen,
  1393. };
  1394. static struct pci_device_id nm256_pci_tbl[] __devinitdata = {
  1395. {PCI_VENDOR_ID_NEOMAGIC, PCI_DEVICE_ID_NEOMAGIC_NM256AV_AUDIO,
  1396. PCI_ANY_ID, PCI_ANY_ID, 0, 0},
  1397. {PCI_VENDOR_ID_NEOMAGIC, PCI_DEVICE_ID_NEOMAGIC_NM256ZX_AUDIO,
  1398. PCI_ANY_ID, PCI_ANY_ID, 0, 0},
  1399. {0,}
  1400. };
  1401. MODULE_DEVICE_TABLE(pci, nm256_pci_tbl);
  1402. MODULE_LICENSE("GPL");
  1403. struct pci_driver nm256_pci_driver = {
  1404. name:"nm256_audio",
  1405. id_table:nm256_pci_tbl,
  1406. probe:nm256_probe,
  1407. remove:nm256_remove,
  1408. };
  1409. MODULE_PARM (usecache, "i");
  1410. MODULE_PARM (buffertop, "i");
  1411. MODULE_PARM (nm256_debug, "i");
  1412. MODULE_PARM (force_load, "i");
  1413. static int __init do_init_nm256(void)
  1414. {
  1415.     printk (KERN_INFO "NeoMagic 256AV/256ZX audio driver, version 1.1pn");
  1416.     return pci_module_init(&nm256_pci_driver);
  1417. }
  1418. static void __exit cleanup_nm256 (void)
  1419. {
  1420.     pci_unregister_driver(&nm256_pci_driver);
  1421.     pm_unregister_all (&handle_pm_event);
  1422. }
  1423. module_init(do_init_nm256);
  1424. module_exit(cleanup_nm256);
  1425. /*
  1426.  * Local variables:
  1427.  *  c-basic-offset: 4
  1428.  * End:
  1429.  */