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

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

?? sequencer.c

?? LINUX1.0源代碼,代碼條理清晰
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):

void
sequencer_release (int dev, struct fileinfo *file)
  {
    int             i;
    int             mode = file->mode & O_ACCMODE;

    dev = dev >> 4;

    DEB (printk ("sequencer_release(dev=%d)\n", dev));

    if (dev)			/* Patch manager device */
      {
	dev--;
	pmgr_release (dev);
	pmgr_present[dev] = 0;
	return;
      }

    /*
     * Wait until the queue is empty
     */

    while (!PROCESS_ABORTING (seq_sleeper, seq_sleep_flag) && qlen)
      {
	seq_sync ();
      }

    if (mode != OPEN_READ)
      seq_drain_midi_queues ();	/* Ensure the output queues are empty */
    seq_reset ();
    if (mode != OPEN_READ)
      seq_drain_midi_queues ();	/* Flush the all notes off messages */

    for (i = 0; i < num_midis; i++)
      if (midi_opened[i])
	midi_devs[i]->close (i);

    if (mode == OPEN_WRITE || mode == OPEN_READWRITE)
      for (i = 0; i < num_synths; i++)
	if (synth_open_mask & (1 << i))	/* Actually opened */
	  if (synth_devs[i])
	    synth_devs[i]->close (i);

    for (i = 0; i < num_synths; i++)
      if (pmgr_present[i])
	pmgr_inform (i, PM_E_CLOSED, 0, 0, 0, 0);

    sequencer_busy = 0;
  }

static int
seq_sync (void)
{
  if (qlen && !seq_playing && !PROCESS_ABORTING (seq_sleeper, seq_sleep_flag))
    seq_startplay ();

  if (qlen && !SOMEONE_WAITING (seq_sleeper, seq_sleep_flag))	/* Queue not empty */
    {
      DO_SLEEP (seq_sleeper, seq_sleep_flag, 0);
    }

  return qlen;
}

static void
midi_outc (int dev, unsigned char data)
{
  /*
   * NOTE! Calls sleep(). Don't call this from interrupt.
   */

  int             n;

  /* This routine sends one byte to the Midi channel. */
  /* If the output Fifo is full, it waits until there */
  /* is space in the queue */

  n = 300;			/* Timeout in jiffies */

  while (n && !midi_devs[dev]->putc (dev, data))
    {
      DO_SLEEP (seq_sleeper, seq_sleep_flag, 4);
      n--;
    }
}

static void
seq_reset (void)
{
  /*
   * NOTE! Calls sleep(). Don't call this from interrupt.
   */

  int             i, chn;

  sound_stop_timer ();

  qlen = qhead = qtail = 0;
  iqlen = iqhead = iqtail = 0;

  for (i = 0; i < num_synths; i++)
    if (synth_open_mask & (1 << i))
      if (synth_devs[i])
	synth_devs[i]->reset (i);

  for (i = 0; i < num_midis; i++)
    if (midi_written[i])	/* Midi used. Some notes may still be playing */
      {
	for (chn = 0; chn < 16; chn++)
	  {
	    midi_outc (i, 
		(unsigned char)(0xb0 + (chn & 0xff))); /* Channel msg */
	    midi_outc (i, 0x7b);/* All notes off */
	    midi_outc (i, 0);	/* Dummy parameter */
	  }

	midi_devs[i]->close (i);

	midi_written[i] = 0;
	midi_opened[i] = 0;
      }

  seq_playing = 0;

  if (SOMEONE_WAITING (seq_sleeper, seq_sleep_flag))
    printk ("Sequencer Warning: Unexpected sleeping process\n");

}

