esssolo1.c 73 KB

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