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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sm.c

?? 這個linux源代碼是很全面的~基本完整了~使用c編譯的~由于時間問題我沒有親自測試~但就算用來做參考資料也是非常好的
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*****************************************************************************//* *	sm.c  -- soundcard radio modem driver. * *	Copyright (C) 1996-2000  Thomas Sailer (sailer@ife.ee.ethz.ch) * *	This program is free software; you can redistribute it and/or modify *	it under the terms of the GNU General Public License as published by *	the Free Software Foundation; either version 2 of the License, or *	(at your option) any later version. * *	This program is distributed in the hope that it will be useful, *	but WITHOUT ANY WARRANTY; without even the implied warranty of *	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *	GNU General Public License for more details. * *	You should have received a copy of the GNU General Public License *	along with this program; if not, write to the Free Software *	Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * *  Please note that the GPL allows you to use the driver, NOT the radio. *  In order to use the radio, you need a license from the communications *  authority of your country. * * *  Command line options (insmod command line) * *  mode     mode string; eg. "wss:afsk1200" *  iobase   base address of the soundcard; common values are 0x220 for sbc, *           0x530 for wss *  irq      interrupt number; common values are 7 or 5 for sbc, 11 for wss *  dma      dma number; common values are 0 or 1 * * *  History: *   0.1  21.09.1996  Started *        18.10.1996  Changed to new user space access routines (copy_{to,from}_user) *   0.4  21.01.1997  Separately compileable soundcard/modem modules *   0.5  03.03.1997  fixed LPT probing (check_lpt result was interpreted the wrong way round) *   0.6  16.04.1997  init code/data tagged *   0.7  30.07.1997  fixed halfduplex interrupt handlers/hotfix for CS423X *   0.8  14.04.1998  cleanups *   0.9  03.08.1999  adapt to Linus' new __setup/__initcall *                    use parport lowlevel drivers instead of directly writing to a parallel port *                    removed some pre-2.2 kernel compatibility cruft *   0.10 10.08.1999  Check if parport can do SPP and is safe to access during interrupt contexts *   0.11 12.02.2000  adapted to softnet driver interface *   0.12 03.07.2000  fix interface name handling *//*****************************************************************************/#include <linux/config.h>#include <linux/version.h>#include <linux/module.h>#include <linux/ioport.h>#include <linux/string.h>#include <linux/init.h>#include <linux/parport.h>#include <asm/uaccess.h>#include <asm/io.h>#include "sm.h"/* --------------------------------------------------------------------- *//*static*/ const char sm_drvname[] = "soundmodem";static const char sm_drvinfo[] = KERN_INFO "soundmodem: (C) 1996-2000 Thomas Sailer, HB9JNX/AE4WA\n"KERN_INFO "soundmodem: version 0.12 compiled " __TIME__ " " __DATE__ "\n";/* --------------------------------------------------------------------- *//*static*/ const struct modem_tx_info *sm_modem_tx_table[] = {#ifdef CONFIG_SOUNDMODEM_AFSK1200	&sm_afsk1200_tx,#endif /* CONFIG_SOUNDMODEM_AFSK1200 */#ifdef CONFIG_SOUNDMODEM_AFSK2400_7	&sm_afsk2400_7_tx,#endif /* CONFIG_SOUNDMODEM_AFSK2400_7 */#ifdef CONFIG_SOUNDMODEM_AFSK2400_8	&sm_afsk2400_8_tx,#endif /* CONFIG_SOUNDMODEM_AFSK2400_8 */#ifdef CONFIG_SOUNDMODEM_AFSK2666	&sm_afsk2666_tx,#endif /* CONFIG_SOUNDMODEM_AFSK2666 */#ifdef CONFIG_SOUNDMODEM_PSK4800	&sm_psk4800_tx,#endif /* CONFIG_SOUNDMODEM_PSK4800 */#ifdef CONFIG_SOUNDMODEM_HAPN4800	&sm_hapn4800_8_tx,	&sm_hapn4800_10_tx,	&sm_hapn4800_pm8_tx,	&sm_hapn4800_pm10_tx,#endif /* CONFIG_SOUNDMODEM_HAPN4800 */#ifdef CONFIG_SOUNDMODEM_FSK9600	&sm_fsk9600_4_tx,	&sm_fsk9600_5_tx,#endif /* CONFIG_SOUNDMODEM_FSK9600 */	NULL};/*static*/ const struct modem_rx_info *sm_modem_rx_table[] = {#ifdef CONFIG_SOUNDMODEM_AFSK1200	&sm_afsk1200_rx,#endif /* CONFIG_SOUNDMODEM_AFSK1200 */#ifdef CONFIG_SOUNDMODEM_AFSK2400_7	&sm_afsk2400_7_rx,#endif /* CONFIG_SOUNDMODEM_AFSK2400_7 */#ifdef CONFIG_SOUNDMODEM_AFSK2400_8	&sm_afsk2400_8_rx,#endif /* CONFIG_SOUNDMODEM_AFSK2400_8 */#ifdef CONFIG_SOUNDMODEM_AFSK2666	&sm_afsk2666_rx,#endif /* CONFIG_SOUNDMODEM_AFSK2666 */#ifdef CONFIG_SOUNDMODEM_PSK4800	&sm_psk4800_rx,#endif /* CONFIG_SOUNDMODEM_PSK4800 */#ifdef CONFIG_SOUNDMODEM_HAPN4800	&sm_hapn4800_8_rx,	&sm_hapn4800_10_rx,	&sm_hapn4800_pm8_rx,	&sm_hapn4800_pm10_rx,#endif /* CONFIG_SOUNDMODEM_HAPN4800 */#ifdef CONFIG_SOUNDMODEM_FSK9600	&sm_fsk9600_4_rx,	&sm_fsk9600_5_rx,#endif /* CONFIG_SOUNDMODEM_FSK9600 */	NULL};static const struct hardware_info *sm_hardware_table[] = {#ifdef CONFIG_SOUNDMODEM_SBC	&sm_hw_sbc,	&sm_hw_sbcfdx,#endif /* CONFIG_SOUNDMODEM_SBC */#ifdef CONFIG_SOUNDMODEM_WSS	&sm_hw_wss,	&sm_hw_wssfdx,#endif /* CONFIG_SOUNDMODEM_WSS */	NULL};/* --------------------------------------------------------------------- */#define NR_PORTS 4static struct net_device sm_device[NR_PORTS];/* --------------------------------------------------------------------- */#define UART_RBR(iobase) (iobase+0)#define UART_THR(iobase) (iobase+0)#define UART_IER(iobase) (iobase+1)#define UART_IIR(iobase) (iobase+2)#define UART_FCR(iobase) (iobase+2)#define UART_LCR(iobase) (iobase+3)#define UART_MCR(iobase) (iobase+4)#define UART_LSR(iobase) (iobase+5)#define UART_MSR(iobase) (iobase+6)#define UART_SCR(iobase) (iobase+7)#define UART_DLL(iobase) (iobase+0)#define UART_DLM(iobase) (iobase+1)#define SER_EXTENT 8#define MIDI_DATA(iobase)     (iobase)#define MIDI_STATUS(iobase)   (iobase+1)#define MIDI_READ_FULL 0x80   /* attention: negative logic!! */#define MIDI_WRITE_EMPTY 0x40 /* attention: negative logic!! */#define MIDI_EXTENT 2/* ---------------------------------------------------------------------- */#define PARAM_TXDELAY   1#define PARAM_PERSIST   2#define PARAM_SLOTTIME  3#define PARAM_TXTAIL    4#define PARAM_FULLDUP   5#define PARAM_HARDWARE  6#define PARAM_RETURN    255#define SP_SER  1#define SP_PAR  2#define SP_MIDI 4/* * ===================== port checking routines ======================== */enum uart { c_uart_unknown, c_uart_8250,	c_uart_16450, c_uart_16550, c_uart_16550A};static const char *uart_str[] =	{ "unknown", "8250", "16450", "16550", "16550A" };static enum uart check_uart(unsigned int iobase){	unsigned char b1,b2,b3;	enum uart u;	enum uart uart_tab[] =		{ c_uart_16450, c_uart_unknown, c_uart_16550, c_uart_16550A };	if (iobase <= 0 || iobase > 0x1000-SER_EXTENT)		return c_uart_unknown;	if (check_region(iobase, SER_EXTENT))		return c_uart_unknown;	b1 = inb(UART_MCR(iobase));	outb(b1 | 0x10, UART_MCR(iobase));	/* loopback mode */	b2 = inb(UART_MSR(iobase));	outb(0x1a, UART_MCR(iobase));	b3 = inb(UART_MSR(iobase)) & 0xf0;	outb(b1, UART_MCR(iobase));	   /* restore old values */	outb(b2, UART_MSR(iobase));	if (b3 != 0x90)		return c_uart_unknown;	inb(UART_RBR(iobase));	inb(UART_RBR(iobase));	outb(0x01, UART_FCR(iobase));		/* enable FIFOs */	u = uart_tab[(inb(UART_IIR(iobase)) >> 6) & 3];	if (u == c_uart_16450) {		outb(0x5a, UART_SCR(iobase));		b1 = inb(UART_SCR(iobase));		outb(0xa5, UART_SCR(iobase));		b2 = inb(UART_SCR(iobase));		if ((b1 != 0x5a) || (b2 != 0xa5))			u = c_uart_8250;	}	return u;}/* --------------------------------------------------------------------- */static int check_midi(unsigned int iobase){	unsigned long timeout;	unsigned long flags;	unsigned char b;	if (iobase <= 0 || iobase > 0x1000-MIDI_EXTENT)		return 0;	if (check_region(iobase, MIDI_EXTENT))		return 0;	timeout = jiffies + (HZ / 100);	while (inb(MIDI_STATUS(iobase)) & MIDI_WRITE_EMPTY)		if ((signed)(jiffies - timeout) > 0)			return 0;	save_flags(flags);	cli();	outb(0xff, MIDI_DATA(iobase));	b = inb(MIDI_STATUS(iobase));	restore_flags(flags);	if (!(b & MIDI_WRITE_EMPTY))		return 0;	while (inb(MIDI_STATUS(iobase)) & MIDI_WRITE_EMPTY)		if ((signed)(jiffies - timeout) > 0)			return 0;	return 1;}/* --------------------------------------------------------------------- */void sm_output_status(struct sm_state *sm){	int invert_dcd = 0;	int invert_ptt = 0;	int ptt = /*hdlcdrv_ptt(&sm->hdrv)*/(sm->dma.ptt_cnt > 0) ^ invert_ptt;	int dcd = (!!sm->hdrv.hdlcrx.dcd) ^ invert_dcd;	if (sm->hdrv.ptt_out.flags & SP_SER) {		outb(dcd | (ptt << 1), UART_MCR(sm->hdrv.ptt_out.seriobase));		outb(0x40 & (-ptt), UART_LCR(sm->hdrv.ptt_out.seriobase));	}	if (sm->hdrv.ptt_out.flags & SP_PAR && sm->pardev && sm->pardev->port)		parport_write_data(sm->pardev->port, ptt | (dcd << 1));	if (sm->hdrv.ptt_out.flags & SP_MIDI && hdlcdrv_ptt(&sm->hdrv))		outb(0, MIDI_DATA(sm->hdrv.ptt_out.midiiobase));}/* --------------------------------------------------------------------- */static void sm_output_open(struct sm_state *sm, const char *ifname){	enum uart u = c_uart_unknown;	struct parport *pp = NULL;	sm->hdrv.ptt_out.flags = 0;	if (sm->hdrv.ptt_out.seriobase > 0 &&	    sm->hdrv.ptt_out.seriobase <= 0x1000-SER_EXTENT &&	    ((u = check_uart(sm->hdrv.ptt_out.seriobase))) != c_uart_unknown) {		sm->hdrv.ptt_out.flags |= SP_SER;		request_region(sm->hdrv.ptt_out.seriobase, SER_EXTENT, "sm ser ptt");		outb(0, UART_IER(sm->hdrv.ptt_out.seriobase));		/* 5 bits, 1 stop, no parity, no break, Div latch access */		outb(0x80, UART_LCR(sm->hdrv.ptt_out.seriobase));		outb(0, UART_DLM(sm->hdrv.ptt_out.seriobase));		outb(1, UART_DLL(sm->hdrv.ptt_out.seriobase)); /* as fast as possible */		/* LCR and MCR set by output_status */	}	sm->pardev = NULL;	if (sm->hdrv.ptt_out.pariobase > 0) {		pp = parport_enumerate();		while (pp && pp->base != sm->hdrv.ptt_out.pariobase) 			pp = pp->next;		if (!pp)			printk(KERN_WARNING "%s: parport at address 0x%x not found\n", sm_drvname, sm->hdrv.ptt_out.pariobase);		else if ((~pp->modes) & (PARPORT_MODE_PCSPP | PARPORT_MODE_SAFEININT))			printk(KERN_WARNING "%s: parport at address 0x%x cannot be used\n", sm_drvname, sm->hdrv.ptt_out.pariobase);		else {			sm->pardev = parport_register_device(pp, ifname, NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);			if (!sm->pardev) {				pp = NULL;				printk(KERN_WARNING "%s: cannot register parport device (address 0x%x)\n", sm_drvname, sm->hdrv.ptt_out.pariobase);			} else {				if (parport_claim(sm->pardev)) {					parport_unregister_device(sm->pardev);					sm->pardev = NULL;					printk(KERN_WARNING "%s: cannot claim parport at address 0x%x\n", sm_drvname, sm->hdrv.ptt_out.pariobase);				} else					sm->hdrv.ptt_out.flags |= SP_PAR;			}		}	}	if (sm->hdrv.ptt_out.midiiobase > 0 &&	    sm->hdrv.ptt_out.midiiobase <= 0x1000-MIDI_EXTENT &&	    check_midi(sm->hdrv.ptt_out.midiiobase)) {		sm->hdrv.ptt_out.flags |= SP_MIDI;		request_region(sm->hdrv.ptt_out.midiiobase, MIDI_EXTENT,			       "sm midi ptt");	}	sm_output_status(sm);	printk(KERN_INFO "%s: ptt output:", sm_drvname);	if (sm->hdrv.ptt_out.flags & SP_SER)		printk(" serial interface at 0x%x, uart %s", sm->hdrv.ptt_out.seriobase,		       uart_str[u]);	if (sm->hdrv.ptt_out.flags & SP_PAR)		printk(" parallel interface at 0x%x", sm->hdrv.ptt_out.pariobase);	if (sm->hdrv.ptt_out.flags & SP_MIDI)		printk(" mpu401 (midi) interface at 0x%x", sm->hdrv.ptt_out.midiiobase);	if (!sm->hdrv.ptt_out.flags)		printk(" none");	printk("\n");}/* --------------------------------------------------------------------- */static void sm_output_close(struct sm_state *sm){	/* release regions used for PTT output */	sm->hdrv.hdlctx.ptt = sm->hdrv.hdlctx.calibrate = 0;	sm_output_status(sm);	if (sm->hdrv.ptt_out.flags & SP_SER)		release_region(sm->hdrv.ptt_out.seriobase, SER_EXTENT);       	if (sm->hdrv.ptt_out.flags & SP_PAR && sm->pardev) {		        parport_release(sm->pardev);			parport_unregister_device(sm->pardev);	}       	if (sm->hdrv.ptt_out.flags & SP_MIDI)		release_region(sm->hdrv.ptt_out.midiiobase, MIDI_EXTENT);	sm->hdrv.ptt_out.flags = 0;}/* --------------------------------------------------------------------- */static int sm_open(struct net_device *dev);static int sm_close(struct net_device *dev);static int sm_ioctl(struct net_device *dev, struct ifreq *ifr,		    struct hdlcdrv_ioctl *hi, int cmd);/* --------------------------------------------------------------------- */static const struct hdlcdrv_ops sm_ops = {	sm_drvname, sm_drvinfo, sm_open, sm_close, sm_ioctl};/* --------------------------------------------------------------------- */static int sm_open(struct net_device *dev){	struct sm_state *sm;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡av在线网| 亚洲一级二级三级| 国产精品自产自拍| 欧美xxxxxxxx| 国产91在线观看丝袜| 国产午夜三级一区二区三| 国产成人在线视频网站| 国产视频在线观看一区二区三区| 国产凹凸在线观看一区二区| 中文字幕一区二区日韩精品绯色| 色综合久久中文字幕综合网| 一区二区三区在线视频免费| 欧美日韩国产影片| 捆绑调教美女网站视频一区| 日本一区二区三区高清不卡| 99久久精品一区| 亚洲va欧美va人人爽| 日韩一级片在线观看| 国产成人av影院| 成人免费视频在线观看| 91精品国产综合久久香蕉的特点| 久久精品72免费观看| 国产欧美日韩亚州综合 | 色婷婷亚洲精品| 日韩精品91亚洲二区在线观看| 久久色视频免费观看| 不卡一区二区中文字幕| 天天操天天综合网| 久久精品欧美一区二区三区不卡| 91丨porny丨国产入口| 天堂午夜影视日韩欧美一区二区| 国产午夜精品一区二区| 欧美伊人精品成人久久综合97| 久久国产精品72免费观看| 国产精品国产三级国产aⅴ入口 | 精品嫩草影院久久| 91亚洲午夜精品久久久久久| 久久国内精品视频| 一区二区免费看| 欧美色区777第一页| 欧美日韩一区三区| 精品一区二区三区在线视频| 中文字幕在线不卡视频| 日韩一级在线观看| 色哟哟一区二区| 另类专区欧美蜜桃臀第一页| 亚洲欧美激情插 | 亚洲国产精品一区二区www在线| 2023国产精品| 制服.丝袜.亚洲.中文.综合| 成人丝袜18视频在线观看| 蜜臀久久99精品久久久画质超高清| 国产精品二区一区二区aⅴ污介绍| 日韩丝袜情趣美女图片| 在线这里只有精品| 成人高清视频免费观看| 韩国v欧美v日本v亚洲v| 日本午夜一区二区| 五月婷婷欧美视频| 一区二区三区**美女毛片| 国产精品伦理一区二区| 91精品国产综合久久久久久漫画 | 视频在线观看一区二区三区| 国产婷婷色一区二区三区| 欧美日韩久久久| www.亚洲激情.com| 黄色成人免费在线| 亚洲成va人在线观看| 综合久久久久久久| 欧美一区二区二区| 欧美丝袜丝nylons| 91丨国产丨九色丨pron| 国产成人精品aa毛片| 久久电影国产免费久久电影| 亚洲va天堂va国产va久| 一区二区三区欧美久久| 亚洲欧洲日产国码二区| 欧美精品一区二区三区蜜桃视频| 91免费视频网址| 91色综合久久久久婷婷| 成人黄色国产精品网站大全在线免费观看 | 久久超级碰视频| 日韩成人午夜电影| 全部av―极品视觉盛宴亚洲| 亚洲福利一二三区| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲国产精品ⅴa在线观看| 久久综合中文字幕| 日韩欧美在线一区二区三区| 欧美日韩高清影院| 欧美偷拍一区二区| 欧美亚洲综合一区| 99国产精品久| 在线观看av不卡| 91蝌蚪porny| 色婷婷综合久色| 一本久道久久综合中文字幕| proumb性欧美在线观看| 成人成人成人在线视频| www.色综合.com| 色综合夜色一区| 成人天堂资源www在线| 色综合久久久久| 欧美艳星brazzers| 88在线观看91蜜桃国自产| 欧美日韩dvd在线观看| 欧美精品一级二级三级| 91精选在线观看| 日韩精品中文字幕一区二区三区| 日韩一区二区免费在线电影| 91精品国产色综合久久| 91精品国产综合久久香蕉的特点 | 亚洲另类春色校园小说| 一区二区三区精品久久久| 午夜精品久久久久久久蜜桃app| 亚洲不卡在线观看| 久久av老司机精品网站导航| 岛国精品一区二区| 91丨porny丨国产入口| 91麻豆精品国产91久久久久久| 欧美mv日韩mv亚洲| 国产精品欧美久久久久无广告| 国产欧美日韩麻豆91| 一区二区三区四区五区视频在线观看| 伊人婷婷欧美激情| 天天综合色天天综合| 韩国一区二区在线观看| 91在线观看视频| 欧美色男人天堂| 久久综合九色综合97_久久久| 国产精品久久久久四虎| 亚洲成人动漫在线观看| 日韩三级视频中文字幕| 久久久综合九色合综国产精品| 国产欧美精品区一区二区三区 | 欧美日本国产一区| 精品国产免费一区二区三区香蕉 | 不卡一区二区中文字幕| 欧美日韩一级片在线观看| 精品国产乱码久久久久久夜甘婷婷| 久久久久国产精品人| 天天射综合影视| 成人久久18免费网站麻豆| 91.麻豆视频| 国产精品美女久久久久aⅴ国产馆| 亚洲一区二区三区视频在线| 免费在线观看一区| 国产精品18久久久久久久久久久久 | 色综合夜色一区| 日韩欧美国产系列| 亚洲人成亚洲人成在线观看图片 | 亚洲美女一区二区三区| 日本麻豆一区二区三区视频| 97se亚洲国产综合自在线| 日韩欧美国产三级| 26uuu亚洲| 亚洲精品国产一区二区三区四区在线| 国模娜娜一区二区三区| 欧美日韩在线电影| 亚洲精品老司机| 国产综合成人久久大片91| 精品久久久久99| 亚洲成人tv网| 欧美网站大全在线观看| 国产精品嫩草久久久久| 国产伦精一区二区三区| 日韩一区二区高清| 亚洲黄色免费电影| 欧美色综合久久| 一区二区在线观看视频| 福利一区二区在线观看| 日韩美女视频在线| 日本网站在线观看一区二区三区| 在线看日韩精品电影| 日韩伦理电影网| 91黄色免费版| 亚洲欧美视频一区| eeuss国产一区二区三区| 国产精品美女久久久久高潮| 成人自拍视频在线观看| 国产三级精品视频| 国内精品写真在线观看| 精品国产免费人成在线观看| 日本不卡免费在线视频| 欧美日韩在线播放三区| 全部av―极品视觉盛宴亚洲| 日韩一区二区三区在线观看| 日韩黄色片在线观看| 欧美日韩成人高清| 日韩精品视频网| 日韩视频一区二区三区| 丝瓜av网站精品一区二区| 5858s免费视频成人| 首页亚洲欧美制服丝腿| 日韩欧美综合一区| 韩国一区二区三区| 中文字幕二三区不卡| 欧美午夜精品免费| 日韩专区欧美专区| 欧美日韩二区三区|