int
sequencer_ioctl (int dev, struct fileinfo *file,
		 unsigned int cmd, unsigned int arg)
{
  int             midi_dev, orig_dev;
  int             mode = file->mode & O_ACCMODE;

  orig_dev = dev = dev >> 4;

  switch (cmd)
    {

    case SNDCTL_SEQ_SYNC:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      if (mode == OPEN_READ)
	return 0;
      while (qlen && !PROCESS_ABORTING (seq_sleeper, seq_sleep_flag))
	seq_sync ();
      return 0;
      break;

    case SNDCTL_SEQ_RESET:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      seq_reset ();
      return 0;
      break;

    case SNDCTL_SEQ_TESTMIDI:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      midi_dev = IOCTL_IN (arg);
      if (midi_dev >= num_midis)
	return RET_ERROR (ENXIO);

      if (!midi_opened[midi_dev])
	{
	  int             err, mode;

	  mode = file->mode & O_ACCMODE;
	  if ((err = midi_devs[midi_dev]->open (midi_dev, mode,
						sequencer_midi_input,
						sequencer_midi_output)) < 0)
	    return err;
	}

      midi_opened[midi_dev] = 1;

      return 0;
      break;

    case SNDCTL_SEQ_GETINCOUNT:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      if (mode == OPEN_WRITE)
	return 0;
      return IOCTL_OUT (arg, iqlen);
      break;

    case SNDCTL_SEQ_GETOUTCOUNT:

      if (mode == OPEN_READ)
	return 0;
      return IOCTL_OUT (arg, SEQ_MAX_QUEUE - qlen);
      break;

    case SNDCTL_SEQ_CTRLRATE:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      /* If *arg == 0, just return the current rate */
      return IOCTL_OUT (arg, HZ);
      break;

    case SNDCTL_SEQ_RESETSAMPLES:
      dev = IOCTL_IN (arg);
      if (dev < 0 || dev >= num_synths)
	return RET_ERROR (ENXIO);

      if (!(synth_open_mask & (1 << dev)) && !orig_dev)
	return RET_ERROR (EBUSY);

      if (!orig_dev && pmgr_present[dev])
	pmgr_inform (dev, PM_E_PATCH_RESET, 0, 0, 0, 0);

      return synth_devs[dev]->ioctl (dev, cmd, arg);
      break;

    case SNDCTL_SEQ_NRSYNTHS:
      return IOCTL_OUT (arg, num_synths);
      break;

    case SNDCTL_SEQ_NRMIDIS:
      return IOCTL_OUT (arg, num_midis);
      break;

    case SNDCTL_SYNTH_MEMAVL:
      {
	int             dev = IOCTL_IN (arg);

	if (dev < 0 || dev >= num_synths)
	  return RET_ERROR (ENXIO);

	if (!(synth_open_mask & (1 << dev)) && !orig_dev)
	  return RET_ERROR (EBUSY);

	return IOCTL_OUT (arg, synth_devs[dev]->ioctl (dev, cmd, arg));
      }
      break;

    case SNDCTL_FM_4OP_ENABLE:
      {
	int             dev = IOCTL_IN (arg);

	if (dev < 0 || dev >= num_synths)
	  return RET_ERROR (ENXIO);

	if (!(synth_open_mask & (1 << dev)))
	  return RET_ERROR (ENXIO);

	synth_devs[dev]->ioctl (dev, cmd, arg);
	return 0;
      }
      break;

    case SNDCTL_SYNTH_INFO:
      {
	struct synth_info inf;
	int             dev;

	IOCTL_FROM_USER ((char *) &inf, (char *) arg, 0, sizeof (inf));
	dev = inf.device;

	if (dev < 0 || dev >= num_synths)
	  return RET_ERROR (ENXIO);

	if (!(synth_open_mask & (1 << dev)) && !orig_dev)
	  return RET_ERROR (EBUSY);

	return synth_devs[dev]->ioctl (dev, cmd, arg);
      }
      break;

    case SNDCTL_MIDI_INFO:
      {
	struct midi_info inf;
	int             dev;

	IOCTL_FROM_USER ((char *) &inf, (char *) arg, 0, sizeof (inf));
	dev = inf.device;

	if (dev < 0 || dev >= num_midis)
	  return RET_ERROR (ENXIO);

	IOCTL_TO_USER ((char *) arg, 0, (char *) &(midi_devs[dev]->info), sizeof (inf));
	return 0;
      }
      break;

    case SNDCTL_PMGR_IFACE:
      {
	struct patmgr_info *inf;
	int             dev, err;

	inf = (struct patmgr_info *) KERNEL_MALLOC (sizeof (*inf));

	IOCTL_FROM_USER ((char *) inf, (char *) arg, 0, sizeof (*inf));
	dev = inf->device;

	if (dev < 0 || dev >= num_synths)
	  {
	    KERNEL_FREE (inf);
	    return RET_ERROR (ENXIO);
	  }

	if (!synth_devs[dev]->pmgr_interface)
	  {
	    KERNEL_FREE (inf);
	    return RET_ERROR (ENXIO);
	  }

	if ((err = synth_devs[dev]->pmgr_interface (dev, inf)) == -1)
	  {
	    KERNEL_FREE (inf);
	    return err;
	  }

	IOCTL_TO_USER ((char *) arg, 0, (char *) inf, sizeof (*inf));
	KERNEL_FREE (inf);
	return 0;
      }
      break;

    case SNDCTL_PMGR_ACCESS:
      {
	struct patmgr_info *inf;
	int             dev, err;

	inf = (struct patmgr_info *) KERNEL_MALLOC (sizeof (*inf));

	IOCTL_FROM_USER ((char *) inf, (char *) arg, 0, sizeof (*inf));
	dev = inf->device;

	if (dev < 0 || dev >= num_synths)
	  {
	    KERNEL_FREE (inf);
	    return RET_ERROR (ENXIO);
	  }

	if (!pmgr_present[dev])
	  {
	    KERNEL_FREE (inf);
	    return RET_ERROR (ESRCH);
	  }

	if ((err = pmgr_access (dev, inf)) < 0)
	  {
	    KERNEL_FREE (inf);
	    return err;
	  }

	IOCTL_TO_USER ((char *) arg, 0, (char *) inf, sizeof (*inf));
	KERNEL_FREE (inf);
	return 0;
      }
      break;

    case SNDCTL_SEQ_TRESHOLD:
      {
	int             tmp = IOCTL_IN (arg);

	if (dev)		/* Patch manager */
	  return RET_ERROR (EIO);

	if (tmp < 1)
	  tmp = 1;
	if (tmp >= SEQ_MAX_QUEUE)
	  tmp = SEQ_MAX_QUEUE - 1;
	output_treshold = tmp;
	return 0;
      }
      break;

    default:
      if (dev)			/* Patch manager */
	return RET_ERROR (EIO);

      if (mode == OPEN_READ)
	return RET_ERROR (EIO);

      if (!synth_devs[0])
	return RET_ERROR (ENXIO);
      if (!(synth_open_mask & (1 << 0)))
	return RET_ERROR (ENXIO);
      return synth_devs[0]->ioctl (0, cmd, arg);
      break;
    }

  return RET_ERROR (EINVAL);
}

