esssolo1.c 72 KB

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