1. 22 11月, 2010 2 次提交
    • A
      ALSA: azt3328: period bug fix (for PA), add missing ACK on stop timer · 78ac07b0
      Andreas Mohr 提交于
      . Fix PulseAudio "ALSA driver bug" issue
        (if we have two alternated areas within a 64k DMA buffer, then max
        period size should obviously be 32k only).
        Back references:
         http://pulseaudio.org/wiki/AlsaIssues
         http://fedoraproject.org/wiki/Features/GlitchFreeAudio
      . In stop timer function, need to supply ACK in the timer control byte.
      . Minor log output correction
      
      When I did my first PA testing recently, the period size bug resulted
      in quite precisely observeable half-period-based playback distortion.
      
      PA-based operation is quite a bit more underrun-prone (despite its
      zero-copy optimizations etc.) than raw ALSA with this rather spartan
      sound hardware implementation on my puny Athlon.
      
      Note that even with this patch, azt3328 still doesn't work for both
      cases yet, PA tsched=0 and tsched
      (on tsched=0 it will playback tiny fragments of periods, leading to tiny
      stuttering sounds with some pauses in between, whereas with
      timer-scheduled operation playback works fine - minus some quite increased
      underrun trouble on PA vs. ALSA, that is).
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      78ac07b0
    • A
      ALSA: azt3328: period bug fix (for PA), add missing ACK on stop timer · 7974150c
      Andreas Mohr 提交于
      . Fix PulseAudio "ALSA driver bug" issue
        (if we have two alternated areas within a 64k DMA buffer, then max
        period size should obviously be 32k only).
        Back references:
         http://pulseaudio.org/wiki/AlsaIssues
         http://fedoraproject.org/wiki/Features/GlitchFreeAudio
      . In stop timer function, need to supply ACK in the timer control byte.
      . Minor log output correction
      
      When I did my first PA testing recently, the period size bug resulted
      in quite precisely observeable half-period-based playback distortion.
      
      PA-based operation is quite a bit more underrun-prone (despite its
      zero-copy optimizations etc.) than raw ALSA with this rather spartan
      sound hardware implementation on my puny Athlon.
      
      Note that even with this patch, azt3328 still doesn't work for both
      cases yet, PA tsched=0 and tsched
      (on tsched=0 it will playback tiny fragments of periods, leading to tiny
      stuttering sounds with some pauses in between, whereas with
      timer-scheduled operation playback works fine - minus some quite increased
      underrun trouble on PA vs. ALSA, that is).
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      7974150c
  2. 09 2月, 2010 1 次提交
  3. 05 11月, 2009 1 次提交
  4. 15 7月, 2009 1 次提交
    • A
      ALSA: azt3328: fix previous breakage, improve suspend, cleanups · 78df617a
      Andreas Mohr 提交于
      - fix my previous codec activity breakage (_non-warned_ variable assignment
        issue)
      - convert suspend/resume to 32bit I/O access (I/O is painful; to improve
        suspend/resume performance)
      - change DEBUG_PLAY_REC to DEBUG_CODEC for consistency
      - printk cleanup
      - some logging improvements
      - minor cleanup/improvements
      
      The variable assignment issue above was a conditional assignment to the
      call_function variable (this ended with the non-preinitialized variable
      not getting assigned in some cases, thus a dangling stack value, yet gcc 4.3.3
      unbelievably did _NOT_ warn about it in this case!!),
      needed to change this into _always_ assigning the check result.
      Practical result of this bug was that when shutting down
      _either_ playback or capture, _both_ streams dropped dead :P
      
      Tested, working (plus resume) and checkpatch.pl:ed on 2.6.30-rc5,
      applies cleanly to 2.6.30 proper with my previous (committed)
      patches applied.
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      78df617a
  5. 06 7月, 2009 1 次提交
    • A
      ALSA: azt3328: large codec cleanup, add I2S port etc. · dfbf9511
      Andreas Mohr 提交于
      - fully separate codec I/O port handling, enabling the use of a single
        function each for all codecs (playback, capture, I2S out)
      - add a new separate pcm for I2S out port (UNTESTED, no I2S DAC
        available yet)
      - switch gameport to low frequency while idle, to try to reduce noise/power
      - improve snd_azf3328_codec_setdmaa() calculation
      - minor variable type cleanup (u16, bool etc.)
      - add some doc updates (help those lost Windows users, debug help, ...)
      
      Note that due to the large cleanup aspect of the codec I/O change,
      I was able to fit everything including all improvements into the
      same binary size!! (a measly 10 bytes more or so)
      
      This should now be the almost last patch to this driver
      (minus some possible kernel clocksource patch and x86_64 fixes or so).
      I just felt like taking a break from the usual stuff and wanted to
      get this driver's structure finished, and it's rather clean now...
      
      Tested, working and checkpatch.pl:ed on 2.6.30-rc5,
      applies cleanly to 2.6.30 proper.
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      dfbf9511
  6. 07 4月, 2009 1 次提交
  7. 05 2月, 2009 1 次提交
  8. 12 1月, 2009 1 次提交
  9. 13 8月, 2008 1 次提交
  10. 26 6月, 2008 1 次提交
    • A
      ALSA: PCI168 snd-azt3328: some more fixups · 627d3e7a
      Andreas Mohr 提交于
      - fix problem with codec register 0x6a being write-only
        by adding a software shadow register
        (caused annoying noise after module loading due to _toggling_
        between gameport and audio bits instead of configuring them properly)
      - rename several "Wave" mixer controls to "PCM", since this is
        what Wine and several other apps are looking for (IOW, _requiring_)
        and this is what AC97 specs use as naming, too,
        thus I'd guess it's what these controls are
      - cleanup, small optimizations
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      Signed-off-by: NJaroslav Kysela <perex@perex.cz>
      627d3e7a
  11. 19 5月, 2008 1 次提交
    • A
      [ALSA] PCI168 snd-azt3328 Linux driver: another huge update · 02330fba
      Andreas Mohr 提交于
      - figured out 'Digital(ly) Enhanced Game Port' functionality,
        implemented support for it (eliminating gameport polling overhead)
      - removed optional joystick activation, gameport now enabled unconditionally,
        since we now support it via the PCI I/O space, not via conflict-prone
        legacy I/O (which I was thus able to DISABLE now)!
      - fix playback bug (a muted wave output would get unmuted upon start of
        playback, of course this is not what we want, thus remember mute state)
      - implement partial power management: when idle, lower clock rate and disable
        codec (reduced noise!), and disable gameport circuit when unused
      - instantiate OPL3 timer, too
      - much better implementation of snd_azf3328_mixer_write_volume_gradually()
      - slightly optimized interrupt handling
      - lots of cleanup
      
      This time, I also found a way to verify proper OPL3 operation
      via MIDI file playback (emulation via synth hardware).
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      Signed-off-by: NJaroslav Kysela <perex@perex.cz>
      02330fba
  12. 24 4月, 2008 2 次提交
  13. 01 2月, 2008 1 次提交
    • T
      [ALSA] Remove sound/driver.h · 9004acc7
      Takashi Iwai 提交于
      This header file exists only for some hacks to adapt alsa-driver
      tree.  It's useless for building in the kernel.  Let's move a few
      lines in it to sound/core.h and remove it.
      With this patch, sound/driver.h isn't removed but has just a single
      compile warning to include it.  This should be really killed in
      future.
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      Signed-off-by: NJaroslav Kysela <perex@perex.cz>
      9004acc7
  14. 11 5月, 2007 2 次提交
  15. 20 12月, 2006 1 次提交
  16. 22 10月, 2006 1 次提交
  17. 05 10月, 2006 1 次提交
    • D
      IRQ: Maintain regs pointer globally rather than passing to IRQ handlers · 7d12e780
      David Howells 提交于
      Maintain a per-CPU global "struct pt_regs *" variable which can be used instead
      of passing regs around manually through all ~1800 interrupt handlers in the
      Linux kernel.
      
      The regs pointer is used in few places, but it potentially costs both stack
      space and code to pass it around.  On the FRV arch, removing the regs parameter
      from all the genirq function results in a 20% speed up of the IRQ exit path
      (ie: from leaving timer_interrupt() to leaving do_IRQ()).
      
      Where appropriate, an arch may override the generic storage facility and do
      something different with the variable.  On FRV, for instance, the address is
      maintained in GR28 at all times inside the kernel as part of general exception
      handling.
      
      Having looked over the code, it appears that the parameter may be handed down
      through up to twenty or so layers of functions.  Consider a USB character
      device attached to a USB hub, attached to a USB controller that posts its
      interrupts through a cascaded auxiliary interrupt controller.  A character
      device driver may want to pass regs to the sysrq handler through the input
      layer which adds another few layers of parameter passing.
      
      I've build this code with allyesconfig for x86_64 and i386.  I've runtested the
      main part of the code on FRV and i386, though I can't test most of the drivers.
      I've also done partial conversion for powerpc and MIPS - these at least compile
      with minimal configurations.
      
      This will affect all archs.  Mostly the changes should be relatively easy.
      Take do_IRQ(), store the regs pointer at the beginning, saving the old one:
      
      	struct pt_regs *old_regs = set_irq_regs(regs);
      
      And put the old one back at the end:
      
      	set_irq_regs(old_regs);
      
      Don't pass regs through to generic_handle_irq() or __do_IRQ().
      
      In timer_interrupt(), this sort of change will be necessary:
      
      	-	update_process_times(user_mode(regs));
      	-	profile_tick(CPU_PROFILING, regs);
      	+	update_process_times(user_mode(get_irq_regs()));
      	+	profile_tick(CPU_PROFILING);
      
      I'd like to move update_process_times()'s use of get_irq_regs() into itself,
      except that i386, alone of the archs, uses something other than user_mode().
      
      Some notes on the interrupt handling in the drivers:
      
       (*) input_dev() is now gone entirely.  The regs pointer is no longer stored in
           the input_dev struct.
      
       (*) finish_unlinks() in drivers/usb/host/ohci-q.c needs checking.  It does
           something different depending on whether it's been supplied with a regs
           pointer or not.
      
       (*) Various IRQ handler function pointers have been moved to type
           irq_handler_t.
      Signed-Off-By: NDavid Howells <dhowells@redhat.com>
      (cherry picked from 1b16e7ac850969f38b375e511e3fa2f474a33867 commit)
      7d12e780
  18. 13 7月, 2006 1 次提交
  19. 03 7月, 2006 1 次提交
  20. 23 6月, 2006 4 次提交
  21. 28 4月, 2006 1 次提交
  22. 29 3月, 2006 1 次提交
  23. 03 1月, 2006 2 次提交
  24. 11 11月, 2005 1 次提交
  25. 04 11月, 2005 3 次提交
    • A
      [ALSA] AZT3328 driver update · d91c64c8
      Andreas Mohr 提交于
      Modules: AZT3328 driver
      
      this is now an even much more reworked patch (#3) for my azt3328.c ALSA driver.
      IOW I spent another 4 evenings to get the sequencer timer to work properly
      (my head is still hurting) and do lots of other cleanups.
      
      Note that despite the extensive sequencer timer additions, the driver object
      is still only 2kB bigger than the previous version, due to those many
      optimizations...
      
      Changes in version #3:
      - fully working ALSA sequencer timer support for the card's 1024000Hz
        DirectX timer (downscaling adjustable via seqtimer_scaling module param)
      - an insane amount of code optimizations
      - many, many cleanups
      
      Changes in version #2:
      - FOUND the 1us DirectX timer area (yay!), made the code respect it
      properly
      - renamed some 'weird' mixer control names according to ControlNames.txt
      - cleanup unneeded debug messages, reformatting
      - improved I/O register documentation
      - constified many more structs
      
      Changes in version #1:
      - improves/fixes some fatal playback/recording interaction
      - improves IRQ handler performance (and actually fixes some weird code)
      - coalesces some I/O accesses
      - slightly improves I/O interface documentation
      - improves/fixes logging
      - defines out some less important debug code
      - constifies some data
      Signed-off-by: NAndreas Mohr <andi@lisas.de>
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      d91c64c8
    • T
      [ALSA] Add missing KERN_* suffix to printk · 99b359ba
      Takashi Iwai 提交于
      Add missing KERN_* suffix to printk.
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      99b359ba
    • T
      [ALSA] Remove vmalloc wrapper, kfree_nocheck() · b1d5776d
      Takashi Iwai 提交于
      - Remove vmalloc wrapper
      - Add release_and_free_resource() to remove kfree_nocheck() from each driver
        and simplify the code
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      b1d5776d
  26. 12 9月, 2005 2 次提交
    • C
      [ALSA] set owner field in struct pci_driver · 3bcd4649
      Clemens Ladisch 提交于
      AD1889 driver,ALS4000 driver,ATIIXP driver,ATIIXP-modem driver
      AZT3328 driver,BT87x driver,CMIPCI driver,CS4281 driver
      ENS1370/1+ driver,ES1938 driver,ES1968 driver,FM801 driver
      Intel8x0 driver,Intel8x0-modem driver,Maestro3 driver,RME32 driver
      RME96 driver,SonicVibes driver,VIA82xx driver,VIA82xx-modem driver
      ALI5451 driver,au88x0 driver,CS46xx driver,EMU10K1/EMU10K2 driver
      HDA Intel driver,ICE1712 driver,ICE1724 driver,KORG1212 driver
      MIXART driver,NM256 driver,RME HDSP driver,RME9652 driver
      Trident driver,Digigram VX222 driver,YMFPCI driver
      Set the module owner field in each driver's struct pci_driver to get
      the driver symlink in the sysfs device directory.
      Signed-off-by: NClemens Ladisch <clemens@ladisch.de>
      3bcd4649
    • T
      [ALSA] Replace with kzalloc() - pci stuff · e560d8d8
      Takashi Iwai 提交于
      AD1889 driver,ATIIXP driver,ATIIXP-modem driver,AZT3328 driver
      BT87x driver,CMIPCI driver,CS4281 driver,ENS1370/1+ driver
      ES1938 driver,ES1968 driver,FM801 driver,Intel8x0 driver
      Intel8x0-modem driver,Maestro3 driver,SonicVibes driver,VIA82xx driver
      VIA82xx-modem driver,AC97 Codec,AK4531 codec,au88x0 driver
      CA0106 driver,CS46xx driver,EMU10K1/EMU10K2 driver,HDA Codec driver
      HDA generic driver,HDA Intel driver,ICE1712 driver,ICE1724 driver
      KORG1212 driver,MIXART driver,NM256 driver,Trident driver,YMFPCI driver
      Replace kcalloc(1,..) with kzalloc().
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      e560d8d8
  27. 29 5月, 2005 1 次提交
    • T
      [ALSA] Replace pci_module_init() with pci_register_driver() · 01d25d46
      Takashi Iwai 提交于
      Documentation,ALS4000 driver,ATIIXP driver,ATIIXP-modem driver
      AZT3328 driver,BT87x driver,CMIPCI driver,CS4281 driver
      ENS1370/1+ driver,ES1938 driver,ES1968 driver,FM801 driver
      Intel8x0 driver,Intel8x0-modem driver,Maestro3 driver,RME32 driver
      RME96 driver,SonicVibes driver,VIA82xx driver,VIA82xx-modem driver
      ALI5451 driver,au88x0 driver,CA0106 driver,CS46xx driver
      EMU10K1/EMU10K2 driver,HDA Intel driver,ICE1712 driver,ICE1724 driver
      KORG1212 driver,MIXART driver,NM256 driver,RME HDSP driver
      RME9652 driver,Trident driver,Digigram VX222 driver,YMFPCI driver
      Replace the obsolete pci_module_init() with pci_register_driver().
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      01d25d46
  28. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4