#ifdef ALLOW_SELECT
int
sequencer_select (int dev, struct fileinfo *file, int sel_type, select_table * wait)
{
  dev = dev >> 4;

  switch (sel_type)
    {
    case SEL_IN:
      if (!iqlen)
	{
	  select_wait (&midi_sleeper, wait);
	  return 0;
	}
      return 1;

      break;

    case SEL_OUT:
      if (qlen >= SEQ_MAX_QUEUE)
	{
	  select_wait (&seq_sleeper, wait);
	  return 0;
	}
      return 1;
      break;

    case SEL_EX:
      return 0;
    }

  return 0;
}

#endif

void
sequencer_timer (void)
{
  seq_startplay ();
}

int
note_to_freq (int note_num)
{

  /*
   * This routine converts a midi note to a frequency (multiplied by 1000)
   */

  int             note, octave, note_freq;
  int             notes[] =
  {
    261632, 277189, 293671, 311132, 329632, 349232,
    369998, 391998, 415306, 440000, 466162, 493880
  };				/* Note freq*1000 for octave 5 */

#define BASE_OCTAVE	5

  octave = note_num / 12;
  note = note_num % 12;

  note_freq = notes[note];

  if (octave < BASE_OCTAVE)
    note_freq >>= (BASE_OCTAVE - octave);
  else if (octave > BASE_OCTAVE)
    note_freq <<= (octave - BASE_OCTAVE);

  /* note_freq >>= 1;	 */

  return note_freq;
}

unsigned long
compute_finetune (unsigned long base_freq, int bend, int range)
{
  unsigned long   amount;
  int             negative, semitones, cents;

  if (!bend)
    return base_freq;
  if (!range)
    return base_freq;

  if (!base_freq)
    return base_freq;

  if (range >= 8192)
    range = 8191;

  bend = bend * range / 8192;
  if (!bend)
    return base_freq;

  negative = bend < 0 ? 1 : 0;

  if (bend < 0)
    bend *= -1;
  if (bend > range)
    bend = range;

  if (bend > 2399)
    bend = 2399;

  semitones = bend / 100;
  cents = bend % 100;

  amount = semitone_tuning[semitones] * cent_tuning[cents] / 10000;

  if (negative)
    return (base_freq * 10000) / amount;	/* Bend down */
  else
    return (base_freq * amount) / 10000;	/* Bend up */
}


