esssolo1.c 72 KB

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