亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sb_dsp.c

?? LINUX1.0源代碼,代碼條理清晰
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
 * sound/sb_dsp.c
 * 
 * The low level driver for the SoundBlaster DSP chip.
 * 
 * Copyright by Hannu Savolainen 1993
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met: 1. Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer. 2.
 * Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 * 
 */

#include "sound_config.h"

#if defined(CONFIGURE_SOUNDCARD) && !defined(EXCLUDE_SB)

#include "sb.h"
#include "sb_mixer.h"
#undef SB_TEST_IRQ

int      sbc_base = 0;
static int      sbc_irq = 0;

/*
 * The DSP channel can be used either for input or output. Variable
 * 'sb_irq_mode' will be set when the program calls read or write first time
 * after open. Current version doesn't support mode changes without closing
 * and reopening the device. Support for this feature may be implemented in a
 * future version of this driver.
 */

int      sb_dsp_ok = 0;	/* Set to 1 after successful initialization */
static int      midi_disabled = 0;
int      sb_dsp_highspeed = 0;
static int	major=1, minor=0;	/* DSP version */
static int	dsp_stereo = 0;
static int      dsp_current_speed = DSP_DEFAULT_SPEED;
static int      sb16 = 0;
static int	irq_verified = 0;

int      sb_midi_mode = NORMAL_MIDI;
int      sb_midi_busy = 0;	/* 1 if the process has output to MIDI */
int      sb_dsp_busy = 0;

volatile int sb_irq_mode = IMODE_NONE;	/* IMODE_INPUT, IMODE_OUTPUT
						 * or IMODE_NONE */
static volatile int irq_ok = 0;

int      sb_dsp_model = 1;	/* 1=SB, 2=SB Pro */
int      sb_duplex_midi = 0;
static int      my_dev = 0;

volatile int sb_intr_active = 0;

static int      dsp_speed (int);
static int      dsp_set_stereo (int mode);
int      sb_dsp_command (unsigned char val);

#if !defined(EXCLUDE_MIDI) || !defined(EXCLUDE_AUDIO)

/* Common code for the midi and pcm functions */

int
sb_dsp_command (unsigned char val)
{
  int             i, limit;

  limit = GET_TIME () + 10;	/* The timeout is 0.1 secods */

  /*
   * Note! the i<500000 is an emergency exit. The sb_dsp_command() is sometimes
   * called while interrupts are disabled. This means that the timer is
   * disabled also. However the timeout situation is a abnormal condition.
   * Normally the DSP should be ready to accept commands after just couple of
   * loops.
   */

  for (i = 0; i < 500000 && GET_TIME () < limit; i++)
    {
      if ((INB (DSP_STATUS) & 0x80) == 0)
	{
	  OUTB (val, DSP_COMMAND);
	  return 1;
	}
    }

  printk ("SoundBlaster: DSP Command(%x) Timeout.\n", val);
  printk ("IRQ conflict???\n");
  return 0;
}

void
sbintr (int unit)
{
  int             status, data;

#ifndef EXCLUDE_SBPRO
  if (sb16)
    {
      unsigned char   src = sb_getmixer (IRQ_STAT);	/* Interrupt source register */

#ifndef EXCLUDE_SB16
      if (src & 3) sb16_dsp_interrupt(unit);

#ifndef EXCLUDE_MIDI
      if (src & 4) sb16midiintr (unit);			/* MPU401 interrupt */
#endif

#endif

      if (!(src & 1))
	return;			/* Not a DSP interupt */
    }
#endif

  status = INB (DSP_DATA_AVAIL);/* Clear interrupt */

  if (sb_intr_active)
    switch (sb_irq_mode)
      {
      case IMODE_OUTPUT:
	sb_intr_active = 0;
	DMAbuf_outputintr (my_dev, 1);
	break;

      case IMODE_INPUT:
	sb_intr_active = 0;
	DMAbuf_inputintr (my_dev);
	/* A complete buffer has been input. Let's start new one */
	break;

      case IMODE_INIT:
	sb_intr_active = 0;
	irq_ok = 1;
	break;

      case IMODE_MIDI:
	printk ("+");
	data = INB (DSP_READ);
	printk ("%x", data);

	break;

      default:
	printk ("SoundBlaster: Unexpected interrupt\n");
      }
}