long
sequencer_init (long mem_start)
{

  sequencer_ok = 1;
  PERMANENT_MALLOC(unsigned char*, queue, SEQ_MAX_QUEUE*EV_SZ, mem_start);
  PERMANENT_MALLOC(unsigned char*, iqueue, SEQ_MAX_QUEUE*IEV_SZ, mem_start);
  return mem_start;
}

#else
/* Stub version */
int
sequencer_read (int dev, struct fileinfo *file, snd_rw_buf * buf, int count)
{
  return RET_ERROR (EIO);
}

int
sequencer_write (int dev, struct fileinfo *file, snd_rw_buf * buf, int count)
{
  return RET_ERROR (EIO);
}

int
sequencer_open (int dev, struct fileinfo *file)
  {
    return RET_ERROR (ENXIO);
  }

void
sequencer_release (int dev, struct fileinfo *file)
  {
  }
int
sequencer_ioctl (int dev, struct fileinfo *file,
		 unsigned int cmd, unsigned int arg)
{
  return RET_ERROR (EIO);
}

int
sequencer_lseek (int dev, struct fileinfo *file, off_t offset, int orig)
{
  return RET_ERROR (EIO);
}

long
sequencer_init (long mem_start)
{
  return mem_start;
}

int
sequencer_select (int dev, struct fileinfo *file, int sel_type, select_table * wait)
{
  return RET_ERROR (EIO);
}

