esssolo1.c 72 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498
  1. /****************************************************************************/
  2. /*
  3. * esssolo1.c -- ESS Technology Solo1 (ES1946) audio driver.
  4. *
  5. * Copyright (C) 1998-2001, 2003 Thomas Sailer (t.sailer@alumni.ethz.ch)
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20. *
  21. * Module command line parameters:
  22. * none so far
  23. *
  24. * Supported devices:
  25. * /dev/dsp standard /dev/dsp device, (mostly) OSS compatible
  26. * /dev/mixer standard /dev/mixer device, (mostly) OSS compatible
  27. * /dev/midi simple MIDI UART interface, no ioctl
  28. *
  29. * Revision history
  30. * 10.11.1998 0.1 Initial release (without any hardware)
  31. * 22.03.1999 0.2 cinfo.blocks should be reset after GETxPTR ioctl.
  32. * reported by Johan Maes <joma@telindus.be>
  33. * return EAGAIN instead of EBUSY when O_NONBLOCK
  34. * read/write cannot be executed
  35. * 07.04.1999 0.3 implemented the following ioctl's: SOUND_PCM_READ_RATE,
  36. * SOUND_PCM_READ_CHANNELS, SOUND_PCM_READ_BITS;
  37. * Alpha fixes reported by Peter Jones <pjones@redhat.com>
  38. * 15.06.1999 0.4 Fix bad allocation bug.
  39. * Thanks to Deti Fliegl <fliegl@in.tum.de>
  40. * 28.06.1999 0.5 Add pci_set_master
  41. * 12.08.1999 0.6 Fix MIDI UART crashing the driver
  42. * Changed mixer semantics from OSS documented
  43. * behaviour to OSS "code behaviour".
  44. * Recording might actually work now.
  45. * The real DDMA controller address register is at PCI config
  46. * 0x60, while the register at 0x18 is used as a placeholder
  47. * register for BIOS address allocation. This register
  48. * is supposed to be copied into 0x60, according
  49. * to the Solo1 datasheet. When I do that, I can access
  50. * the DDMA registers except the mask bit, which
  51. * is stuck at 1. When I copy the contents of 0x18 +0x10
  52. * to the DDMA base register, everything seems to work.
  53. * The fun part is that the Windows Solo1 driver doesn't
  54. * seem to do these tricks.
  55. * Bugs remaining: plops and clicks when starting/stopping playback
  56. * 31.08.1999 0.7 add spin_lock_init
  57. * replaced current->state = x with set_current_state(x)
  58. * 03.09.1999 0.8 change read semantics for MIDI to match
  59. * OSS more closely; remove possible wakeup race
  60. * 07.10.1999 0.9 Fix initialization; complain if sequencer writes time out
  61. * Revised resource grabbing for the FM synthesizer
  62. * 28.10.1999 0.10 More waitqueue races fixed
  63. * 09.12.1999 0.11 Work around stupid Alpha port issue (virt_to_bus(kmalloc(GFP_DMA)) > 16M)
  64. * Disabling recording on Alpha
  65. * 12.01.2000 0.12 Prevent some ioctl's from returning bad count values on underrun/overrun;
  66. * Tim Janik's BSE (Bedevilled Sound Engine) found this
  67. * Integrated (aka redid 8-)) APM support patch by Zach Brown
  68. * 07.02.2000 0.13 Use pci_alloc_consistent and pci_register_driver
  69. * 19.02.2000 0.14 Use pci_dma_supported to determine if recording should be disabled
  70. * 13.03.2000 0.15 Reintroduce initialization of a couple of PCI config space registers
  71. * 21.11.2000 0.16 Initialize dma buffers in poll, otherwise poll may return a bogus mask
  72. * 12.12.2000 0.17 More dma buffer initializations, patch from
  73. * Tjeerd Mulder <tjeerd.mulder@fujitsu-siemens.com>
  74. * 31.01.2001 0.18 Register/Unregister gameport, original patch from
  75. * Nathaniel Daw <daw@cs.cmu.edu>
  76. * Fix SETTRIGGER non OSS API conformity
  77. * 10.03.2001 provide abs function, prevent picking up a bogus kernel macro
  78. * for abs. Bug report by Andrew Morton <andrewm@uow.edu.au>
  79. * 15.05.2001 pci_enable_device moved, return values in probe cleaned
  80. * up. Marcus Meissner <mm@caldera.de>
  81. * 22.05.2001 0.19 more cleanups, changed PM to PCI 2.4 style, got rid
  82. * of global list of devices, using pci device data.
  83. * Marcus Meissner <mm@caldera.de>
  84. * 03.01.2003 0.20 open_mode fixes from Georg Acher <acher@in.tum.de>
  85. */
  86. /*****************************************************************************/
  87. #include <linux/interrupt.h>
  88. #include <linux/module.h>
  89. #include <linux/string.h>
  90. #include <linux/ioport.h>
  91. #include <linux/sched.h>
  92. #include <linux/delay.h>
  93. #include <linux/sound.h>
  94. #include <linux/slab.h>
  95. #include <linux/soundcard.h>
  96. #include <linux/pci.h>
  97. #include <linux/bitops.h>
  98. #include <linux/init.h>
  99. #include <linux/poll.h>
  100. #include <linux/spinlock.h>
  101. #include <linux/smp_lock.h>
  102. #include <linux/gameport.h>
  103. #include <linux/wait.h>
  104. #include <linux/dma-mapping.h>
  105. #include <asm/io.h>
  106. #include <asm/page.h>
  107. #include <asm/uaccess.h>
  108. #include "dm.h"
  109. /* --------------------------------------------------------------------- */
  110. #undef OSS_DOCUMENTED_MIXER_SEMANTICS
  111. /* --------------------------------------------------------------------- */
  112. #ifndef PCI_VENDOR_ID_ESS
  113. #define PCI_VENDOR_ID_ESS 0x125d
  114. #endif
  115. #ifndef PCI_DEVICE_ID_ESS_SOLO1
  116. #define PCI_DEVICE_ID_ESS_SOLO1 0x1969
  117. #endif
  118. #define SOLO1_MAGIC ((PCI_VENDOR_ID_ESS<<16)|PCI_DEVICE_ID_ESS_SOLO1)
  119. #define DDMABASE_OFFSET 0 /* chip bug workaround kludge */
  120. #define DDMABASE_EXTENT 16
  121. #define IOBASE_EXTENT 16
  122. #define SBBASE_EXTENT 16
  123. #define VCBASE_EXTENT (DDMABASE_EXTENT+DDMABASE_OFFSET)
  124. #define MPUBASE_EXTENT 4
  125. #define GPBASE_EXTENT 4
  126. #define GAMEPORT_EXTENT 4
  127. #define FMSYNTH_EXTENT 4
  128. /* MIDI buffer sizes */
  129. #define MIDIINBUF 256
  130. #define MIDIOUTBUF 256
  131. #define FMODE_MIDI_SHIFT 3
  132. #define FMODE_MIDI_READ (FMODE_READ << FMODE_MIDI_SHIFT)
  133. #define FMODE_MIDI_WRITE (FMODE_WRITE << FMODE_MIDI_SHIFT)
  134. #define FMODE_DMFM 0x10
  135. static struct pci_driver solo1_driver;
  136. /* --------------------------------------------------------------------- */
  137. struct solo1_state {
  138. /* magic */
  139. unsigned int magic;
  140. /* the corresponding pci_dev structure */
  141. struct pci_dev *dev;
  142. /* soundcore stuff */
  143. int dev_audio;
  144. int dev_mixer;
  145. int dev_midi;
  146. int dev_dmfm;
  147. /* hardware resources */
  148. unsigned long iobase, sbbase, vcbase, ddmabase, mpubase; /* long for SPARC */
  149. unsigned int irq;
  150. /* mixer registers */
  151. struct {
  152. unsigned short vol[10];
  153. unsigned int recsrc;
  154. unsigned int modcnt;
  155. unsigned short micpreamp;
  156. } mix;
  157. /* wave stuff */
  158. unsigned fmt;
  159. unsigned channels;
  160. unsigned rate;
  161. unsigned char clkdiv;
  162. unsigned ena;
  163. spinlock_t lock;
  164. struct semaphore open_sem;
  165. mode_t open_mode;
  166. wait_queue_head_t open_wait;
  167. struct dmabuf {
  168. void *rawbuf;
  169. dma_addr_t dmaaddr;
  170. unsigned buforder;
  171. unsigned numfrag;
  172. unsigned fragshift;
  173. unsigned hwptr, swptr;
  174. unsigned total_bytes;
  175. int count;
  176. unsigned error; /* over/underrun */
  177. wait_queue_head_t wait;
  178. /* redundant, but makes calculations easier */
  179. unsigned fragsize;
  180. unsigned dmasize;
  181. unsigned fragsamples;
  182. /* OSS stuff */
  183. unsigned mapped:1;
  184. unsigned ready:1;
  185. unsigned endcleared:1;
  186. unsigned enabled:1;
  187. unsigned ossfragshift;
  188. int ossmaxfrags;
  189. unsigned subdivision;
  190. } dma_dac, dma_adc;
  191. /* midi stuff */
  192. struct {
  193. unsigned ird, iwr, icnt;
  194. unsigned ord, owr, ocnt;
  195. wait_queue_head_t iwait;
  196. wait_queue_head_t owait;
  197. struct timer_list timer;
  198. unsigned char ibuf[MIDIINBUF];
  199. unsigned char obuf[MIDIOUTBUF];
  200. } midi;
  201. struct gameport *gameport;
  202. };
  203. /* --------------------------------------------------------------------- */
  204. static inline void write_seq(struct solo1_state *s, unsigned char data)
  205. {
  206. int i;
  207. unsigned long flags;
  208. /* the local_irq_save stunt is to send the data within the command window */
  209. for (i = 0; i < 0xffff; i++) {
  210. local_irq_save(flags);
  211. if (!(inb(s->sbbase+0xc) & 0x80)) {
  212. outb(data, s->sbbase+0xc);
  213. local_irq_restore(flags);
  214. return;
  215. }
  216. local_irq_restore(flags);
  217. }
  218. printk(KERN_ERR "esssolo1: write_seq timeout\n");
  219. outb(data, s->sbbase+0xc);
  220. }
  221. static inline int read_seq(struct solo1_state *s, unsigned char *data)
  222. {
  223. int i;
  224. if (!data)
  225. return 0;
  226. for (i = 0; i < 0xffff; i++)
  227. if (inb(s->sbbase+0xe) & 0x80) {
  228. *data = inb(s->sbbase+0xa);
  229. return 1;
  230. }
  231. printk(KERN_ERR "esssolo1: read_seq timeout\n");
  232. return 0;
  233. }
  234. static inline int reset_ctrl(struct solo1_state *s)
  235. {
  236. int i;
  237. outb(3, s->sbbase+6); /* clear sequencer and FIFO */
  238. udelay(10);
  239. outb(0, s->sbbase+6);
  240. for (i = 0; i < 0xffff; i++)
  241. if (inb(s->sbbase+0xe) & 0x80)
  242. if (inb(s->sbbase+0xa) == 0xaa) {
  243. write_seq(s, 0xc6); /* enter enhanced mode */
  244. return 1;
  245. }
  246. return 0;
  247. }
  248. static void write_ctrl(struct solo1_state *s, unsigned char reg, unsigned char data)
  249. {
  250. write_seq(s, reg);
  251. write_seq(s, data);
  252. }
  253. #if 0 /* unused */
  254. static unsigned char read_ctrl(struct solo1_state *s, unsigned char reg)
  255. {
  256. unsigned char r;
  257. write_seq(s, 0xc0);
  258. write_seq(s, reg);
  259. read_seq(s, &r);
  260. return r;
  261. }
  262. #endif /* unused */
  263. static void write_mixer(struct solo1_state *s, unsigned char reg, unsigned char data)
  264. {
  265. outb(reg, s->sbbase+4);
  266. outb(data, s->sbbase+5);
  267. }
  268. static unsigned char read_mixer(struct solo1_state *s, unsigned char reg)
  269. {
  270. outb(reg, s->sbbase+4);
  271. return inb(s->sbbase+5);
  272. }
  273. /* --------------------------------------------------------------------- */
  274. static inline unsigned ld2(unsigned int x)
  275. {
  276. unsigned r = 0;
  277. if (x >= 0x10000) {
  278. x >>= 16;
  279. r += 16;
  280. }
  281. if (x >= 0x100) {
  282. x >>= 8;
  283. r += 8;
  284. }
  285. if (x >= 0x10) {
  286. x >>= 4;
  287. r += 4;
  288. }
  289. if (x >= 4) {
  290. x >>= 2;
  291. r += 2;
  292. }
  293. if (x >= 2)
  294. r++;
  295. return r;
  296. }
  297. /* --------------------------------------------------------------------- */
  298. static inline void stop_dac(struct solo1_state *s)
  299. {
  300. unsigned long flags;
  301. spin_lock_irqsave(&s->lock, flags);
  302. s->ena &= ~FMODE_WRITE;
  303. write_mixer(s, 0x78, 0x10);
  304. spin_unlock_irqrestore(&s->lock, flags);
  305. }
  306. static void start_dac(struct solo1_state *s)
  307. {
  308. unsigned long flags;
  309. spin_lock_irqsave(&s->lock, flags);
  310. if (!(s->ena & FMODE_WRITE) && (s->dma_dac.mapped || s->dma_dac.count > 0) && s->dma_dac.ready) {
  311. s->ena |= FMODE_WRITE;
  312. write_mixer(s, 0x78, 0x12);
  313. udelay(10);
  314. write_mixer(s, 0x78, 0x13);
  315. }
  316. spin_unlock_irqrestore(&s->lock, flags);
  317. }
  318. static inline void stop_adc(struct solo1_state *s)
  319. {
  320. unsigned long flags;
  321. spin_lock_irqsave(&s->lock, flags);
  322. s->ena &= ~FMODE_READ;
  323. write_ctrl(s, 0xb8, 0xe);
  324. spin_unlock_irqrestore(&s->lock, flags);
  325. }
  326. static void start_adc(struct solo1_state *s)
  327. {
  328. unsigned long flags;
  329. spin_lock_irqsave(&s->lock, flags);
  330. if (!(s->ena & FMODE_READ) && (s->dma_adc.mapped || s->dma_adc.count < (signed)(s->dma_adc.dmasize - 2*s->dma_adc.fragsize))
  331. && s->dma_adc.ready) {
  332. s->ena |= FMODE_READ;
  333. write_ctrl(s, 0xb8, 0xf);
  334. #if 0
  335. printk(KERN_DEBUG "solo1: DMAbuffer: 0x%08lx\n", (long)s->dma_adc.rawbuf);
  336. printk(KERN_DEBUG "solo1: DMA: mask: 0x%02x cnt: 0x%04x addr: 0x%08x stat: 0x%02x\n",
  337. inb(s->ddmabase+0xf), inw(s->ddmabase+4), inl(s->ddmabase), inb(s->ddmabase+8));
  338. #endif
  339. outb(0, s->ddmabase+0xd); /* master reset */
  340. outb(1, s->ddmabase+0xf); /* mask */
  341. outb(0x54/*0x14*/, s->ddmabase+0xb); /* DMA_MODE_READ | DMA_MODE_AUTOINIT */
  342. outl(virt_to_bus(s->dma_adc.rawbuf), s->ddmabase);
  343. outw(s->dma_adc.dmasize-1, s->ddmabase+4);
  344. outb(0, s->ddmabase+0xf);
  345. }
  346. spin_unlock_irqrestore(&s->lock, flags);
  347. #if 0
  348. printk(KERN_DEBUG "solo1: start DMA: reg B8: 0x%02x SBstat: 0x%02x\n"
  349. KERN_DEBUG "solo1: DMA: stat: 0x%02x cnt: 0x%04x mask: 0x%02x\n",
  350. read_ctrl(s, 0xb8), inb(s->sbbase+0xc),
  351. inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->ddmabase+0xf));
  352. printk(KERN_DEBUG "solo1: A1: 0x%02x A2: 0x%02x A4: 0x%02x A5: 0x%02x A8: 0x%02x\n"
  353. KERN_DEBUG "solo1: B1: 0x%02x B2: 0x%02x B4: 0x%02x B7: 0x%02x B8: 0x%02x B9: 0x%02x\n",
  354. read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8),
  355. read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb4), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8),
  356. read_ctrl(s, 0xb9));
  357. #endif
  358. }
  359. /* --------------------------------------------------------------------- */
  360. #define DMABUF_DEFAULTORDER (15-PAGE_SHIFT)
  361. #define DMABUF_MINORDER 1
  362. static inline void dealloc_dmabuf(struct solo1_state *s, struct dmabuf *db)
  363. {
  364. struct page *page, *pend;
  365. if (db->rawbuf) {
  366. /* undo marking the pages as reserved */
  367. pend = virt_to_page(db->rawbuf + (PAGE_SIZE << db->buforder) - 1);
  368. for (page = virt_to_page(db->rawbuf); page <= pend; page++)
  369. ClearPageReserved(page);
  370. pci_free_consistent(s->dev, PAGE_SIZE << db->buforder, db->rawbuf, db->dmaaddr);
  371. }
  372. db->rawbuf = NULL;
  373. db->mapped = db->ready = 0;
  374. }
  375. static int prog_dmabuf(struct solo1_state *s, struct dmabuf *db)
  376. {
  377. int order;
  378. unsigned bytespersec;
  379. unsigned bufs, sample_shift = 0;
  380. struct page *page, *pend;
  381. db->hwptr = db->swptr = db->total_bytes = db->count = db->error = db->endcleared = 0;
  382. if (!db->rawbuf) {
  383. db->ready = db->mapped = 0;
  384. for (order = DMABUF_DEFAULTORDER; order >= DMABUF_MINORDER; order--)
  385. if ((db->rawbuf = pci_alloc_consistent(s->dev, PAGE_SIZE << order, &db->dmaaddr)))
  386. break;
  387. if (!db->rawbuf)
  388. return -ENOMEM;
  389. db->buforder = order;
  390. /* now mark the pages as reserved; otherwise remap_pfn_range doesn't do what we want */
  391. pend = virt_to_page(db->rawbuf + (PAGE_SIZE << db->buforder) - 1);
  392. for (page = virt_to_page(db->rawbuf); page <= pend; page++)
  393. SetPageReserved(page);
  394. }
  395. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  396. sample_shift++;
  397. if (s->channels > 1)
  398. sample_shift++;
  399. bytespersec = s->rate << sample_shift;
  400. bufs = PAGE_SIZE << db->buforder;
  401. if (db->ossfragshift) {
  402. if ((1000 << db->ossfragshift) < bytespersec)
  403. db->fragshift = ld2(bytespersec/1000);
  404. else
  405. db->fragshift = db->ossfragshift;
  406. } else {
  407. db->fragshift = ld2(bytespersec/100/(db->subdivision ? db->subdivision : 1));
  408. if (db->fragshift < 3)
  409. db->fragshift = 3;
  410. }
  411. db->numfrag = bufs >> db->fragshift;
  412. while (db->numfrag < 4 && db->fragshift > 3) {
  413. db->fragshift--;
  414. db->numfrag = bufs >> db->fragshift;
  415. }
  416. db->fragsize = 1 << db->fragshift;
  417. if (db->ossmaxfrags >= 4 && db->ossmaxfrags < db->numfrag)
  418. db->numfrag = db->ossmaxfrags;
  419. db->fragsamples = db->fragsize >> sample_shift;
  420. db->dmasize = db->numfrag << db->fragshift;
  421. db->enabled = 1;
  422. return 0;
  423. }
  424. static inline int prog_dmabuf_adc(struct solo1_state *s)
  425. {
  426. unsigned long va;
  427. int c;
  428. stop_adc(s);
  429. /* check if PCI implementation supports 24bit busmaster DMA */
  430. if (s->dev->dma_mask > 0xffffff)
  431. return -EIO;
  432. if ((c = prog_dmabuf(s, &s->dma_adc)))
  433. return c;
  434. va = s->dma_adc.dmaaddr;
  435. if ((va & ~((1<<24)-1)))
  436. panic("solo1: buffer above 16M boundary");
  437. outb(0, s->ddmabase+0xd); /* clear */
  438. outb(1, s->ddmabase+0xf); /* mask */
  439. /*outb(0, s->ddmabase+8);*/ /* enable (enable is active low!) */
  440. outb(0x54, s->ddmabase+0xb); /* DMA_MODE_READ | DMA_MODE_AUTOINIT */
  441. outl(va, s->ddmabase);
  442. outw(s->dma_adc.dmasize-1, s->ddmabase+4);
  443. c = - s->dma_adc.fragsamples;
  444. write_ctrl(s, 0xa4, c);
  445. write_ctrl(s, 0xa5, c >> 8);
  446. outb(0, s->ddmabase+0xf);
  447. s->dma_adc.ready = 1;
  448. return 0;
  449. }
  450. static inline int prog_dmabuf_dac(struct solo1_state *s)
  451. {
  452. unsigned long va;
  453. int c;
  454. stop_dac(s);
  455. if ((c = prog_dmabuf(s, &s->dma_dac)))
  456. return c;
  457. memset(s->dma_dac.rawbuf, (s->fmt & (AFMT_U8 | AFMT_U16_LE)) ? 0 : 0x80, s->dma_dac.dmasize); /* almost correct for U16 */
  458. va = s->dma_dac.dmaaddr;
  459. if ((va ^ (va + s->dma_dac.dmasize - 1)) & ~((1<<20)-1))
  460. panic("solo1: buffer crosses 1M boundary");
  461. outl(va, s->iobase);
  462. /* warning: s->dma_dac.dmasize & 0xffff must not be zero! i.e. this limits us to a 32k buffer */
  463. outw(s->dma_dac.dmasize, s->iobase+4);
  464. c = - s->dma_dac.fragsamples;
  465. write_mixer(s, 0x74, c);
  466. write_mixer(s, 0x76, c >> 8);
  467. outb(0xa, s->iobase+6);
  468. s->dma_dac.ready = 1;
  469. return 0;
  470. }
  471. static inline void clear_advance(void *buf, unsigned bsize, unsigned bptr, unsigned len, unsigned char c)
  472. {
  473. if (bptr + len > bsize) {
  474. unsigned x = bsize - bptr;
  475. memset(((char *)buf) + bptr, c, x);
  476. bptr = 0;
  477. len -= x;
  478. }
  479. memset(((char *)buf) + bptr, c, len);
  480. }
  481. /* call with spinlock held! */
  482. static void solo1_update_ptr(struct solo1_state *s)
  483. {
  484. int diff;
  485. unsigned hwptr;
  486. /* update ADC pointer */
  487. if (s->ena & FMODE_READ) {
  488. hwptr = (s->dma_adc.dmasize - 1 - inw(s->ddmabase+4)) % s->dma_adc.dmasize;
  489. diff = (s->dma_adc.dmasize + hwptr - s->dma_adc.hwptr) % s->dma_adc.dmasize;
  490. s->dma_adc.hwptr = hwptr;
  491. s->dma_adc.total_bytes += diff;
  492. s->dma_adc.count += diff;
  493. #if 0
  494. printk(KERN_DEBUG "solo1: rd: hwptr %u swptr %u dmasize %u count %u\n",
  495. s->dma_adc.hwptr, s->dma_adc.swptr, s->dma_adc.dmasize, s->dma_adc.count);
  496. #endif
  497. if (s->dma_adc.mapped) {
  498. if (s->dma_adc.count >= (signed)s->dma_adc.fragsize)
  499. wake_up(&s->dma_adc.wait);
  500. } else {
  501. if (s->dma_adc.count > (signed)(s->dma_adc.dmasize - ((3 * s->dma_adc.fragsize) >> 1))) {
  502. s->ena &= ~FMODE_READ;
  503. write_ctrl(s, 0xb8, 0xe);
  504. s->dma_adc.error++;
  505. }
  506. if (s->dma_adc.count > 0)
  507. wake_up(&s->dma_adc.wait);
  508. }
  509. }
  510. /* update DAC pointer */
  511. if (s->ena & FMODE_WRITE) {
  512. hwptr = (s->dma_dac.dmasize - inw(s->iobase+4)) % s->dma_dac.dmasize;
  513. diff = (s->dma_dac.dmasize + hwptr - s->dma_dac.hwptr) % s->dma_dac.dmasize;
  514. s->dma_dac.hwptr = hwptr;
  515. s->dma_dac.total_bytes += diff;
  516. #if 0
  517. printk(KERN_DEBUG "solo1: wr: hwptr %u swptr %u dmasize %u count %u\n",
  518. s->dma_dac.hwptr, s->dma_dac.swptr, s->dma_dac.dmasize, s->dma_dac.count);
  519. #endif
  520. if (s->dma_dac.mapped) {
  521. s->dma_dac.count += diff;
  522. if (s->dma_dac.count >= (signed)s->dma_dac.fragsize)
  523. wake_up(&s->dma_dac.wait);
  524. } else {
  525. s->dma_dac.count -= diff;
  526. if (s->dma_dac.count <= 0) {
  527. s->ena &= ~FMODE_WRITE;
  528. write_mixer(s, 0x78, 0x12);
  529. s->dma_dac.error++;
  530. } else if (s->dma_dac.count <= (signed)s->dma_dac.fragsize && !s->dma_dac.endcleared) {
  531. clear_advance(s->dma_dac.rawbuf, s->dma_dac.dmasize, s->dma_dac.swptr,
  532. s->dma_dac.fragsize, (s->fmt & (AFMT_U8 | AFMT_U16_LE)) ? 0 : 0x80);
  533. s->dma_dac.endcleared = 1;
  534. }
  535. if (s->dma_dac.count < (signed)s->dma_dac.dmasize)
  536. wake_up(&s->dma_dac.wait);
  537. }
  538. }
  539. }
  540. /* --------------------------------------------------------------------- */
  541. static void prog_codec(struct solo1_state *s)
  542. {
  543. unsigned long flags;
  544. int fdiv, filter;
  545. unsigned char c;
  546. reset_ctrl(s);
  547. write_seq(s, 0xd3);
  548. /* program sampling rates */
  549. filter = s->rate * 9 / 20; /* Set filter roll-off to 90% of rate/2 */
  550. fdiv = 256 - 7160000 / (filter * 82);
  551. spin_lock_irqsave(&s->lock, flags);
  552. write_ctrl(s, 0xa1, s->clkdiv);
  553. write_ctrl(s, 0xa2, fdiv);
  554. write_mixer(s, 0x70, s->clkdiv);
  555. write_mixer(s, 0x72, fdiv);
  556. /* program ADC parameters */
  557. write_ctrl(s, 0xb8, 0xe);
  558. write_ctrl(s, 0xb9, /*0x1*/0);
  559. write_ctrl(s, 0xa8, (s->channels > 1) ? 0x11 : 0x12);
  560. c = 0xd0;
  561. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  562. c |= 0x04;
  563. if (s->fmt & (AFMT_S16_LE | AFMT_S8))
  564. c |= 0x20;
  565. if (s->channels > 1)
  566. c ^= 0x48;
  567. write_ctrl(s, 0xb7, (c & 0x70) | 1);
  568. write_ctrl(s, 0xb7, c);
  569. write_ctrl(s, 0xb1, 0x50);
  570. write_ctrl(s, 0xb2, 0x50);
  571. /* program DAC parameters */
  572. c = 0x40;
  573. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  574. c |= 1;
  575. if (s->fmt & (AFMT_S16_LE | AFMT_S8))
  576. c |= 4;
  577. if (s->channels > 1)
  578. c |= 2;
  579. write_mixer(s, 0x7a, c);
  580. write_mixer(s, 0x78, 0x10);
  581. s->ena = 0;
  582. spin_unlock_irqrestore(&s->lock, flags);
  583. }
  584. /* --------------------------------------------------------------------- */
  585. static const char invalid_magic[] = KERN_CRIT "solo1: invalid magic value\n";
  586. #define VALIDATE_STATE(s) \
  587. ({ \
  588. if (!(s) || (s)->magic != SOLO1_MAGIC) { \
  589. printk(invalid_magic); \
  590. return -ENXIO; \
  591. } \
  592. })
  593. /* --------------------------------------------------------------------- */
  594. static int mixer_ioctl(struct solo1_state *s, unsigned int cmd, unsigned long arg)
  595. {
  596. static const unsigned int mixer_src[8] = {
  597. SOUND_MASK_MIC, SOUND_MASK_MIC, SOUND_MASK_CD, SOUND_MASK_VOLUME,
  598. SOUND_MASK_MIC, 0, SOUND_MASK_LINE, 0
  599. };
  600. static const unsigned char mixtable1[SOUND_MIXER_NRDEVICES] = {
  601. [SOUND_MIXER_PCM] = 1, /* voice */
  602. [SOUND_MIXER_SYNTH] = 2, /* FM */
  603. [SOUND_MIXER_CD] = 3, /* CD */
  604. [SOUND_MIXER_LINE] = 4, /* Line */
  605. [SOUND_MIXER_LINE1] = 5, /* AUX */
  606. [SOUND_MIXER_MIC] = 6, /* Mic */
  607. [SOUND_MIXER_LINE2] = 7, /* Mono in */
  608. [SOUND_MIXER_SPEAKER] = 8, /* Speaker */
  609. [SOUND_MIXER_RECLEV] = 9, /* Recording level */
  610. [SOUND_MIXER_VOLUME] = 10 /* Master Volume */
  611. };
  612. static const unsigned char mixreg[] = {
  613. 0x7c, /* voice */
  614. 0x36, /* FM */
  615. 0x38, /* CD */
  616. 0x3e, /* Line */
  617. 0x3a, /* AUX */
  618. 0x1a, /* Mic */
  619. 0x6d /* Mono in */
  620. };
  621. unsigned char l, r, rl, rr, vidx;
  622. int i, val;
  623. int __user *p = (int __user *)arg;
  624. VALIDATE_STATE(s);
  625. if (cmd == SOUND_MIXER_PRIVATE1) {
  626. /* enable/disable/query mixer preamp */
  627. if (get_user(val, p))
  628. return -EFAULT;
  629. if (val != -1) {
  630. val = val ? 0xff : 0xf7;
  631. write_mixer(s, 0x7d, (read_mixer(s, 0x7d) | 0x08) & val);
  632. }
  633. val = (read_mixer(s, 0x7d) & 0x08) ? 1 : 0;
  634. return put_user(val, p);
  635. }
  636. if (cmd == SOUND_MIXER_PRIVATE2) {
  637. /* enable/disable/query spatializer */
  638. if (get_user(val, p))
  639. return -EFAULT;
  640. if (val != -1) {
  641. val &= 0x3f;
  642. write_mixer(s, 0x52, val);
  643. write_mixer(s, 0x50, val ? 0x08 : 0);
  644. }
  645. return put_user(read_mixer(s, 0x52), p);
  646. }
  647. if (cmd == SOUND_MIXER_INFO) {
  648. mixer_info info;
  649. strncpy(info.id, "Solo1", sizeof(info.id));
  650. strncpy(info.name, "ESS Solo1", sizeof(info.name));
  651. info.modify_counter = s->mix.modcnt;
  652. if (copy_to_user((void __user *)arg, &info, sizeof(info)))
  653. return -EFAULT;
  654. return 0;
  655. }
  656. if (cmd == SOUND_OLD_MIXER_INFO) {
  657. _old_mixer_info info;
  658. strncpy(info.id, "Solo1", sizeof(info.id));
  659. strncpy(info.name, "ESS Solo1", sizeof(info.name));
  660. if (copy_to_user((void __user *)arg, &info, sizeof(info)))
  661. return -EFAULT;
  662. return 0;
  663. }
  664. if (cmd == OSS_GETVERSION)
  665. return put_user(SOUND_VERSION, p);
  666. if (_IOC_TYPE(cmd) != 'M' || _SIOC_SIZE(cmd) != sizeof(int))
  667. return -EINVAL;
  668. if (_SIOC_DIR(cmd) == _SIOC_READ) {
  669. switch (_IOC_NR(cmd)) {
  670. case SOUND_MIXER_RECSRC: /* Arg contains a bit for each recording source */
  671. return put_user(mixer_src[read_mixer(s, 0x1c) & 7], p);
  672. case SOUND_MIXER_DEVMASK: /* Arg contains a bit for each supported device */
  673. return put_user(SOUND_MASK_PCM | SOUND_MASK_SYNTH | SOUND_MASK_CD |
  674. SOUND_MASK_LINE | SOUND_MASK_LINE1 | SOUND_MASK_MIC |
  675. SOUND_MASK_VOLUME | SOUND_MASK_LINE2 | SOUND_MASK_RECLEV |
  676. SOUND_MASK_SPEAKER, p);
  677. case SOUND_MIXER_RECMASK: /* Arg contains a bit for each supported recording source */
  678. return put_user(SOUND_MASK_LINE | SOUND_MASK_MIC | SOUND_MASK_CD | SOUND_MASK_VOLUME, p);
  679. case SOUND_MIXER_STEREODEVS: /* Mixer channels supporting stereo */
  680. return put_user(SOUND_MASK_PCM | SOUND_MASK_SYNTH | SOUND_MASK_CD |
  681. SOUND_MASK_LINE | SOUND_MASK_LINE1 | SOUND_MASK_MIC |
  682. SOUND_MASK_VOLUME | SOUND_MASK_LINE2 | SOUND_MASK_RECLEV, p);
  683. case SOUND_MIXER_CAPS:
  684. return put_user(SOUND_CAP_EXCL_INPUT, p);
  685. default:
  686. i = _IOC_NR(cmd);
  687. if (i >= SOUND_MIXER_NRDEVICES || !(vidx = mixtable1[i]))
  688. return -EINVAL;
  689. return put_user(s->mix.vol[vidx-1], p);
  690. }
  691. }
  692. if (_SIOC_DIR(cmd) != (_SIOC_READ|_SIOC_WRITE))
  693. return -EINVAL;
  694. s->mix.modcnt++;
  695. switch (_IOC_NR(cmd)) {
  696. case SOUND_MIXER_RECSRC: /* Arg contains a bit for each recording source */
  697. #if 0
  698. {
  699. static const unsigned char regs[] = {
  700. 0x1c, 0x1a, 0x36, 0x38, 0x3a, 0x3c, 0x3e, 0x60, 0x62, 0x6d, 0x7c
  701. };
  702. int i;
  703. for (i = 0; i < sizeof(regs); i++)
  704. printk(KERN_DEBUG "solo1: mixer reg 0x%02x: 0x%02x\n",
  705. regs[i], read_mixer(s, regs[i]));
  706. printk(KERN_DEBUG "solo1: ctrl reg 0x%02x: 0x%02x\n",
  707. 0xb4, read_ctrl(s, 0xb4));
  708. }
  709. #endif
  710. if (get_user(val, p))
  711. return -EFAULT;
  712. i = hweight32(val);
  713. if (i == 0)
  714. return 0;
  715. else if (i > 1)
  716. val &= ~mixer_src[read_mixer(s, 0x1c) & 7];
  717. for (i = 0; i < 8; i++) {
  718. if (mixer_src[i] & val)
  719. break;
  720. }
  721. if (i > 7)
  722. return 0;
  723. write_mixer(s, 0x1c, i);
  724. return 0;
  725. case SOUND_MIXER_VOLUME:
  726. if (get_user(val, p))
  727. return -EFAULT;
  728. l = val & 0xff;
  729. if (l > 100)
  730. l = 100;
  731. r = (val >> 8) & 0xff;
  732. if (r > 100)
  733. r = 100;
  734. if (l < 6) {
  735. rl = 0x40;
  736. l = 0;
  737. } else {
  738. rl = (l * 2 - 11) / 3;
  739. l = (rl * 3 + 11) / 2;
  740. }
  741. if (r < 6) {
  742. rr = 0x40;
  743. r = 0;
  744. } else {
  745. rr = (r * 2 - 11) / 3;
  746. r = (rr * 3 + 11) / 2;
  747. }
  748. write_mixer(s, 0x60, rl);
  749. write_mixer(s, 0x62, rr);
  750. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  751. s->mix.vol[9] = ((unsigned int)r << 8) | l;
  752. #else
  753. s->mix.vol[9] = val;
  754. #endif
  755. return put_user(s->mix.vol[9], p);
  756. case SOUND_MIXER_SPEAKER:
  757. if (get_user(val, p))
  758. return -EFAULT;
  759. l = val & 0xff;
  760. if (l > 100)
  761. l = 100;
  762. else if (l < 2)
  763. l = 2;
  764. rl = (l - 2) / 14;
  765. l = rl * 14 + 2;
  766. write_mixer(s, 0x3c, rl);
  767. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  768. s->mix.vol[7] = l * 0x101;
  769. #else
  770. s->mix.vol[7] = val;
  771. #endif
  772. return put_user(s->mix.vol[7], p);
  773. case SOUND_MIXER_RECLEV:
  774. if (get_user(val, p))
  775. return -EFAULT;
  776. l = (val << 1) & 0x1fe;
  777. if (l > 200)
  778. l = 200;
  779. else if (l < 5)
  780. l = 5;
  781. r = (val >> 7) & 0x1fe;
  782. if (r > 200)
  783. r = 200;
  784. else if (r < 5)
  785. r = 5;
  786. rl = (l - 5) / 13;
  787. rr = (r - 5) / 13;
  788. r = (rl * 13 + 5) / 2;
  789. l = (rr * 13 + 5) / 2;
  790. write_ctrl(s, 0xb4, (rl << 4) | rr);
  791. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  792. s->mix.vol[8] = ((unsigned int)r << 8) | l;
  793. #else
  794. s->mix.vol[8] = val;
  795. #endif
  796. return put_user(s->mix.vol[8], p);
  797. default:
  798. i = _IOC_NR(cmd);
  799. if (i >= SOUND_MIXER_NRDEVICES || !(vidx = mixtable1[i]))
  800. return -EINVAL;
  801. if (get_user(val, p))
  802. return -EFAULT;
  803. l = (val << 1) & 0x1fe;
  804. if (l > 200)
  805. l = 200;
  806. else if (l < 5)
  807. l = 5;
  808. r = (val >> 7) & 0x1fe;
  809. if (r > 200)
  810. r = 200;
  811. else if (r < 5)
  812. r = 5;
  813. rl = (l - 5) / 13;
  814. rr = (r - 5) / 13;
  815. r = (rl * 13 + 5) / 2;
  816. l = (rr * 13 + 5) / 2;
  817. write_mixer(s, mixreg[vidx-1], (rl << 4) | rr);
  818. #ifdef OSS_DOCUMENTED_MIXER_SEMANTICS
  819. s->mix.vol[vidx-1] = ((unsigned int)r << 8) | l;
  820. #else
  821. s->mix.vol[vidx-1] = val;
  822. #endif
  823. return put_user(s->mix.vol[vidx-1], p);
  824. }
  825. }
  826. /* --------------------------------------------------------------------- */
  827. static int solo1_open_mixdev(struct inode *inode, struct file *file)
  828. {
  829. unsigned int minor = iminor(inode);
  830. struct solo1_state *s = NULL;
  831. struct pci_dev *pci_dev = NULL;
  832. while ((pci_dev = pci_find_device(PCI_ANY_ID, PCI_ANY_ID, pci_dev)) != NULL) {
  833. struct pci_driver *drvr;
  834. drvr = pci_dev_driver (pci_dev);
  835. if (drvr != &solo1_driver)
  836. continue;
  837. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  838. if (!s)
  839. continue;
  840. if (s->dev_mixer == minor)
  841. break;
  842. }
  843. if (!s)
  844. return -ENODEV;
  845. VALIDATE_STATE(s);
  846. file->private_data = s;
  847. return nonseekable_open(inode, file);
  848. }
  849. static int solo1_release_mixdev(struct inode *inode, struct file *file)
  850. {
  851. struct solo1_state *s = (struct solo1_state *)file->private_data;
  852. VALIDATE_STATE(s);
  853. return 0;
  854. }
  855. static int solo1_ioctl_mixdev(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  856. {
  857. return mixer_ioctl((struct solo1_state *)file->private_data, cmd, arg);
  858. }
  859. static /*const*/ struct file_operations solo1_mixer_fops = {
  860. .owner = THIS_MODULE,
  861. .llseek = no_llseek,
  862. .ioctl = solo1_ioctl_mixdev,
  863. .open = solo1_open_mixdev,
  864. .release = solo1_release_mixdev,
  865. };
  866. /* --------------------------------------------------------------------- */
  867. static int drain_dac(struct solo1_state *s, int nonblock)
  868. {
  869. DECLARE_WAITQUEUE(wait, current);
  870. unsigned long flags;
  871. int count;
  872. unsigned tmo;
  873. if (s->dma_dac.mapped)
  874. return 0;
  875. add_wait_queue(&s->dma_dac.wait, &wait);
  876. for (;;) {
  877. set_current_state(TASK_INTERRUPTIBLE);
  878. spin_lock_irqsave(&s->lock, flags);
  879. count = s->dma_dac.count;
  880. spin_unlock_irqrestore(&s->lock, flags);
  881. if (count <= 0)
  882. break;
  883. if (signal_pending(current))
  884. break;
  885. if (nonblock) {
  886. remove_wait_queue(&s->dma_dac.wait, &wait);
  887. set_current_state(TASK_RUNNING);
  888. return -EBUSY;
  889. }
  890. tmo = 3 * HZ * (count + s->dma_dac.fragsize) / 2 / s->rate;
  891. if (s->fmt & (AFMT_S16_LE | AFMT_U16_LE))
  892. tmo >>= 1;
  893. if (s->channels > 1)
  894. tmo >>= 1;
  895. if (!schedule_timeout(tmo + 1))
  896. printk(KERN_DEBUG "solo1: dma timed out??\n");
  897. }
  898. remove_wait_queue(&s->dma_dac.wait, &wait);
  899. set_current_state(TASK_RUNNING);
  900. if (signal_pending(current))
  901. return -ERESTARTSYS;
  902. return 0;
  903. }
  904. /* --------------------------------------------------------------------- */
  905. static ssize_t solo1_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos)
  906. {
  907. struct solo1_state *s = (struct solo1_state *)file->private_data;
  908. DECLARE_WAITQUEUE(wait, current);
  909. ssize_t ret;
  910. unsigned long flags;
  911. unsigned swptr;
  912. int cnt;
  913. VALIDATE_STATE(s);
  914. if (s->dma_adc.mapped)
  915. return -ENXIO;
  916. if (!s->dma_adc.ready && (ret = prog_dmabuf_adc(s)))
  917. return ret;
  918. if (!access_ok(VERIFY_WRITE, buffer, count))
  919. return -EFAULT;
  920. ret = 0;
  921. add_wait_queue(&s->dma_adc.wait, &wait);
  922. while (count > 0) {
  923. spin_lock_irqsave(&s->lock, flags);
  924. swptr = s->dma_adc.swptr;
  925. cnt = s->dma_adc.dmasize-swptr;
  926. if (s->dma_adc.count < cnt)
  927. cnt = s->dma_adc.count;
  928. if (cnt <= 0)
  929. __set_current_state(TASK_INTERRUPTIBLE);
  930. spin_unlock_irqrestore(&s->lock, flags);
  931. if (cnt > count)
  932. cnt = count;
  933. #ifdef DEBUGREC
  934. printk(KERN_DEBUG "solo1_read: reg B8: 0x%02x DMAstat: 0x%02x DMAcnt: 0x%04x SBstat: 0x%02x cnt: %u\n",
  935. read_ctrl(s, 0xb8), inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->sbbase+0xc), cnt);
  936. #endif
  937. if (cnt <= 0) {
  938. if (s->dma_adc.enabled)
  939. start_adc(s);
  940. #ifdef DEBUGREC
  941. printk(KERN_DEBUG "solo1_read: regs: A1: 0x%02x A2: 0x%02x A4: 0x%02x A5: 0x%02x A8: 0x%02x\n"
  942. KERN_DEBUG "solo1_read: regs: B1: 0x%02x B2: 0x%02x B7: 0x%02x B8: 0x%02x B9: 0x%02x\n"
  943. KERN_DEBUG "solo1_read: DMA: addr: 0x%08x cnt: 0x%04x stat: 0x%02x mask: 0x%02x\n"
  944. KERN_DEBUG "solo1_read: SBstat: 0x%02x cnt: %u\n",
  945. read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8),
  946. read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8), read_ctrl(s, 0xb9),
  947. inl(s->ddmabase), inw(s->ddmabase+4), inb(s->ddmabase+8), inb(s->ddmabase+15), inb(s->sbbase+0xc), cnt);
  948. #endif
  949. if (inb(s->ddmabase+15) & 1)
  950. printk(KERN_ERR "solo1: cannot start recording, DDMA mask bit stuck at 1\n");
  951. if (file->f_flags & O_NONBLOCK) {
  952. if (!ret)
  953. ret = -EAGAIN;
  954. break;
  955. }
  956. schedule();
  957. #ifdef DEBUGREC
  958. printk(KERN_DEBUG "solo1_read: regs: A1: 0x%02x A2: 0x%02x A4: 0x%02x A5: 0x%02x A8: 0x%02x\n"
  959. KERN_DEBUG "solo1_read: regs: B1: 0x%02x B2: 0x%02x B7: 0x%02x B8: 0x%02x B9: 0x%02x\n"
  960. KERN_DEBUG "solo1_read: DMA: addr: 0x%08x cnt: 0x%04x stat: 0x%02x mask: 0x%02x\n"
  961. KERN_DEBUG "solo1_read: SBstat: 0x%02x cnt: %u\n",
  962. read_ctrl(s, 0xa1), read_ctrl(s, 0xa2), read_ctrl(s, 0xa4), read_ctrl(s, 0xa5), read_ctrl(s, 0xa8),
  963. read_ctrl(s, 0xb1), read_ctrl(s, 0xb2), read_ctrl(s, 0xb7), read_ctrl(s, 0xb8), read_ctrl(s, 0xb9),
  964. inl(s->ddmabase), inw(s->ddmabase+4), inb(s->ddmabase+8), inb(s->ddmabase+15), inb(s->sbbase+0xc), cnt);
  965. #endif
  966. if (signal_pending(current)) {
  967. if (!ret)
  968. ret = -ERESTARTSYS;
  969. break;
  970. }
  971. continue;
  972. }
  973. if (copy_to_user(buffer, s->dma_adc.rawbuf + swptr, cnt)) {
  974. if (!ret)
  975. ret = -EFAULT;
  976. break;
  977. }
  978. swptr = (swptr + cnt) % s->dma_adc.dmasize;
  979. spin_lock_irqsave(&s->lock, flags);
  980. s->dma_adc.swptr = swptr;
  981. s->dma_adc.count -= cnt;
  982. spin_unlock_irqrestore(&s->lock, flags);
  983. count -= cnt;
  984. buffer += cnt;
  985. ret += cnt;
  986. if (s->dma_adc.enabled)
  987. start_adc(s);
  988. #ifdef DEBUGREC
  989. printk(KERN_DEBUG "solo1_read: reg B8: 0x%02x DMAstat: 0x%02x DMAcnt: 0x%04x SBstat: 0x%02x\n",
  990. read_ctrl(s, 0xb8), inb(s->ddmabase+8), inw(s->ddmabase+4), inb(s->sbbase+0xc));
  991. #endif
  992. }
  993. remove_wait_queue(&s->dma_adc.wait, &wait);
  994. set_current_state(TASK_RUNNING);
  995. return ret;
  996. }
  997. static ssize_t solo1_write(struct file *file, const char __user *buffer, size_t count, loff_t *ppos)
  998. {
  999. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1000. DECLARE_WAITQUEUE(wait, current);
  1001. ssize_t ret;
  1002. unsigned long flags;
  1003. unsigned swptr;
  1004. int cnt;
  1005. VALIDATE_STATE(s);
  1006. if (s->dma_dac.mapped)
  1007. return -ENXIO;
  1008. if (!s->dma_dac.ready && (ret = prog_dmabuf_dac(s)))
  1009. return ret;
  1010. if (!access_ok(VERIFY_READ, buffer, count))
  1011. return -EFAULT;
  1012. #if 0
  1013. printk(KERN_DEBUG "solo1_write: reg 70: 0x%02x 71: 0x%02x 72: 0x%02x 74: 0x%02x 76: 0x%02x 78: 0x%02x 7A: 0x%02x\n"
  1014. KERN_DEBUG "solo1_write: DMA: addr: 0x%08x cnt: 0x%04x stat: 0x%02x SBstat: 0x%02x\n",
  1015. read_mixer(s, 0x70), read_mixer(s, 0x71), read_mixer(s, 0x72), read_mixer(s, 0x74), read_mixer(s, 0x76),
  1016. read_mixer(s, 0x78), read_mixer(s, 0x7a), inl(s->iobase), inw(s->iobase+4), inb(s->iobase+6), inb(s->sbbase+0xc));
  1017. printk(KERN_DEBUG "solo1_write: reg 78: 0x%02x reg 7A: 0x%02x DMAcnt: 0x%04x DMAstat: 0x%02x SBstat: 0x%02x\n",
  1018. read_mixer(s, 0x78), read_mixer(s, 0x7a), inw(s->iobase+4), inb(s->iobase+6), inb(s->sbbase+0xc));
  1019. #endif
  1020. ret = 0;
  1021. add_wait_queue(&s->dma_dac.wait, &wait);
  1022. while (count > 0) {
  1023. spin_lock_irqsave(&s->lock, flags);
  1024. if (s->dma_dac.count < 0) {
  1025. s->dma_dac.count = 0;
  1026. s->dma_dac.swptr = s->dma_dac.hwptr;
  1027. }
  1028. swptr = s->dma_dac.swptr;
  1029. cnt = s->dma_dac.dmasize-swptr;
  1030. if (s->dma_dac.count + cnt > s->dma_dac.dmasize)
  1031. cnt = s->dma_dac.dmasize - s->dma_dac.count;
  1032. if (cnt <= 0)
  1033. __set_current_state(TASK_INTERRUPTIBLE);
  1034. spin_unlock_irqrestore(&s->lock, flags);
  1035. if (cnt > count)
  1036. cnt = count;
  1037. if (cnt <= 0) {
  1038. if (s->dma_dac.enabled)
  1039. start_dac(s);
  1040. if (file->f_flags & O_NONBLOCK) {
  1041. if (!ret)
  1042. ret = -EAGAIN;
  1043. break;
  1044. }
  1045. schedule();
  1046. if (signal_pending(current)) {
  1047. if (!ret)
  1048. ret = -ERESTARTSYS;
  1049. break;
  1050. }
  1051. continue;
  1052. }
  1053. if (copy_from_user(s->dma_dac.rawbuf + swptr, buffer, cnt)) {
  1054. if (!ret)
  1055. ret = -EFAULT;
  1056. break;
  1057. }
  1058. swptr = (swptr + cnt) % s->dma_dac.dmasize;
  1059. spin_lock_irqsave(&s->lock, flags);
  1060. s->dma_dac.swptr = swptr;
  1061. s->dma_dac.count += cnt;
  1062. s->dma_dac.endcleared = 0;
  1063. spin_unlock_irqrestore(&s->lock, flags);
  1064. count -= cnt;
  1065. buffer += cnt;
  1066. ret += cnt;
  1067. if (s->dma_dac.enabled)
  1068. start_dac(s);
  1069. }
  1070. remove_wait_queue(&s->dma_dac.wait, &wait);
  1071. set_current_state(TASK_RUNNING);
  1072. return ret;
  1073. }
  1074. /* No kernel lock - we have our own spinlock */
  1075. static unsigned int solo1_poll(struct file *file, struct poll_table_struct *wait)
  1076. {
  1077. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1078. unsigned long flags;
  1079. unsigned int mask = 0;
  1080. VALIDATE_STATE(s);
  1081. if (file->f_mode & FMODE_WRITE) {
  1082. if (!s->dma_dac.ready && prog_dmabuf_dac(s))
  1083. return 0;
  1084. poll_wait(file, &s->dma_dac.wait, wait);
  1085. }
  1086. if (file->f_mode & FMODE_READ) {
  1087. if (!s->dma_adc.ready && prog_dmabuf_adc(s))
  1088. return 0;
  1089. poll_wait(file, &s->dma_adc.wait, wait);
  1090. }
  1091. spin_lock_irqsave(&s->lock, flags);
  1092. solo1_update_ptr(s);
  1093. if (file->f_mode & FMODE_READ) {
  1094. if (s->dma_adc.mapped) {
  1095. if (s->dma_adc.count >= (signed)s->dma_adc.fragsize)
  1096. mask |= POLLIN | POLLRDNORM;
  1097. } else {
  1098. if (s->dma_adc.count > 0)
  1099. mask |= POLLIN | POLLRDNORM;
  1100. }
  1101. }
  1102. if (file->f_mode & FMODE_WRITE) {
  1103. if (s->dma_dac.mapped) {
  1104. if (s->dma_dac.count >= (signed)s->dma_dac.fragsize)
  1105. mask |= POLLOUT | POLLWRNORM;
  1106. } else {
  1107. if ((signed)s->dma_dac.dmasize > s->dma_dac.count)
  1108. mask |= POLLOUT | POLLWRNORM;
  1109. }
  1110. }
  1111. spin_unlock_irqrestore(&s->lock, flags);
  1112. return mask;
  1113. }
  1114. static int solo1_mmap(struct file *file, struct vm_area_struct *vma)
  1115. {
  1116. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1117. struct dmabuf *db;
  1118. int ret = -EINVAL;
  1119. unsigned long size;
  1120. VALIDATE_STATE(s);
  1121. lock_kernel();
  1122. if (vma->vm_flags & VM_WRITE) {
  1123. if ((ret = prog_dmabuf_dac(s)) != 0)
  1124. goto out;
  1125. db = &s->dma_dac;
  1126. } else if (vma->vm_flags & VM_READ) {
  1127. if ((ret = prog_dmabuf_adc(s)) != 0)
  1128. goto out;
  1129. db = &s->dma_adc;
  1130. } else
  1131. goto out;
  1132. ret = -EINVAL;
  1133. if (vma->vm_pgoff != 0)
  1134. goto out;
  1135. size = vma->vm_end - vma->vm_start;
  1136. if (size > (PAGE_SIZE << db->buforder))
  1137. goto out;
  1138. ret = -EAGAIN;
  1139. if (remap_pfn_range(vma, vma->vm_start,
  1140. virt_to_phys(db->rawbuf) >> PAGE_SHIFT,
  1141. size, vma->vm_page_prot))
  1142. goto out;
  1143. db->mapped = 1;
  1144. ret = 0;
  1145. out:
  1146. unlock_kernel();
  1147. return ret;
  1148. }
  1149. static int solo1_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  1150. {
  1151. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1152. unsigned long flags;
  1153. audio_buf_info abinfo;
  1154. count_info cinfo;
  1155. int val, mapped, ret, count;
  1156. int div1, div2;
  1157. unsigned rate1, rate2;
  1158. void __user *argp = (void __user *)arg;
  1159. int __user *p = argp;
  1160. VALIDATE_STATE(s);
  1161. mapped = ((file->f_mode & FMODE_WRITE) && s->dma_dac.mapped) ||
  1162. ((file->f_mode & FMODE_READ) && s->dma_adc.mapped);
  1163. switch (cmd) {
  1164. case OSS_GETVERSION:
  1165. return put_user(SOUND_VERSION, p);
  1166. case SNDCTL_DSP_SYNC:
  1167. if (file->f_mode & FMODE_WRITE)
  1168. return drain_dac(s, 0/*file->f_flags & O_NONBLOCK*/);
  1169. return 0;
  1170. case SNDCTL_DSP_SETDUPLEX:
  1171. return 0;
  1172. case SNDCTL_DSP_GETCAPS:
  1173. return put_user(DSP_CAP_DUPLEX | DSP_CAP_REALTIME | DSP_CAP_TRIGGER | DSP_CAP_MMAP, p);
  1174. case SNDCTL_DSP_RESET:
  1175. if (file->f_mode & FMODE_WRITE) {
  1176. stop_dac(s);
  1177. synchronize_irq(s->irq);
  1178. s->dma_dac.swptr = s->dma_dac.hwptr = s->dma_dac.count = s->dma_dac.total_bytes = 0;
  1179. }
  1180. if (file->f_mode & FMODE_READ) {
  1181. stop_adc(s);
  1182. synchronize_irq(s->irq);
  1183. s->dma_adc.swptr = s->dma_adc.hwptr = s->dma_adc.count = s->dma_adc.total_bytes = 0;
  1184. }
  1185. prog_codec(s);
  1186. return 0;
  1187. case SNDCTL_DSP_SPEED:
  1188. if (get_user(val, p))
  1189. return -EFAULT;
  1190. if (val >= 0) {
  1191. stop_adc(s);
  1192. stop_dac(s);
  1193. s->dma_adc.ready = s->dma_dac.ready = 0;
  1194. /* program sampling rates */
  1195. if (val > 48000)
  1196. val = 48000;
  1197. if (val < 6300)
  1198. val = 6300;
  1199. div1 = (768000 + val / 2) / val;
  1200. rate1 = (768000 + div1 / 2) / div1;
  1201. div1 = -div1;
  1202. div2 = (793800 + val / 2) / val;
  1203. rate2 = (793800 + div2 / 2) / div2;
  1204. div2 = (-div2) & 0x7f;
  1205. if (abs(val - rate2) < abs(val - rate1)) {
  1206. rate1 = rate2;
  1207. div1 = div2;
  1208. }
  1209. s->rate = rate1;
  1210. s->clkdiv = div1;
  1211. prog_codec(s);
  1212. }
  1213. return put_user(s->rate, p);
  1214. case SNDCTL_DSP_STEREO:
  1215. if (get_user(val, p))
  1216. return -EFAULT;
  1217. stop_adc(s);
  1218. stop_dac(s);
  1219. s->dma_adc.ready = s->dma_dac.ready = 0;
  1220. /* program channels */
  1221. s->channels = val ? 2 : 1;
  1222. prog_codec(s);
  1223. return 0;
  1224. case SNDCTL_DSP_CHANNELS:
  1225. if (get_user(val, p))
  1226. return -EFAULT;
  1227. if (val != 0) {
  1228. stop_adc(s);
  1229. stop_dac(s);
  1230. s->dma_adc.ready = s->dma_dac.ready = 0;
  1231. /* program channels */
  1232. s->channels = (val >= 2) ? 2 : 1;
  1233. prog_codec(s);
  1234. }
  1235. return put_user(s->channels, p);
  1236. case SNDCTL_DSP_GETFMTS: /* Returns a mask */
  1237. return put_user(AFMT_S16_LE|AFMT_U16_LE|AFMT_S8|AFMT_U8, p);
  1238. case SNDCTL_DSP_SETFMT: /* Selects ONE fmt*/
  1239. if (get_user(val, p))
  1240. return -EFAULT;
  1241. if (val != AFMT_QUERY) {
  1242. stop_adc(s);
  1243. stop_dac(s);
  1244. s->dma_adc.ready = s->dma_dac.ready = 0;
  1245. /* program format */
  1246. if (val != AFMT_S16_LE && val != AFMT_U16_LE &&
  1247. val != AFMT_S8 && val != AFMT_U8)
  1248. val = AFMT_U8;
  1249. s->fmt = val;
  1250. prog_codec(s);
  1251. }
  1252. return put_user(s->fmt, p);
  1253. case SNDCTL_DSP_POST:
  1254. return 0;
  1255. case SNDCTL_DSP_GETTRIGGER:
  1256. val = 0;
  1257. if (file->f_mode & s->ena & FMODE_READ)
  1258. val |= PCM_ENABLE_INPUT;
  1259. if (file->f_mode & s->ena & FMODE_WRITE)
  1260. val |= PCM_ENABLE_OUTPUT;
  1261. return put_user(val, p);
  1262. case SNDCTL_DSP_SETTRIGGER:
  1263. if (get_user(val, p))
  1264. return -EFAULT;
  1265. if (file->f_mode & FMODE_READ) {
  1266. if (val & PCM_ENABLE_INPUT) {
  1267. if (!s->dma_adc.ready && (ret = prog_dmabuf_adc(s)))
  1268. return ret;
  1269. s->dma_dac.enabled = 1;
  1270. start_adc(s);
  1271. if (inb(s->ddmabase+15) & 1)
  1272. printk(KERN_ERR "solo1: cannot start recording, DDMA mask bit stuck at 1\n");
  1273. } else {
  1274. s->dma_dac.enabled = 0;
  1275. stop_adc(s);
  1276. }
  1277. }
  1278. if (file->f_mode & FMODE_WRITE) {
  1279. if (val & PCM_ENABLE_OUTPUT) {
  1280. if (!s->dma_dac.ready && (ret = prog_dmabuf_dac(s)))
  1281. return ret;
  1282. s->dma_dac.enabled = 1;
  1283. start_dac(s);
  1284. } else {
  1285. s->dma_dac.enabled = 0;
  1286. stop_dac(s);
  1287. }
  1288. }
  1289. return 0;
  1290. case SNDCTL_DSP_GETOSPACE:
  1291. if (!(file->f_mode & FMODE_WRITE))
  1292. return -EINVAL;
  1293. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1294. return val;
  1295. spin_lock_irqsave(&s->lock, flags);
  1296. solo1_update_ptr(s);
  1297. abinfo.fragsize = s->dma_dac.fragsize;
  1298. count = s->dma_dac.count;
  1299. if (count < 0)
  1300. count = 0;
  1301. abinfo.bytes = s->dma_dac.dmasize - count;
  1302. abinfo.fragstotal = s->dma_dac.numfrag;
  1303. abinfo.fragments = abinfo.bytes >> s->dma_dac.fragshift;
  1304. spin_unlock_irqrestore(&s->lock, flags);
  1305. return copy_to_user(argp, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1306. case SNDCTL_DSP_GETISPACE:
  1307. if (!(file->f_mode & FMODE_READ))
  1308. return -EINVAL;
  1309. if (!s->dma_adc.ready && (val = prog_dmabuf_adc(s)) != 0)
  1310. return val;
  1311. spin_lock_irqsave(&s->lock, flags);
  1312. solo1_update_ptr(s);
  1313. abinfo.fragsize = s->dma_adc.fragsize;
  1314. abinfo.bytes = s->dma_adc.count;
  1315. abinfo.fragstotal = s->dma_adc.numfrag;
  1316. abinfo.fragments = abinfo.bytes >> s->dma_adc.fragshift;
  1317. spin_unlock_irqrestore(&s->lock, flags);
  1318. return copy_to_user(argp, &abinfo, sizeof(abinfo)) ? -EFAULT : 0;
  1319. case SNDCTL_DSP_NONBLOCK:
  1320. file->f_flags |= O_NONBLOCK;
  1321. return 0;
  1322. case SNDCTL_DSP_GETODELAY:
  1323. if (!(file->f_mode & FMODE_WRITE))
  1324. return -EINVAL;
  1325. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1326. return val;
  1327. spin_lock_irqsave(&s->lock, flags);
  1328. solo1_update_ptr(s);
  1329. count = s->dma_dac.count;
  1330. spin_unlock_irqrestore(&s->lock, flags);
  1331. if (count < 0)
  1332. count = 0;
  1333. return put_user(count, p);
  1334. case SNDCTL_DSP_GETIPTR:
  1335. if (!(file->f_mode & FMODE_READ))
  1336. return -EINVAL;
  1337. if (!s->dma_adc.ready && (val = prog_dmabuf_adc(s)) != 0)
  1338. return val;
  1339. spin_lock_irqsave(&s->lock, flags);
  1340. solo1_update_ptr(s);
  1341. cinfo.bytes = s->dma_adc.total_bytes;
  1342. cinfo.blocks = s->dma_adc.count >> s->dma_adc.fragshift;
  1343. cinfo.ptr = s->dma_adc.hwptr;
  1344. if (s->dma_adc.mapped)
  1345. s->dma_adc.count &= s->dma_adc.fragsize-1;
  1346. spin_unlock_irqrestore(&s->lock, flags);
  1347. if (copy_to_user(argp, &cinfo, sizeof(cinfo)))
  1348. return -EFAULT;
  1349. return 0;
  1350. case SNDCTL_DSP_GETOPTR:
  1351. if (!(file->f_mode & FMODE_WRITE))
  1352. return -EINVAL;
  1353. if (!s->dma_dac.ready && (val = prog_dmabuf_dac(s)) != 0)
  1354. return val;
  1355. spin_lock_irqsave(&s->lock, flags);
  1356. solo1_update_ptr(s);
  1357. cinfo.bytes = s->dma_dac.total_bytes;
  1358. count = s->dma_dac.count;
  1359. if (count < 0)
  1360. count = 0;
  1361. cinfo.blocks = count >> s->dma_dac.fragshift;
  1362. cinfo.ptr = s->dma_dac.hwptr;
  1363. if (s->dma_dac.mapped)
  1364. s->dma_dac.count &= s->dma_dac.fragsize-1;
  1365. spin_unlock_irqrestore(&s->lock, flags);
  1366. #if 0
  1367. printk(KERN_DEBUG "esssolo1: GETOPTR: bytes %u blocks %u ptr %u, buforder %u numfrag %u fragshift %u\n"
  1368. KERN_DEBUG "esssolo1: swptr %u count %u fragsize %u dmasize %u fragsamples %u\n",
  1369. cinfo.bytes, cinfo.blocks, cinfo.ptr, s->dma_dac.buforder, s->dma_dac.numfrag, s->dma_dac.fragshift,
  1370. s->dma_dac.swptr, s->dma_dac.count, s->dma_dac.fragsize, s->dma_dac.dmasize, s->dma_dac.fragsamples);
  1371. #endif
  1372. if (copy_to_user(argp, &cinfo, sizeof(cinfo)))
  1373. return -EFAULT;
  1374. return 0;
  1375. case SNDCTL_DSP_GETBLKSIZE:
  1376. if (file->f_mode & FMODE_WRITE) {
  1377. if ((val = prog_dmabuf_dac(s)))
  1378. return val;
  1379. return put_user(s->dma_dac.fragsize, p);
  1380. }
  1381. if ((val = prog_dmabuf_adc(s)))
  1382. return val;
  1383. return put_user(s->dma_adc.fragsize, p);
  1384. case SNDCTL_DSP_SETFRAGMENT:
  1385. if (get_user(val, p))
  1386. return -EFAULT;
  1387. if (file->f_mode & FMODE_READ) {
  1388. s->dma_adc.ossfragshift = val & 0xffff;
  1389. s->dma_adc.ossmaxfrags = (val >> 16) & 0xffff;
  1390. if (s->dma_adc.ossfragshift < 4)
  1391. s->dma_adc.ossfragshift = 4;
  1392. if (s->dma_adc.ossfragshift > 15)
  1393. s->dma_adc.ossfragshift = 15;
  1394. if (s->dma_adc.ossmaxfrags < 4)
  1395. s->dma_adc.ossmaxfrags = 4;
  1396. }
  1397. if (file->f_mode & FMODE_WRITE) {
  1398. s->dma_dac.ossfragshift = val & 0xffff;
  1399. s->dma_dac.ossmaxfrags = (val >> 16) & 0xffff;
  1400. if (s->dma_dac.ossfragshift < 4)
  1401. s->dma_dac.ossfragshift = 4;
  1402. if (s->dma_dac.ossfragshift > 15)
  1403. s->dma_dac.ossfragshift = 15;
  1404. if (s->dma_dac.ossmaxfrags < 4)
  1405. s->dma_dac.ossmaxfrags = 4;
  1406. }
  1407. return 0;
  1408. case SNDCTL_DSP_SUBDIVIDE:
  1409. if ((file->f_mode & FMODE_READ && s->dma_adc.subdivision) ||
  1410. (file->f_mode & FMODE_WRITE && s->dma_dac.subdivision))
  1411. return -EINVAL;
  1412. if (get_user(val, p))
  1413. return -EFAULT;
  1414. if (val != 1 && val != 2 && val != 4)
  1415. return -EINVAL;
  1416. if (file->f_mode & FMODE_READ)
  1417. s->dma_adc.subdivision = val;
  1418. if (file->f_mode & FMODE_WRITE)
  1419. s->dma_dac.subdivision = val;
  1420. return 0;
  1421. case SOUND_PCM_READ_RATE:
  1422. return put_user(s->rate, p);
  1423. case SOUND_PCM_READ_CHANNELS:
  1424. return put_user(s->channels, p);
  1425. case SOUND_PCM_READ_BITS:
  1426. return put_user((s->fmt & (AFMT_S8|AFMT_U8)) ? 8 : 16, p);
  1427. case SOUND_PCM_WRITE_FILTER:
  1428. case SNDCTL_DSP_SETSYNCRO:
  1429. case SOUND_PCM_READ_FILTER:
  1430. return -EINVAL;
  1431. }
  1432. return mixer_ioctl(s, cmd, arg);
  1433. }
  1434. static int solo1_release(struct inode *inode, struct file *file)
  1435. {
  1436. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1437. VALIDATE_STATE(s);
  1438. lock_kernel();
  1439. if (file->f_mode & FMODE_WRITE)
  1440. drain_dac(s, file->f_flags & O_NONBLOCK);
  1441. down(&s->open_sem);
  1442. if (file->f_mode & FMODE_WRITE) {
  1443. stop_dac(s);
  1444. outb(0, s->iobase+6); /* disable DMA */
  1445. dealloc_dmabuf(s, &s->dma_dac);
  1446. }
  1447. if (file->f_mode & FMODE_READ) {
  1448. stop_adc(s);
  1449. outb(1, s->ddmabase+0xf); /* mask DMA channel */
  1450. outb(0, s->ddmabase+0xd); /* DMA master clear */
  1451. dealloc_dmabuf(s, &s->dma_adc);
  1452. }
  1453. s->open_mode &= ~(FMODE_READ | FMODE_WRITE);
  1454. wake_up(&s->open_wait);
  1455. up(&s->open_sem);
  1456. unlock_kernel();
  1457. return 0;
  1458. }
  1459. static int solo1_open(struct inode *inode, struct file *file)
  1460. {
  1461. unsigned int minor = iminor(inode);
  1462. DECLARE_WAITQUEUE(wait, current);
  1463. struct solo1_state *s = NULL;
  1464. struct pci_dev *pci_dev = NULL;
  1465. while ((pci_dev = pci_find_device(PCI_ANY_ID, PCI_ANY_ID, pci_dev)) != NULL) {
  1466. struct pci_driver *drvr;
  1467. drvr = pci_dev_driver(pci_dev);
  1468. if (drvr != &solo1_driver)
  1469. continue;
  1470. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1471. if (!s)
  1472. continue;
  1473. if (!((s->dev_audio ^ minor) & ~0xf))
  1474. break;
  1475. }
  1476. if (!s)
  1477. return -ENODEV;
  1478. VALIDATE_STATE(s);
  1479. file->private_data = s;
  1480. /* wait for device to become free */
  1481. down(&s->open_sem);
  1482. while (s->open_mode & (FMODE_READ | FMODE_WRITE)) {
  1483. if (file->f_flags & O_NONBLOCK) {
  1484. up(&s->open_sem);
  1485. return -EBUSY;
  1486. }
  1487. add_wait_queue(&s->open_wait, &wait);
  1488. __set_current_state(TASK_INTERRUPTIBLE);
  1489. up(&s->open_sem);
  1490. schedule();
  1491. remove_wait_queue(&s->open_wait, &wait);
  1492. set_current_state(TASK_RUNNING);
  1493. if (signal_pending(current))
  1494. return -ERESTARTSYS;
  1495. down(&s->open_sem);
  1496. }
  1497. s->fmt = AFMT_U8;
  1498. s->channels = 1;
  1499. s->rate = 8000;
  1500. s->clkdiv = 96 | 0x80;
  1501. s->ena = 0;
  1502. s->dma_adc.ossfragshift = s->dma_adc.ossmaxfrags = s->dma_adc.subdivision = 0;
  1503. s->dma_adc.enabled = 1;
  1504. s->dma_dac.ossfragshift = s->dma_dac.ossmaxfrags = s->dma_dac.subdivision = 0;
  1505. s->dma_dac.enabled = 1;
  1506. s->open_mode |= file->f_mode & (FMODE_READ | FMODE_WRITE);
  1507. up(&s->open_sem);
  1508. prog_codec(s);
  1509. return nonseekable_open(inode, file);
  1510. }
  1511. static /*const*/ struct file_operations solo1_audio_fops = {
  1512. .owner = THIS_MODULE,
  1513. .llseek = no_llseek,
  1514. .read = solo1_read,
  1515. .write = solo1_write,
  1516. .poll = solo1_poll,
  1517. .ioctl = solo1_ioctl,
  1518. .mmap = solo1_mmap,
  1519. .open = solo1_open,
  1520. .release = solo1_release,
  1521. };
  1522. /* --------------------------------------------------------------------- */
  1523. /* hold spinlock for the following! */
  1524. static void solo1_handle_midi(struct solo1_state *s)
  1525. {
  1526. unsigned char ch;
  1527. int wake;
  1528. if (!(s->mpubase))
  1529. return;
  1530. wake = 0;
  1531. while (!(inb(s->mpubase+1) & 0x80)) {
  1532. ch = inb(s->mpubase);
  1533. if (s->midi.icnt < MIDIINBUF) {
  1534. s->midi.ibuf[s->midi.iwr] = ch;
  1535. s->midi.iwr = (s->midi.iwr + 1) % MIDIINBUF;
  1536. s->midi.icnt++;
  1537. }
  1538. wake = 1;
  1539. }
  1540. if (wake)
  1541. wake_up(&s->midi.iwait);
  1542. wake = 0;
  1543. while (!(inb(s->mpubase+1) & 0x40) && s->midi.ocnt > 0) {
  1544. outb(s->midi.obuf[s->midi.ord], s->mpubase);
  1545. s->midi.ord = (s->midi.ord + 1) % MIDIOUTBUF;
  1546. s->midi.ocnt--;
  1547. if (s->midi.ocnt < MIDIOUTBUF-16)
  1548. wake = 1;
  1549. }
  1550. if (wake)
  1551. wake_up(&s->midi.owait);
  1552. }
  1553. static irqreturn_t solo1_interrupt(int irq, void *dev_id, struct pt_regs *regs)
  1554. {
  1555. struct solo1_state *s = (struct solo1_state *)dev_id;
  1556. unsigned int intsrc;
  1557. /* fastpath out, to ease interrupt sharing */
  1558. intsrc = inb(s->iobase+7); /* get interrupt source(s) */
  1559. if (!intsrc)
  1560. return IRQ_NONE;
  1561. (void)inb(s->sbbase+0xe); /* clear interrupt */
  1562. spin_lock(&s->lock);
  1563. /* clear audio interrupts first */
  1564. if (intsrc & 0x20)
  1565. write_mixer(s, 0x7a, read_mixer(s, 0x7a) & 0x7f);
  1566. solo1_update_ptr(s);
  1567. solo1_handle_midi(s);
  1568. spin_unlock(&s->lock);
  1569. return IRQ_HANDLED;
  1570. }
  1571. static void solo1_midi_timer(unsigned long data)
  1572. {
  1573. struct solo1_state *s = (struct solo1_state *)data;
  1574. unsigned long flags;
  1575. spin_lock_irqsave(&s->lock, flags);
  1576. solo1_handle_midi(s);
  1577. spin_unlock_irqrestore(&s->lock, flags);
  1578. s->midi.timer.expires = jiffies+1;
  1579. add_timer(&s->midi.timer);
  1580. }
  1581. /* --------------------------------------------------------------------- */
  1582. static ssize_t solo1_midi_read(struct file *file, char __user *buffer, size_t count, loff_t *ppos)
  1583. {
  1584. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1585. DECLARE_WAITQUEUE(wait, current);
  1586. ssize_t ret;
  1587. unsigned long flags;
  1588. unsigned ptr;
  1589. int cnt;
  1590. VALIDATE_STATE(s);
  1591. if (!access_ok(VERIFY_WRITE, buffer, count))
  1592. return -EFAULT;
  1593. if (count == 0)
  1594. return 0;
  1595. ret = 0;
  1596. add_wait_queue(&s->midi.iwait, &wait);
  1597. while (count > 0) {
  1598. spin_lock_irqsave(&s->lock, flags);
  1599. ptr = s->midi.ird;
  1600. cnt = MIDIINBUF - ptr;
  1601. if (s->midi.icnt < cnt)
  1602. cnt = s->midi.icnt;
  1603. if (cnt <= 0)
  1604. __set_current_state(TASK_INTERRUPTIBLE);
  1605. spin_unlock_irqrestore(&s->lock, flags);
  1606. if (cnt > count)
  1607. cnt = count;
  1608. if (cnt <= 0) {
  1609. if (file->f_flags & O_NONBLOCK) {
  1610. if (!ret)
  1611. ret = -EAGAIN;
  1612. break;
  1613. }
  1614. schedule();
  1615. if (signal_pending(current)) {
  1616. if (!ret)
  1617. ret = -ERESTARTSYS;
  1618. break;
  1619. }
  1620. continue;
  1621. }
  1622. if (copy_to_user(buffer, s->midi.ibuf + ptr, cnt)) {
  1623. if (!ret)
  1624. ret = -EFAULT;
  1625. break;
  1626. }
  1627. ptr = (ptr + cnt) % MIDIINBUF;
  1628. spin_lock_irqsave(&s->lock, flags);
  1629. s->midi.ird = ptr;
  1630. s->midi.icnt -= cnt;
  1631. spin_unlock_irqrestore(&s->lock, flags);
  1632. count -= cnt;
  1633. buffer += cnt;
  1634. ret += cnt;
  1635. break;
  1636. }
  1637. __set_current_state(TASK_RUNNING);
  1638. remove_wait_queue(&s->midi.iwait, &wait);
  1639. return ret;
  1640. }
  1641. static ssize_t solo1_midi_write(struct file *file, const char __user *buffer, size_t count, loff_t *ppos)
  1642. {
  1643. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1644. DECLARE_WAITQUEUE(wait, current);
  1645. ssize_t ret;
  1646. unsigned long flags;
  1647. unsigned ptr;
  1648. int cnt;
  1649. VALIDATE_STATE(s);
  1650. if (!access_ok(VERIFY_READ, buffer, count))
  1651. return -EFAULT;
  1652. if (count == 0)
  1653. return 0;
  1654. ret = 0;
  1655. add_wait_queue(&s->midi.owait, &wait);
  1656. while (count > 0) {
  1657. spin_lock_irqsave(&s->lock, flags);
  1658. ptr = s->midi.owr;
  1659. cnt = MIDIOUTBUF - ptr;
  1660. if (s->midi.ocnt + cnt > MIDIOUTBUF)
  1661. cnt = MIDIOUTBUF - s->midi.ocnt;
  1662. if (cnt <= 0) {
  1663. __set_current_state(TASK_INTERRUPTIBLE);
  1664. solo1_handle_midi(s);
  1665. }
  1666. spin_unlock_irqrestore(&s->lock, flags);
  1667. if (cnt > count)
  1668. cnt = count;
  1669. if (cnt <= 0) {
  1670. if (file->f_flags & O_NONBLOCK) {
  1671. if (!ret)
  1672. ret = -EAGAIN;
  1673. break;
  1674. }
  1675. schedule();
  1676. if (signal_pending(current)) {
  1677. if (!ret)
  1678. ret = -ERESTARTSYS;
  1679. break;
  1680. }
  1681. continue;
  1682. }
  1683. if (copy_from_user(s->midi.obuf + ptr, buffer, cnt)) {
  1684. if (!ret)
  1685. ret = -EFAULT;
  1686. break;
  1687. }
  1688. ptr = (ptr + cnt) % MIDIOUTBUF;
  1689. spin_lock_irqsave(&s->lock, flags);
  1690. s->midi.owr = ptr;
  1691. s->midi.ocnt += cnt;
  1692. spin_unlock_irqrestore(&s->lock, flags);
  1693. count -= cnt;
  1694. buffer += cnt;
  1695. ret += cnt;
  1696. spin_lock_irqsave(&s->lock, flags);
  1697. solo1_handle_midi(s);
  1698. spin_unlock_irqrestore(&s->lock, flags);
  1699. }
  1700. __set_current_state(TASK_RUNNING);
  1701. remove_wait_queue(&s->midi.owait, &wait);
  1702. return ret;
  1703. }
  1704. /* No kernel lock - we have our own spinlock */
  1705. static unsigned int solo1_midi_poll(struct file *file, struct poll_table_struct *wait)
  1706. {
  1707. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1708. unsigned long flags;
  1709. unsigned int mask = 0;
  1710. VALIDATE_STATE(s);
  1711. if (file->f_flags & FMODE_WRITE)
  1712. poll_wait(file, &s->midi.owait, wait);
  1713. if (file->f_flags & FMODE_READ)
  1714. poll_wait(file, &s->midi.iwait, wait);
  1715. spin_lock_irqsave(&s->lock, flags);
  1716. if (file->f_flags & FMODE_READ) {
  1717. if (s->midi.icnt > 0)
  1718. mask |= POLLIN | POLLRDNORM;
  1719. }
  1720. if (file->f_flags & FMODE_WRITE) {
  1721. if (s->midi.ocnt < MIDIOUTBUF)
  1722. mask |= POLLOUT | POLLWRNORM;
  1723. }
  1724. spin_unlock_irqrestore(&s->lock, flags);
  1725. return mask;
  1726. }
  1727. static int solo1_midi_open(struct inode *inode, struct file *file)
  1728. {
  1729. unsigned int minor = iminor(inode);
  1730. DECLARE_WAITQUEUE(wait, current);
  1731. unsigned long flags;
  1732. struct solo1_state *s = NULL;
  1733. struct pci_dev *pci_dev = NULL;
  1734. while ((pci_dev = pci_find_device(PCI_ANY_ID, PCI_ANY_ID, pci_dev)) != NULL) {
  1735. struct pci_driver *drvr;
  1736. drvr = pci_dev_driver(pci_dev);
  1737. if (drvr != &solo1_driver)
  1738. continue;
  1739. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1740. if (!s)
  1741. continue;
  1742. if (s->dev_midi == minor)
  1743. break;
  1744. }
  1745. if (!s)
  1746. return -ENODEV;
  1747. VALIDATE_STATE(s);
  1748. file->private_data = s;
  1749. /* wait for device to become free */
  1750. down(&s->open_sem);
  1751. while (s->open_mode & (file->f_mode << FMODE_MIDI_SHIFT)) {
  1752. if (file->f_flags & O_NONBLOCK) {
  1753. up(&s->open_sem);
  1754. return -EBUSY;
  1755. }
  1756. add_wait_queue(&s->open_wait, &wait);
  1757. __set_current_state(TASK_INTERRUPTIBLE);
  1758. up(&s->open_sem);
  1759. schedule();
  1760. remove_wait_queue(&s->open_wait, &wait);
  1761. set_current_state(TASK_RUNNING);
  1762. if (signal_pending(current))
  1763. return -ERESTARTSYS;
  1764. down(&s->open_sem);
  1765. }
  1766. spin_lock_irqsave(&s->lock, flags);
  1767. if (!(s->open_mode & (FMODE_MIDI_READ | FMODE_MIDI_WRITE))) {
  1768. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1769. s->midi.ord = s->midi.owr = s->midi.ocnt = 0;
  1770. outb(0xff, s->mpubase+1); /* reset command */
  1771. outb(0x3f, s->mpubase+1); /* uart command */
  1772. if (!(inb(s->mpubase+1) & 0x80))
  1773. inb(s->mpubase);
  1774. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1775. outb(0xb0, s->iobase + 7); /* enable A1, A2, MPU irq's */
  1776. init_timer(&s->midi.timer);
  1777. s->midi.timer.expires = jiffies+1;
  1778. s->midi.timer.data = (unsigned long)s;
  1779. s->midi.timer.function = solo1_midi_timer;
  1780. add_timer(&s->midi.timer);
  1781. }
  1782. if (file->f_mode & FMODE_READ) {
  1783. s->midi.ird = s->midi.iwr = s->midi.icnt = 0;
  1784. }
  1785. if (file->f_mode & FMODE_WRITE) {
  1786. s->midi.ord = s->midi.owr = s->midi.ocnt = 0;
  1787. }
  1788. spin_unlock_irqrestore(&s->lock, flags);
  1789. s->open_mode |= (file->f_mode << FMODE_MIDI_SHIFT) & (FMODE_MIDI_READ | FMODE_MIDI_WRITE);
  1790. up(&s->open_sem);
  1791. return nonseekable_open(inode, file);
  1792. }
  1793. static int solo1_midi_release(struct inode *inode, struct file *file)
  1794. {
  1795. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1796. DECLARE_WAITQUEUE(wait, current);
  1797. unsigned long flags;
  1798. unsigned count, tmo;
  1799. VALIDATE_STATE(s);
  1800. lock_kernel();
  1801. if (file->f_mode & FMODE_WRITE) {
  1802. add_wait_queue(&s->midi.owait, &wait);
  1803. for (;;) {
  1804. __set_current_state(TASK_INTERRUPTIBLE);
  1805. spin_lock_irqsave(&s->lock, flags);
  1806. count = s->midi.ocnt;
  1807. spin_unlock_irqrestore(&s->lock, flags);
  1808. if (count <= 0)
  1809. break;
  1810. if (signal_pending(current))
  1811. break;
  1812. if (file->f_flags & O_NONBLOCK)
  1813. break;
  1814. tmo = (count * HZ) / 3100;
  1815. if (!schedule_timeout(tmo ? : 1) && tmo)
  1816. printk(KERN_DEBUG "solo1: midi timed out??\n");
  1817. }
  1818. remove_wait_queue(&s->midi.owait, &wait);
  1819. set_current_state(TASK_RUNNING);
  1820. }
  1821. down(&s->open_sem);
  1822. s->open_mode &= ~((file->f_mode << FMODE_MIDI_SHIFT) & (FMODE_MIDI_READ|FMODE_MIDI_WRITE));
  1823. spin_lock_irqsave(&s->lock, flags);
  1824. if (!(s->open_mode & (FMODE_MIDI_READ | FMODE_MIDI_WRITE))) {
  1825. outb(0x30, s->iobase + 7); /* enable A1, A2 irq's */
  1826. del_timer(&s->midi.timer);
  1827. }
  1828. spin_unlock_irqrestore(&s->lock, flags);
  1829. wake_up(&s->open_wait);
  1830. up(&s->open_sem);
  1831. unlock_kernel();
  1832. return 0;
  1833. }
  1834. static /*const*/ struct file_operations solo1_midi_fops = {
  1835. .owner = THIS_MODULE,
  1836. .llseek = no_llseek,
  1837. .read = solo1_midi_read,
  1838. .write = solo1_midi_write,
  1839. .poll = solo1_midi_poll,
  1840. .open = solo1_midi_open,
  1841. .release = solo1_midi_release,
  1842. };
  1843. /* --------------------------------------------------------------------- */
  1844. static int solo1_dmfm_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)
  1845. {
  1846. static const unsigned char op_offset[18] = {
  1847. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05,
  1848. 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D,
  1849. 0x10, 0x11, 0x12, 0x13, 0x14, 0x15
  1850. };
  1851. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1852. struct dm_fm_voice v;
  1853. struct dm_fm_note n;
  1854. struct dm_fm_params p;
  1855. unsigned int io;
  1856. unsigned int regb;
  1857. switch (cmd) {
  1858. case FM_IOCTL_RESET:
  1859. for (regb = 0xb0; regb < 0xb9; regb++) {
  1860. outb(regb, s->sbbase);
  1861. outb(0, s->sbbase+1);
  1862. outb(regb, s->sbbase+2);
  1863. outb(0, s->sbbase+3);
  1864. }
  1865. return 0;
  1866. case FM_IOCTL_PLAY_NOTE:
  1867. if (copy_from_user(&n, (void __user *)arg, sizeof(n)))
  1868. return -EFAULT;
  1869. if (n.voice >= 18)
  1870. return -EINVAL;
  1871. if (n.voice >= 9) {
  1872. regb = n.voice - 9;
  1873. io = s->sbbase+2;
  1874. } else {
  1875. regb = n.voice;
  1876. io = s->sbbase;
  1877. }
  1878. outb(0xa0 + regb, io);
  1879. outb(n.fnum & 0xff, io+1);
  1880. outb(0xb0 + regb, io);
  1881. outb(((n.fnum >> 8) & 3) | ((n.octave & 7) << 2) | ((n.key_on & 1) << 5), io+1);
  1882. return 0;
  1883. case FM_IOCTL_SET_VOICE:
  1884. if (copy_from_user(&v, (void __user *)arg, sizeof(v)))
  1885. return -EFAULT;
  1886. if (v.voice >= 18)
  1887. return -EINVAL;
  1888. regb = op_offset[v.voice];
  1889. io = s->sbbase + ((v.op & 1) << 1);
  1890. outb(0x20 + regb, io);
  1891. outb(((v.am & 1) << 7) | ((v.vibrato & 1) << 6) | ((v.do_sustain & 1) << 5) |
  1892. ((v.kbd_scale & 1) << 4) | (v.harmonic & 0xf), io+1);
  1893. outb(0x40 + regb, io);
  1894. outb(((v.scale_level & 0x3) << 6) | (v.volume & 0x3f), io+1);
  1895. outb(0x60 + regb, io);
  1896. outb(((v.attack & 0xf) << 4) | (v.decay & 0xf), io+1);
  1897. outb(0x80 + regb, io);
  1898. outb(((v.sustain & 0xf) << 4) | (v.release & 0xf), io+1);
  1899. outb(0xe0 + regb, io);
  1900. outb(v.waveform & 0x7, io+1);
  1901. if (n.voice >= 9) {
  1902. regb = n.voice - 9;
  1903. io = s->sbbase+2;
  1904. } else {
  1905. regb = n.voice;
  1906. io = s->sbbase;
  1907. }
  1908. outb(0xc0 + regb, io);
  1909. outb(((v.right & 1) << 5) | ((v.left & 1) << 4) | ((v.feedback & 7) << 1) |
  1910. (v.connection & 1), io+1);
  1911. return 0;
  1912. case FM_IOCTL_SET_PARAMS:
  1913. if (copy_from_user(&p, (void __user *)arg, sizeof(p)))
  1914. return -EFAULT;
  1915. outb(0x08, s->sbbase);
  1916. outb((p.kbd_split & 1) << 6, s->sbbase+1);
  1917. outb(0xbd, s->sbbase);
  1918. outb(((p.am_depth & 1) << 7) | ((p.vib_depth & 1) << 6) | ((p.rhythm & 1) << 5) | ((p.bass & 1) << 4) |
  1919. ((p.snare & 1) << 3) | ((p.tomtom & 1) << 2) | ((p.cymbal & 1) << 1) | (p.hihat & 1), s->sbbase+1);
  1920. return 0;
  1921. case FM_IOCTL_SET_OPL:
  1922. outb(4, s->sbbase+2);
  1923. outb(arg, s->sbbase+3);
  1924. return 0;
  1925. case FM_IOCTL_SET_MODE:
  1926. outb(5, s->sbbase+2);
  1927. outb(arg & 1, s->sbbase+3);
  1928. return 0;
  1929. default:
  1930. return -EINVAL;
  1931. }
  1932. }
  1933. static int solo1_dmfm_open(struct inode *inode, struct file *file)
  1934. {
  1935. unsigned int minor = iminor(inode);
  1936. DECLARE_WAITQUEUE(wait, current);
  1937. struct solo1_state *s = NULL;
  1938. struct pci_dev *pci_dev = NULL;
  1939. while ((pci_dev = pci_find_device(PCI_ANY_ID, PCI_ANY_ID, pci_dev)) != NULL) {
  1940. struct pci_driver *drvr;
  1941. drvr = pci_dev_driver(pci_dev);
  1942. if (drvr != &solo1_driver)
  1943. continue;
  1944. s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  1945. if (!s)
  1946. continue;
  1947. if (s->dev_dmfm == minor)
  1948. break;
  1949. }
  1950. if (!s)
  1951. return -ENODEV;
  1952. VALIDATE_STATE(s);
  1953. file->private_data = s;
  1954. /* wait for device to become free */
  1955. down(&s->open_sem);
  1956. while (s->open_mode & FMODE_DMFM) {
  1957. if (file->f_flags & O_NONBLOCK) {
  1958. up(&s->open_sem);
  1959. return -EBUSY;
  1960. }
  1961. add_wait_queue(&s->open_wait, &wait);
  1962. __set_current_state(TASK_INTERRUPTIBLE);
  1963. up(&s->open_sem);
  1964. schedule();
  1965. remove_wait_queue(&s->open_wait, &wait);
  1966. set_current_state(TASK_RUNNING);
  1967. if (signal_pending(current))
  1968. return -ERESTARTSYS;
  1969. down(&s->open_sem);
  1970. }
  1971. if (!request_region(s->sbbase, FMSYNTH_EXTENT, "ESS Solo1")) {
  1972. up(&s->open_sem);
  1973. printk(KERN_ERR "solo1: FM synth io ports in use, opl3 loaded?\n");
  1974. return -EBUSY;
  1975. }
  1976. /* init the stuff */
  1977. outb(1, s->sbbase);
  1978. outb(0x20, s->sbbase+1); /* enable waveforms */
  1979. outb(4, s->sbbase+2);
  1980. outb(0, s->sbbase+3); /* no 4op enabled */
  1981. outb(5, s->sbbase+2);
  1982. outb(1, s->sbbase+3); /* enable OPL3 */
  1983. s->open_mode |= FMODE_DMFM;
  1984. up(&s->open_sem);
  1985. return nonseekable_open(inode, file);
  1986. }
  1987. static int solo1_dmfm_release(struct inode *inode, struct file *file)
  1988. {
  1989. struct solo1_state *s = (struct solo1_state *)file->private_data;
  1990. unsigned int regb;
  1991. VALIDATE_STATE(s);
  1992. lock_kernel();
  1993. down(&s->open_sem);
  1994. s->open_mode &= ~FMODE_DMFM;
  1995. for (regb = 0xb0; regb < 0xb9; regb++) {
  1996. outb(regb, s->sbbase);
  1997. outb(0, s->sbbase+1);
  1998. outb(regb, s->sbbase+2);
  1999. outb(0, s->sbbase+3);
  2000. }
  2001. release_region(s->sbbase, FMSYNTH_EXTENT);
  2002. wake_up(&s->open_wait);
  2003. up(&s->open_sem);
  2004. unlock_kernel();
  2005. return 0;
  2006. }
  2007. static /*const*/ struct file_operations solo1_dmfm_fops = {
  2008. .owner = THIS_MODULE,
  2009. .llseek = no_llseek,
  2010. .ioctl = solo1_dmfm_ioctl,
  2011. .open = solo1_dmfm_open,
  2012. .release = solo1_dmfm_release,
  2013. };
  2014. /* --------------------------------------------------------------------- */
  2015. static struct initvol {
  2016. int mixch;
  2017. int vol;
  2018. } initvol[] __devinitdata = {
  2019. { SOUND_MIXER_WRITE_VOLUME, 0x4040 },
  2020. { SOUND_MIXER_WRITE_PCM, 0x4040 },
  2021. { SOUND_MIXER_WRITE_SYNTH, 0x4040 },
  2022. { SOUND_MIXER_WRITE_CD, 0x4040 },
  2023. { SOUND_MIXER_WRITE_LINE, 0x4040 },
  2024. { SOUND_MIXER_WRITE_LINE1, 0x4040 },
  2025. { SOUND_MIXER_WRITE_LINE2, 0x4040 },
  2026. { SOUND_MIXER_WRITE_RECLEV, 0x4040 },
  2027. { SOUND_MIXER_WRITE_SPEAKER, 0x4040 },
  2028. { SOUND_MIXER_WRITE_MIC, 0x4040 }
  2029. };
  2030. static int setup_solo1(struct solo1_state *s)
  2031. {
  2032. struct pci_dev *pcidev = s->dev;
  2033. mm_segment_t fs;
  2034. int i, val;
  2035. /* initialize DDMA base address */
  2036. printk(KERN_DEBUG "solo1: ddma base address: 0x%lx\n", s->ddmabase);
  2037. pci_write_config_word(pcidev, 0x60, (s->ddmabase & (~0xf)) | 1);
  2038. /* set DMA policy to DDMA, IRQ emulation off (CLKRUN disabled for now) */
  2039. pci_write_config_dword(pcidev, 0x50, 0);
  2040. /* disable legacy audio address decode */
  2041. pci_write_config_word(pcidev, 0x40, 0x907f);
  2042. /* initialize the chips */
  2043. if (!reset_ctrl(s)) {
  2044. printk(KERN_ERR "esssolo1: cannot reset controller\n");
  2045. return -1;
  2046. }
  2047. outb(0xb0, s->iobase+7); /* enable A1, A2, MPU irq's */
  2048. /* initialize mixer regs */
  2049. write_mixer(s, 0x7f, 0); /* disable music digital recording */
  2050. write_mixer(s, 0x7d, 0x0c); /* enable mic preamp, MONO_OUT is 2nd DAC right channel */
  2051. write_mixer(s, 0x64, 0x45); /* volume control */
  2052. write_mixer(s, 0x48, 0x10); /* enable music DAC/ES6xx interface */
  2053. write_mixer(s, 0x50, 0); /* disable spatializer */
  2054. write_mixer(s, 0x52, 0);
  2055. write_mixer(s, 0x14, 0); /* DAC1 minimum volume */
  2056. write_mixer(s, 0x71, 0x20); /* enable new 0xA1 reg format */
  2057. outb(0, s->ddmabase+0xd); /* DMA master clear */
  2058. outb(1, s->ddmabase+0xf); /* mask channel */
  2059. /*outb(0, s->ddmabase+0x8);*/ /* enable controller (enable is low active!!) */
  2060. pci_set_master(pcidev); /* enable bus mastering */
  2061. fs = get_fs();
  2062. set_fs(KERNEL_DS);
  2063. val = SOUND_MASK_LINE;
  2064. mixer_ioctl(s, SOUND_MIXER_WRITE_RECSRC, (unsigned long)&val);
  2065. for (i = 0; i < sizeof(initvol)/sizeof(initvol[0]); i++) {
  2066. val = initvol[i].vol;
  2067. mixer_ioctl(s, initvol[i].mixch, (unsigned long)&val);
  2068. }
  2069. val = 1; /* enable mic preamp */
  2070. mixer_ioctl(s, SOUND_MIXER_PRIVATE1, (unsigned long)&val);
  2071. set_fs(fs);
  2072. return 0;
  2073. }
  2074. static int
  2075. solo1_suspend(struct pci_dev *pci_dev, pm_message_t state) {
  2076. struct solo1_state *s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  2077. if (!s)
  2078. return 1;
  2079. outb(0, s->iobase+6);
  2080. /* DMA master clear */
  2081. outb(0, s->ddmabase+0xd);
  2082. /* reset sequencer and FIFO */
  2083. outb(3, s->sbbase+6);
  2084. /* turn off DDMA controller address space */
  2085. pci_write_config_word(s->dev, 0x60, 0);
  2086. return 0;
  2087. }
  2088. static int
  2089. solo1_resume(struct pci_dev *pci_dev) {
  2090. struct solo1_state *s = (struct solo1_state*)pci_get_drvdata(pci_dev);
  2091. if (!s)
  2092. return 1;
  2093. setup_solo1(s);
  2094. return 0;
  2095. }
  2096. static int __devinit solo1_register_gameport(struct solo1_state *s, int io_port)
  2097. {
  2098. struct gameport *gp;
  2099. if (!request_region(io_port, GAMEPORT_EXTENT, "ESS Solo1")) {
  2100. printk(KERN_ERR "solo1: gameport io ports are in use\n");
  2101. return -EBUSY;
  2102. }
  2103. s->gameport = gp = gameport_allocate_port();
  2104. if (!gp) {
  2105. printk(KERN_ERR "solo1: can not allocate memory for gameport\n");
  2106. release_region(io_port, GAMEPORT_EXTENT);
  2107. return -ENOMEM;
  2108. }
  2109. gameport_set_name(gp, "ESS Solo1 Gameport");
  2110. gameport_set_phys(gp, "isa%04x/gameport0", io_port);
  2111. gp->dev.parent = &s->dev->dev;
  2112. gp->io = io_port;
  2113. gameport_register_port(gp);
  2114. return 0;
  2115. }
  2116. static int __devinit solo1_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid)
  2117. {
  2118. struct solo1_state *s;
  2119. int gpio;
  2120. int ret;
  2121. if ((ret=pci_enable_device(pcidev)))
  2122. return ret;
  2123. if (!(pci_resource_flags(pcidev, 0) & IORESOURCE_IO) ||
  2124. !(pci_resource_flags(pcidev, 1) & IORESOURCE_IO) ||
  2125. !(pci_resource_flags(pcidev, 2) & IORESOURCE_IO) ||
  2126. !(pci_resource_flags(pcidev, 3) & IORESOURCE_IO))
  2127. return -ENODEV;
  2128. if (pcidev->irq == 0)
  2129. return -ENODEV;
  2130. /* Recording requires 24-bit DMA, so attempt to set dma mask
  2131. * to 24 bits first, then 32 bits (playback only) if that fails.
  2132. */
  2133. if (pci_set_dma_mask(pcidev, 0x00ffffff) &&
  2134. pci_set_dma_mask(pcidev, DMA_32BIT_MASK)) {
  2135. printk(KERN_WARNING "solo1: architecture does not support 24bit or 32bit PCI busmaster DMA\n");
  2136. return -ENODEV;
  2137. }
  2138. if (!(s = kmalloc(sizeof(struct solo1_state), GFP_KERNEL))) {
  2139. printk(KERN_WARNING "solo1: out of memory\n");
  2140. return -ENOMEM;
  2141. }
  2142. memset(s, 0, sizeof(struct solo1_state));
  2143. init_waitqueue_head(&s->dma_adc.wait);
  2144. init_waitqueue_head(&s->dma_dac.wait);
  2145. init_waitqueue_head(&s->open_wait);
  2146. init_waitqueue_head(&s->midi.iwait);
  2147. init_waitqueue_head(&s->midi.owait);
  2148. init_MUTEX(&s->open_sem);
  2149. spin_lock_init(&s->lock);
  2150. s->magic = SOLO1_MAGIC;
  2151. s->dev = pcidev;
  2152. s->iobase = pci_resource_start(pcidev, 0);
  2153. s->sbbase = pci_resource_start(pcidev, 1);
  2154. s->vcbase = pci_resource_start(pcidev, 2);
  2155. s->ddmabase = s->vcbase + DDMABASE_OFFSET;
  2156. s->mpubase = pci_resource_start(pcidev, 3);
  2157. gpio = pci_resource_start(pcidev, 4);
  2158. s->irq = pcidev->irq;
  2159. ret = -EBUSY;
  2160. if (!request_region(s->iobase, IOBASE_EXTENT, "ESS Solo1")) {
  2161. printk(KERN_ERR "solo1: io ports in use\n");
  2162. goto err_region1;
  2163. }
  2164. if (!request_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT, "ESS Solo1")) {
  2165. printk(KERN_ERR "solo1: io ports in use\n");
  2166. goto err_region2;
  2167. }
  2168. if (!request_region(s->ddmabase, DDMABASE_EXTENT, "ESS Solo1")) {
  2169. printk(KERN_ERR "solo1: io ports in use\n");
  2170. goto err_region3;
  2171. }
  2172. if (!request_region(s->mpubase, MPUBASE_EXTENT, "ESS Solo1")) {
  2173. printk(KERN_ERR "solo1: io ports in use\n");
  2174. goto err_region4;
  2175. }
  2176. if ((ret=request_irq(s->irq,solo1_interrupt,SA_SHIRQ,"ESS Solo1",s))) {
  2177. printk(KERN_ERR "solo1: irq %u in use\n", s->irq);
  2178. goto err_irq;
  2179. }
  2180. /* register devices */
  2181. if ((s->dev_audio = register_sound_dsp(&solo1_audio_fops, -1)) < 0) {
  2182. ret = s->dev_audio;
  2183. goto err_dev1;
  2184. }
  2185. if ((s->dev_mixer = register_sound_mixer(&solo1_mixer_fops, -1)) < 0) {
  2186. ret = s->dev_mixer;
  2187. goto err_dev2;
  2188. }
  2189. if ((s->dev_midi = register_sound_midi(&solo1_midi_fops, -1)) < 0) {
  2190. ret = s->dev_midi;
  2191. goto err_dev3;
  2192. }
  2193. if ((s->dev_dmfm = register_sound_special(&solo1_dmfm_fops, 15 /* ?? */)) < 0) {
  2194. ret = s->dev_dmfm;
  2195. goto err_dev4;
  2196. }
  2197. if (setup_solo1(s)) {
  2198. ret = -EIO;
  2199. goto err;
  2200. }
  2201. /* register gameport */
  2202. solo1_register_gameport(s, gpio);
  2203. /* store it in the driver field */
  2204. pci_set_drvdata(pcidev, s);
  2205. return 0;
  2206. err:
  2207. unregister_sound_special(s->dev_dmfm);
  2208. err_dev4:
  2209. unregister_sound_midi(s->dev_midi);
  2210. err_dev3:
  2211. unregister_sound_mixer(s->dev_mixer);
  2212. err_dev2:
  2213. unregister_sound_dsp(s->dev_audio);
  2214. err_dev1:
  2215. printk(KERN_ERR "solo1: initialisation error\n");
  2216. free_irq(s->irq, s);
  2217. err_irq:
  2218. release_region(s->mpubase, MPUBASE_EXTENT);
  2219. err_region4:
  2220. release_region(s->ddmabase, DDMABASE_EXTENT);
  2221. err_region3:
  2222. release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT);
  2223. err_region2:
  2224. release_region(s->iobase, IOBASE_EXTENT);
  2225. err_region1:
  2226. kfree(s);
  2227. return ret;
  2228. }
  2229. static void __devexit solo1_remove(struct pci_dev *dev)
  2230. {
  2231. struct solo1_state *s = pci_get_drvdata(dev);
  2232. if (!s)
  2233. return;
  2234. /* stop DMA controller */
  2235. outb(0, s->iobase+6);
  2236. outb(0, s->ddmabase+0xd); /* DMA master clear */
  2237. outb(3, s->sbbase+6); /* reset sequencer and FIFO */
  2238. synchronize_irq(s->irq);
  2239. pci_write_config_word(s->dev, 0x60, 0); /* turn off DDMA controller address space */
  2240. free_irq(s->irq, s);
  2241. if (s->gameport) {
  2242. int gpio = s->gameport->io;
  2243. gameport_unregister_port(s->gameport);
  2244. release_region(gpio, GAMEPORT_EXTENT);
  2245. }
  2246. release_region(s->iobase, IOBASE_EXTENT);
  2247. release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT);
  2248. release_region(s->ddmabase, DDMABASE_EXTENT);
  2249. release_region(s->mpubase, MPUBASE_EXTENT);
  2250. unregister_sound_dsp(s->dev_audio);
  2251. unregister_sound_mixer(s->dev_mixer);
  2252. unregister_sound_midi(s->dev_midi);
  2253. unregister_sound_special(s->dev_dmfm);
  2254. kfree(s);
  2255. pci_set_drvdata(dev, NULL);
  2256. }
  2257. static struct pci_device_id id_table[] = {
  2258. { PCI_VENDOR_ID_ESS, PCI_DEVICE_ID_ESS_SOLO1, PCI_ANY_ID, PCI_ANY_ID, 0, 0 },
  2259. { 0, }
  2260. };
  2261. MODULE_DEVICE_TABLE(pci, id_table);
  2262. static struct pci_driver solo1_driver = {
  2263. .name = "ESS Solo1",
  2264. .id_table = id_table,
  2265. .probe = solo1_probe,
  2266. .remove = __devexit_p(solo1_remove),
  2267. .suspend = solo1_suspend,
  2268. .resume = solo1_resume,
  2269. };
  2270. static int __init init_solo1(void)
  2271. {
  2272. printk(KERN_INFO "solo1: version v0.20 time " __TIME__ " " __DATE__ "\n");
  2273. return pci_register_driver(&solo1_driver);
  2274. }
  2275. /* --------------------------------------------------------------------- */
  2276. MODULE_AUTHOR("Thomas M. Sailer, sailer@ife.ee.ethz.ch, hb9jnx@hb9w.che.eu");
  2277. MODULE_DESCRIPTION("ESS Solo1 Driver");
  2278. MODULE_LICENSE("GPL");
  2279. static void __exit cleanup_solo1(void)
  2280. {
  2281. printk(KERN_INFO "solo1: unloading\n");
  2282. pci_unregister_driver(&solo1_driver);
  2283. }
  2284. /* --------------------------------------------------------------------- */
  2285. module_init(init_solo1);
  2286. module_exit(cleanup_solo1);