static int sb_irq_usecount = 0;

int
sb_get_irq(void)
{
	int ok;

	if (!sb_irq_usecount)
	  if ((ok=snd_set_irq_handler(sbc_irq, sbintr))<0) return ok;

	sb_irq_usecount++;

	return 0; 
}

void 
sb_free_irq(void)
{
	if (!sb_irq_usecount) return;

	sb_irq_usecount--;

	if (!sb_irq_usecount) snd_release_irq(sbc_irq);
}

int
sb_reset_dsp (void)
{
  int             loopc;

  OUTB (1, DSP_RESET);
  tenmicrosec ();
  OUTB (0, DSP_RESET);
  tenmicrosec ();
  tenmicrosec ();
  tenmicrosec ();

  for (loopc = 0; loopc < 1000 && !(INB (DSP_DATA_AVAIL) & 0x80); loopc++);	/* Wait for data
										 * available status */

  if (INB (DSP_READ) != 0xAA)
    return 0;			/* Sorry */

  return 1;
}

#endif

#ifndef EXCLUDE_AUDIO

static void
dsp_speaker (char state)
{
  if (state)
    sb_dsp_command (DSP_CMD_SPKON);
  else
    sb_dsp_command (DSP_CMD_SPKOFF);
}

static int
dsp_speed (int speed)
{
  unsigned char   tconst;
  unsigned long   flags;

  if (speed < 4000)
    speed = 4000;

  if (speed > 44100)
    speed = 44100;		/* Invalid speed */

  if (sb_dsp_model == 1 && speed > 22050)
    speed = 22050;
  /* SB Classic doesn't support higher speed */


  if (dsp_stereo && speed > 22050)
    speed = 22050;
  /* Max. stereo speed is 22050 */

  if ((speed > 22050) && sb_midi_busy)
    {
      printk ("SB Warning: High speed DSP not possible simultaneously with MIDI output\n");
      speed = 22050;
    }

  if (dsp_stereo)
    speed *= 2;

  /* Now the speed should be valid */

  if (speed > 22050)
    {				/* High speed mode */
      int tmp;

      tconst = (unsigned char) ((65536 - 
      				((256000000+speed/2) / speed)) >> 8);
      sb_dsp_highspeed = 1;

      DISABLE_INTR (flags);
      if (sb_dsp_command (0x40))
	sb_dsp_command (tconst);
      RESTORE_INTR (flags);

      tmp = 65536 - (tconst << 8);
      speed = (256000000+tmp/2) / tmp;
    }
  else
    {
      int tmp;

      sb_dsp_highspeed = 0;
      tconst = (256 - ((1000000+speed/2) / speed)) & 0xff;

      DISABLE_INTR (flags);
      if (sb_dsp_command (0x40))	/* Set time constant */
	sb_dsp_command (tconst);
      RESTORE_INTR (flags);

      tmp = 256 - tconst;
      speed = (1000000+tmp/2) / tmp;
    }

  if (dsp_stereo)
    speed /= 2;

  dsp_current_speed = speed;
  return speed;
}

static int
dsp_set_stereo (int mode)
{
  dsp_stereo = 0;

#ifdef EXCLUDE_SBPRO
  return 0;
#else
  if (sb_dsp_model == 1 || sb16)
    return 0;			/* Sorry no stereo */

  if (mode && sb_midi_busy)
    {
      printk ("SB Warning: Stereo DSP not possible simultaneously with MIDI output\n");
      return 0;
    }

  dsp_stereo = !!mode;
  return dsp_stereo;
#endif
}