#endif

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品欧美成人高清一区二区| 国内一区二区在线| 91精品国产aⅴ一区二区| 国产成人午夜精品影院观看视频| 一片黄亚洲嫩模| 欧美激情中文字幕| 欧美男人的天堂一二区| 99精品国产91久久久久久| 国产综合一区二区| 天天综合日日夜夜精品| 亚洲精品欧美二区三区中文字幕| 久久久久九九视频| 欧美精品在线观看一区二区| 91丨九色丨蝌蚪丨老版| 粉嫩高潮美女一区二区三区| 美女高潮久久久| 天使萌一区二区三区免费观看| 亚洲日本在线观看| 欧美国产精品中文字幕| 久久久久久亚洲综合影院红桃| 欧美老人xxxx18| 在线精品观看国产| 色综合久久久久久久久| www.亚洲免费av| 成人午夜电影久久影院| 国产美女一区二区三区| 精品一区二区在线观看| 日本午夜一本久久久综合| 亚洲国产精品一区二区www在线| 亚洲色图.com| 亚洲六月丁香色婷婷综合久久| 久久久蜜臀国产一区二区| 久久综合国产精品| 精品日韩av一区二区| 欧美成人在线直播| 日韩美女一区二区三区四区| 日韩欧美一区二区免费| 精品乱码亚洲一区二区不卡| 精品日韩在线观看| 国产色婷婷亚洲99精品小说| 久久影视一区二区| 亚洲国产精品精华液ab| 国产精品久久久久久久久久久免费看 | 99久久精品费精品国产一区二区| 国产一区二区精品久久91| 国内外精品视频| 成人一级视频在线观看| 成人精品视频一区| 成人亚洲一区二区一| 91丨国产丨九色丨pron| 91国产成人在线| 91精品国产综合久久小美女| 日韩欧美自拍偷拍| 久久久www成人免费无遮挡大片| 亚洲午夜影视影院在线观看| 亚洲免费av观看| 亚洲成人免费视| 青青草国产精品亚洲专区无| 久久福利视频一区二区| 国产精品白丝av| 91在线免费视频观看| 在线观看一区二区视频| 91精品国产入口| 久久久久国色av免费看影院| 亚洲色图另类专区| 日本强好片久久久久久aaa| 国产一区二区三区四| 9i看片成人免费高清| 欧美男同性恋视频网站| 久久久久亚洲蜜桃| 一级日本不卡的影视| 免费欧美高清视频| 成人午夜av电影| 欧美日韩精品欧美日韩精品| 久久午夜老司机| 亚洲精品乱码久久久久久黑人 | 国产成人精品免费看| 99精品国产视频| 欧美精品在线观看播放| 欧美精彩视频一区二区三区| 一卡二卡欧美日韩| 国产精选一区二区三区| 欧美伊人久久大香线蕉综合69| 日韩精品最新网址| 亚洲女人****多毛耸耸8| 蜜臀av性久久久久av蜜臀妖精| 国产99久久久久| 777a∨成人精品桃花网| 国产精品欧美一级免费| 日韩精品国产精品| 波多野结衣中文字幕一区 | 亚洲www啪成人一区二区麻豆| 国内精品久久久久影院色| 欧美少妇bbb| 久久精品视频免费观看| 午夜伊人狠狠久久| 成人黄色在线视频| 日韩欧美黄色影院| 亚洲国产aⅴ成人精品无吗| 粉嫩av一区二区三区| 日韩一区二区三区在线| 一区二区三区资源| 成人激情午夜影院| 欧美精品一区二区三区蜜桃| 亚洲高清视频在线| 99久久久久免费精品国产| 久久久亚洲综合| 日本视频在线一区| 欧美综合在线视频| |精品福利一区二区三区| 国产精品77777| 欧美大片免费久久精品三p| 亚洲国产精品久久一线不卡| 色又黄又爽网站www久久| 日本一区二区三区国色天香| 久久99精品久久久| 欧美欧美欧美欧美| 亚洲成人自拍偷拍| 在线视频你懂得一区二区三区| 中文字幕av一区二区三区| 国产精品中文字幕日韩精品| 日韩精品一区二区三区视频播放| 爽好多水快深点欧美视频| 欧美伊人精品成人久久综合97 | 成人高清免费观看| 日本一区二区免费在线观看视频| 国产美女在线观看一区| 精品美女一区二区三区| 蜜桃视频在线观看一区| 91精品国产美女浴室洗澡无遮挡| 亚洲成人av中文| 欧美日韩精品免费| 天堂va蜜桃一区二区三区漫画版| 欧美精品777| 蜜桃传媒麻豆第一区在线观看| 欧美一级片免费看| 麻豆精品一二三| 精品久久久久久久久久久院品网 | 91精品久久久久久久91蜜桃| 五月激情丁香一区二区三区| 欧美日本一区二区三区四区| 亚洲大片一区二区三区| 91精品啪在线观看国产60岁| 青娱乐精品视频| 欧美不卡一二三| 国产呦萝稀缺另类资源| 国产日韩精品久久久| 成人国产精品视频| 亚洲精品国产一区二区精华液| 在线免费观看视频一区| 亚洲高清免费视频| 日韩精品中午字幕| 国产精品99久久久| 亚洲欧美日韩综合aⅴ视频| 在线亚洲免费视频| 麻豆91精品视频| 欧美国产日产图区| 欧美日韩一区二区三区四区| 男人的j进女人的j一区| 国产亚洲欧美中文| 色婷婷国产精品| 免费在线视频一区| 国产精品私人自拍| 欧美日韩电影一区| 韩国成人福利片在线播放| 国产精品美女www爽爽爽| 91久久精品日日躁夜夜躁欧美| 日韩精品五月天| 久久久精品天堂| 色香蕉久久蜜桃| 麻豆精品一二三| 亚洲免费视频成人| 精品免费国产二区三区 | av成人老司机| 亚洲成av人片| 国产精品久久久爽爽爽麻豆色哟哟| 欧美在线短视频| 国产乱色国产精品免费视频| 综合在线观看色| 日韩视频中午一区| 日本精品一区二区三区高清 | 欧美性猛交xxxxxxxx| 久久99精品一区二区三区三区| 中文字幕一区在线观看视频| 69堂亚洲精品首页| 99久久国产综合精品色伊| 久久精品国产精品亚洲红杏| 亚洲精品国产品国语在线app| 欧美成人一区二区三区在线观看| 97se狠狠狠综合亚洲狠狠| 免费成人在线视频观看| 一区二区三区在线不卡| 国产色产综合色产在线视频| 欧美精品久久一区| 99精品视频中文字幕| 国内精品伊人久久久久av影院| 五月综合激情日本mⅴ| 日韩理论在线观看| 中文字幕乱码一区二区免费| 日韩精品一区二区三区三区免费|