static void
sb_dsp_output_block (int dev, unsigned long buf, int count, 
		     int intrflag, int restart_dma)
{
  unsigned long   flags;

  if (!sb_irq_mode)
    dsp_speaker (ON);

  sb_irq_mode = IMODE_OUTPUT;
  DMAbuf_start_dma (dev, buf, count, DMA_MODE_WRITE);

  if (sound_dsp_dmachan[dev] > 3)
    count >>= 1;
  count--;

  if (sb_dsp_highspeed)
    {
      DISABLE_INTR (flags);
      if (sb_dsp_command (0x48))	/* High speed size */
	{
	  sb_dsp_command ((unsigned char)(count & 0xff));
	  sb_dsp_command ((unsigned char)((count >> 8) & 0xff));
	  sb_dsp_command (0x91);	/* High speed 8 bit DAC */
	}
      else
	printk ("SB Error: Unable to start (high speed) DAC\n");
      RESTORE_INTR (flags);
    }
  else
    {
      DISABLE_INTR (flags);
      if (sb_dsp_command (0x14))	/* 8-bit DAC (DMA) */
	{
	  sb_dsp_command ((unsigned char)(count & 0xff));
	  sb_dsp_command ((unsigned char)((count >> 8) & 0xff));
	}
      else
	printk ("SB Error: Unable to start DAC\n");
      RESTORE_INTR (flags);
    }
  sb_intr_active = 1;
}

static void
sb_dsp_start_input (int dev, unsigned long buf, int count, int intrflag,
		    int restart_dma)
{
  /* Start a DMA input to the buffer pointed by dmaqtail */

  unsigned long   flags;

  if (!sb_irq_mode)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区欧美日韩| 综合色中文字幕| 久久激情五月婷婷| 精品国产免费一区二区三区香蕉| 麻豆精品一区二区av白丝在线| 日韩一区二区三区av| 极品美女销魂一区二区三区免费| 2欧美一区二区三区在线观看视频| 国产一区二区三区综合| 国产精品成人免费| 欧美四级电影在线观看| 美女www一区二区| 欧美激情一区不卡| 欧美性高清videossexo| 蜜臀a∨国产成人精品| 国产亚洲精品久| 91黄色免费看| 韩国欧美国产一区| 亚洲色图在线播放| 日韩欧美国产综合一区| 国产乱码一区二区三区| 亚洲欧美日韩国产手机在线| 911国产精品| 国产很黄免费观看久久| 亚洲欧美一区二区三区孕妇| 欧美精品第1页| 国产成人免费9x9x人网站视频| 亚洲综合视频网| 精品国产91久久久久久久妲己| av电影一区二区| 日韩avvvv在线播放| 中文一区二区在线观看| 欧美精品久久99久久在免费线| 国产成人av一区二区| 日韩电影免费一区| 亚洲色欲色欲www| 久久色视频免费观看| 欧美日韩在线不卡| 99视频有精品| 国产乱对白刺激视频不卡| 亚洲午夜激情av| 中文字幕一区二区三区乱码在线| 在线成人午夜影院| 972aa.com艺术欧美| 精品综合久久久久久8888| 亚洲线精品一区二区三区| 国产日韩亚洲欧美综合| 日韩丝袜情趣美女图片| 欧美亚洲一区三区| av高清久久久| 成人一区二区视频| 久久99精品国产| 日日摸夜夜添夜夜添国产精品| 成人免费在线视频观看| 久久久影院官网| 91精品欧美久久久久久动漫| 91美女蜜桃在线| 成人黄色小视频| 国产精品一卡二卡在线观看| 蜜桃一区二区三区四区| 亚洲国产精品久久久久秋霞影院 | 4438成人网| 一本色道久久加勒比精品 | 93久久精品日日躁夜夜躁欧美| 国产真实精品久久二三区| 日韩精品欧美精品| 偷窥少妇高潮呻吟av久久免费| 亚洲色图欧美偷拍| 亚洲欧美日韩精品久久久久| 国产精品高潮久久久久无| 久久久不卡网国产精品二区| 欧美一级精品在线| 日韩欧美成人午夜| 日韩午夜小视频| 日韩精品一区二| 久久影院电视剧免费观看| 精品欧美久久久| 久久亚洲私人国产精品va媚药| 欧美精品一区视频| 久久综合色播五月| 国产调教视频一区| 国产精品美女久久久久高潮| 欧美国产1区2区| 一区二区中文视频| 一区二区三区欧美日| 性做久久久久久免费观看| 午夜精品免费在线观看| 日产精品久久久久久久性色| 欧美aaaaaa午夜精品| 国产一区二区三区av电影 | 在线一区二区三区做爰视频网站| 在线国产亚洲欧美| 欧美理论在线播放| 日韩限制级电影在线观看| 久久免费精品国产久精品久久久久| 久久久久9999亚洲精品| 国产女同互慰高潮91漫画| 中文字幕一区二区不卡| 一区二区三区不卡在线观看| 首页国产丝袜综合| 国产精品一区二区在线播放| eeuss影院一区二区三区| 欧美日韩专区在线| 日韩精品中文字幕一区二区三区 | 7777精品伊人久久久大香线蕉的 | 韩国精品在线观看| 成人a级免费电影| 欧美日韩精品免费观看视频| 777久久久精品| 亚洲国产高清不卡| 亚洲国产成人va在线观看天堂| 日本中文字幕一区| 成人av在线一区二区| 欧美视频日韩视频在线观看| 亚洲精品一线二线三线| 一区二区三区在线免费观看 | 亚洲国产综合91精品麻豆| 久久电影网电视剧免费观看| 成人h动漫精品一区二区| 69久久夜色精品国产69蝌蚪网| 国产欧美一二三区| 日日夜夜一区二区| 91最新地址在线播放| 欧美大片国产精品| 亚洲最大成人综合| 国产不卡一区视频| 欧美一区二区二区| 一级特黄大欧美久久久| 国产精品888| 日韩一区二区精品葵司在线| 亚洲特黄一级片| 国产精品一级黄| 欧美一级片在线观看| 亚洲蜜桃精久久久久久久| 国产一区二区三区四| 欧美高清www午色夜在线视频| 国产精品嫩草影院av蜜臀| 精品在线你懂的| 91精品国产一区二区人妖| 亚洲黄色在线视频| 国产精品一区二区在线观看网站| 欧美日本乱大交xxxxx| 中文字幕在线不卡| 国产美女娇喘av呻吟久久| 日韩一区二区三区视频在线观看| 一区二区三区免费网站| av不卡在线观看| 亚洲国产精品v| 国产成人精品在线看| 精品国产a毛片| 精品一区二区在线播放| 91精品黄色片免费大全| 亚洲网友自拍偷拍| 日本韩国一区二区三区视频| 中文一区二区在线观看| 国产.欧美.日韩| 国产亚洲精品资源在线26u| 精品一区二区在线观看| 欧美大片日本大片免费观看| 日本视频一区二区三区| 欧美猛男男办公室激情| 亚洲成人免费影院| 欧美日韩国产一二三| 婷婷成人综合网| 制服视频三区第一页精品| 日韩黄色免费电影| 91精品国产综合久久婷婷香蕉| 亚洲成人动漫精品| 欧美日韩极品在线观看一区| 亚洲小说春色综合另类电影| 欧美网站大全在线观看| 图片区日韩欧美亚洲| 欧美一二三区在线观看| 国内偷窥港台综合视频在线播放| 久久综合999| 不卡电影免费在线播放一区| 国产精品国产三级国产普通话三级| va亚洲va日韩不卡在线观看| 亚洲激情一二三区| 欧美精品少妇一区二区三区| 日韩综合小视频| 精品国产乱码久久久久久久| 成人小视频免费在线观看| 国产精品午夜在线| 在线观看中文字幕不卡| 天堂成人国产精品一区| 欧美大片免费久久精品三p| 国产成人精品免费网站| 中文字幕一区二区三区在线不卡 | 91精品国产aⅴ一区二区| 日本一区中文字幕| 久久你懂得1024| 91伊人久久大香线蕉| 天天综合网天天综合色| 久久久激情视频| 91国产福利在线| 九九精品一区二区| 日韩毛片在线免费观看| 欧美电影一区二区三区| 成人视屏免费看|