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

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

?? sm.c

?? 這個linux源代碼是很全面的~基本完整了~使用c編譯的~由于時間問題我沒有親自測試~但就算用來做參考資料也是非常好的
?? C
?? 第 1 頁 / 共 2 頁
字號:
	int err;	if (!dev || !dev->priv ||	    ((struct sm_state *)dev->priv)->hdrv.magic != HDLCDRV_MAGIC) {		printk(KERN_ERR "sm_open: invalid device struct\n");		return -EINVAL;	}	sm = (struct sm_state *)dev->priv;	if (!sm->mode_tx || !sm->mode_rx || !sm->hwdrv || !sm->hwdrv->open)		return -ENODEV;	sm->hdrv.par.bitrate = sm->mode_rx->bitrate;	err = sm->hwdrv->open(dev, sm);	if (err)		return err;	sm_output_open(sm, dev->name);	MOD_INC_USE_COUNT;	printk(KERN_INFO "%s: %s mode %s.%s at iobase 0x%lx irq %u dma %u dma2 %u\n",	       sm_drvname, sm->hwdrv->hw_name, sm->mode_tx->name,	       sm->mode_rx->name, dev->base_addr, dev->irq, dev->dma, sm->hdrv.ptt_out.dma2);	return 0;}/* --------------------------------------------------------------------- */static int sm_close(struct net_device *dev){	struct sm_state *sm;	int err = -ENODEV;	if (!dev || !dev->priv ||	    ((struct sm_state *)dev->priv)->hdrv.magic != HDLCDRV_MAGIC) {		printk(KERN_ERR "sm_close: invalid device struct\n");		return -EINVAL;	}	sm = (struct sm_state *)dev->priv;	if (sm->hwdrv && sm->hwdrv->close)		err = sm->hwdrv && sm->hwdrv->close(dev, sm);	sm_output_close(sm);	MOD_DEC_USE_COUNT;	printk(KERN_INFO "%s: close %s at iobase 0x%lx irq %u dma %u\n",	       sm_drvname, sm->hwdrv->hw_name, dev->base_addr, dev->irq, dev->dma);	return err;}/* --------------------------------------------------------------------- */static int sethw(struct net_device *dev, struct sm_state *sm, char *mode){	char *cp = strchr(mode, ':');	const struct hardware_info **hwp = sm_hardware_table;	if (!cp)		cp = mode;	else {		*cp++ = '\0';		while (hwp && (*hwp) && (*hwp)->hw_name && strcmp((*hwp)->hw_name, mode))			hwp++;		if (!hwp || !*hwp || !(*hwp)->hw_name)			return -EINVAL;		if ((*hwp)->loc_storage > sizeof(sm->hw)) {			printk(KERN_ERR "%s: insufficient storage for hw driver %s (%d)\n",			       sm_drvname, (*hwp)->hw_name, (*hwp)->loc_storage);			return -EINVAL;		}		sm->hwdrv = *hwp;	}	if (!*cp)		return 0;	if (sm->hwdrv && sm->hwdrv->sethw)		return sm->hwdrv->sethw(dev, sm, cp);	return -EINVAL;}/* --------------------------------------------------------------------- */static int sm_ioctl(struct net_device *dev, struct ifreq *ifr,		    struct hdlcdrv_ioctl *hi, int cmd){	struct sm_state *sm;	struct sm_ioctl bi;	unsigned long flags;	unsigned int newdiagmode;	unsigned int newdiagflags;	char *cp;	const struct modem_tx_info **mtp = sm_modem_tx_table;	const struct modem_rx_info **mrp = sm_modem_rx_table;	const struct hardware_info **hwp = sm_hardware_table;	if (!dev || !dev->priv ||	    ((struct sm_state *)dev->priv)->hdrv.magic != HDLCDRV_MAGIC) {		printk(KERN_ERR "sm_ioctl: invalid device struct\n");		return -EINVAL;	}	sm = (struct sm_state *)dev->priv;	if (cmd != SIOCDEVPRIVATE) {		if (!sm->hwdrv || !sm->hwdrv->ioctl)			return sm->hwdrv->ioctl(dev, sm, ifr, hi, cmd);		return -ENOIOCTLCMD;	}	switch (hi->cmd) {	default:		if (sm->hwdrv && sm->hwdrv->ioctl)			return sm->hwdrv->ioctl(dev, sm, ifr, hi, cmd);		return -ENOIOCTLCMD;	case HDLCDRVCTL_GETMODE:		cp = hi->data.modename;		if (sm->hwdrv && sm->hwdrv->hw_name)			cp += sprintf(cp, "%s:", sm->hwdrv->hw_name);		else			cp += sprintf(cp, "<unspec>:");		if (sm->mode_tx && sm->mode_tx->name)			cp += sprintf(cp, "%s", sm->mode_tx->name);		else			cp += sprintf(cp, "<unspec>");		if (!sm->mode_rx || !sm->mode_rx ||		    strcmp(sm->mode_rx->name, sm->mode_tx->name)) {			if (sm->mode_rx && sm->mode_rx->name)				cp += sprintf(cp, ",%s", sm->mode_rx->name);			else				cp += sprintf(cp, ",<unspec>");		}		if (copy_to_user(ifr->ifr_data, hi, sizeof(*hi)))			return -EFAULT;		return 0;	case HDLCDRVCTL_SETMODE:		if (netif_running(dev) || !capable(CAP_NET_ADMIN))			return -EACCES;		hi->data.modename[sizeof(hi->data.modename)-1] = '\0';		return sethw(dev, sm, hi->data.modename);	case HDLCDRVCTL_MODELIST:		cp = hi->data.modename;		while (*hwp) {			if ((*hwp)->hw_name)				cp += sprintf(cp, "%s:,", (*hwp)->hw_name);			hwp++;		}		while (*mtp) {			if ((*mtp)->name)				cp += sprintf(cp, ">%s,", (*mtp)->name);			mtp++;		}		while (*mrp) {			if ((*mrp)->name)				cp += sprintf(cp, "<%s,", (*mrp)->name);			mrp++;		}		cp[-1] = '\0';		if (copy_to_user(ifr->ifr_data, hi, sizeof(*hi)))			return -EFAULT;		return 0;#ifdef SM_DEBUG	case SMCTL_GETDEBUG:		if (copy_from_user(&bi, ifr->ifr_data, sizeof(bi)))			return -EFAULT;		bi.data.dbg.int_rate = sm->debug_vals.last_intcnt;		bi.data.dbg.mod_cycles = sm->debug_vals.mod_cyc;		bi.data.dbg.demod_cycles = sm->debug_vals.demod_cyc;		bi.data.dbg.dma_residue = sm->debug_vals.dma_residue;		sm->debug_vals.mod_cyc = sm->debug_vals.demod_cyc =			sm->debug_vals.dma_residue = 0;		if (copy_to_user(ifr->ifr_data, &bi, sizeof(bi)))			return -EFAULT;		return 0;#endif /* SM_DEBUG */	case SMCTL_DIAGNOSE:		if (copy_from_user(&bi, ifr->ifr_data, sizeof(bi)))			return -EFAULT;		newdiagmode = bi.data.diag.mode;		newdiagflags = bi.data.diag.flags;		if (newdiagmode > SM_DIAGMODE_CONSTELLATION)			return -EINVAL;		bi.data.diag.mode = sm->diag.mode;		bi.data.diag.flags = sm->diag.flags;		bi.data.diag.samplesperbit = sm->mode_rx->sperbit;		if (sm->diag.mode != newdiagmode) {			save_flags(flags);			cli();			sm->diag.ptr = -1;			sm->diag.flags = newdiagflags & ~SM_DIAGFLAG_VALID;			sm->diag.mode = newdiagmode;			restore_flags(flags);			if (copy_to_user(ifr->ifr_data, &bi, sizeof(bi)))				return -EFAULT;			return 0;		}		if (sm->diag.ptr < 0 || sm->diag.mode == SM_DIAGMODE_OFF) {			if (copy_to_user(ifr->ifr_data, &bi, sizeof(bi)))				return -EFAULT;			return 0;		}		if (bi.data.diag.datalen > DIAGDATALEN)			bi.data.diag.datalen = DIAGDATALEN;		if (sm->diag.ptr < bi.data.diag.datalen) {			if (copy_to_user(ifr->ifr_data, &bi, sizeof(bi)))				return -EFAULT;			return 0;		}		if (copy_to_user(bi.data.diag.data, sm->diag.data,				 bi.data.diag.datalen * sizeof(short)))			return -EFAULT;		bi.data.diag.flags |= SM_DIAGFLAG_VALID;		save_flags(flags);		cli();		sm->diag.ptr = -1;		sm->diag.flags = newdiagflags & ~SM_DIAGFLAG_VALID;		sm->diag.mode = newdiagmode;		restore_flags(flags);		if (copy_to_user(ifr->ifr_data, &bi, sizeof(bi)))			return -EFAULT;		return 0;	}}/* --------------------------------------------------------------------- *//* * command line settable parameters */static char *mode[NR_PORTS] = { [0 ... NR_PORTS-1] = NULL };static int iobase[NR_PORTS] = { [0 ... NR_PORTS-1] = -1 };static int irq[NR_PORTS] = { [0 ... NR_PORTS-1] = -1 };static int dma[NR_PORTS] = { [0 ... NR_PORTS-1] = -1 };static int dma2[NR_PORTS] = { [0 ... NR_PORTS-1] = -1 };static int serio[NR_PORTS] = { [0 ... NR_PORTS-1] = 0 };static int pario[NR_PORTS] = { [0 ... NR_PORTS-1] = 0 };static int midiio[NR_PORTS] = { [0 ... NR_PORTS-1] = 0 };MODULE_PARM(mode, "1-" __MODULE_STRING(NR_PORTS) "s");MODULE_PARM_DESC(mode, "soundmodem operating mode; eg. sbc:afsk1200 or wss:fsk9600");MODULE_PARM(iobase, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(iobase, "soundmodem base address");MODULE_PARM(irq, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(irq, "soundmodem interrupt");MODULE_PARM(dma, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(dma, "soundmodem dma channel");MODULE_PARM(dma2, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(dma2, "soundmodem 2nd dma channel; full duplex only");MODULE_PARM(serio, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(serio, "soundmodem PTT output on serial port");MODULE_PARM(pario, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(pario, "soundmodem PTT output on parallel port");MODULE_PARM(midiio, "1-" __MODULE_STRING(NR_PORTS) "i");MODULE_PARM_DESC(midiio, "soundmodem PTT output on midi port");MODULE_AUTHOR("Thomas M. Sailer, sailer@ife.ee.ethz.ch, hb9jnx@hb9w.che.eu");MODULE_DESCRIPTION("Soundcard amateur radio modem driver");/* --------------------------------------------------------------------- */static int __init init_soundmodem(void){	int i, j, found = 0;	char set_hw = 1;	struct sm_state *sm;	printk(sm_drvinfo);	/*	 * register net devices	 */	for (i = 0; i < NR_PORTS; i++) {		struct net_device *dev = sm_device+i;		char ifname[IFNAMSIZ];		sprintf(ifname, "sm%d", i);		if (!mode[i])			set_hw = 0;		else {			if (!strncmp(mode[i], "sbc", 3)) {				if (iobase[i] == -1)					iobase[i] = 0x220;				if (irq[i] == -1)					irq[i] = 5;				if (dma[i] == -1)					dma[i] = 1;			} else {				if (iobase[i] == -1)					iobase[i] = 0x530;				if (irq[i] == -1)					irq[i] = 11;				if (dma[i] == -1)					dma[i] = 1;			}		}		if (!set_hw)			iobase[i] = irq[i] = 0;		j = hdlcdrv_register_hdlcdrv(dev, &sm_ops, sizeof(struct sm_state), ifname, iobase[i], irq[i], dma[i]);		if (!j) {			sm = (struct sm_state *)dev->priv;			sm->hdrv.ptt_out.dma2 = dma2[i];			sm->hdrv.ptt_out.seriobase = serio[i];			sm->hdrv.ptt_out.pariobase = pario[i];			sm->hdrv.ptt_out.midiiobase = midiio[i];			if (set_hw && sethw(dev, sm, mode[i]))				set_hw = 0;			found++;		} else {			printk(KERN_WARNING "%s: cannot register net device\n", sm_drvname);		}	}	if (!found)		return -ENXIO;	return 0;}static void __exit cleanup_soundmodem(void){	int i;	printk(KERN_INFO "sm: cleanup_module called\n");	for(i = 0; i < NR_PORTS; i++) {		struct net_device *dev = sm_device+i;		struct sm_state *sm = (struct sm_state *)dev->priv;		if (sm) {			if (sm->hdrv.magic != HDLCDRV_MAGIC)				printk(KERN_ERR "sm: invalid magic in "				       "cleanup_module\n");			else				hdlcdrv_unregister_hdlcdrv(dev);		}	}}module_init(init_soundmodem);module_exit(cleanup_soundmodem);/* --------------------------------------------------------------------- */#ifndef MODULE/* * format: soundmodem=io,irq,dma[,dma2[,serio[,pario]]],mode * mode: hw:modem * hw: sbc, wss, wssfdx * modem: afsk1200, fsk9600 */static int __init sm_setup(char *str){	static unsigned nr_dev;	int ints[8];	if (nr_dev >= NR_PORTS)		return 0;	str = get_options(str, 8, ints);	mode[nr_dev] = str;	if (ints[0] >= 1)		iobase[nr_dev] = ints[1];	if (ints[0] >= 2)		irq[nr_dev] = ints[2];	if (ints[0] >= 3)		dma[nr_dev] = ints[3];	if (ints[0] >= 4)		dma2[nr_dev] = ints[4];	if (ints[0] >= 5)		serio[nr_dev] = ints[5];	if (ints[0] >= 6)		pario[nr_dev] = ints[6];	if (ints[0] >= 7)		midiio[nr_dev] = ints[7];	nr_dev++;	return 1;}__setup("soundmodem=", sm_setup);#endif /* MODULE *//* --------------------------------------------------------------------- */MODULE_LICENSE("GPL");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人精品一区| 欧美亚洲综合在线| 欧美日韩国产综合视频在线观看 | 色综合久久九月婷婷色综合| 日本一区二区视频在线观看| 国产一区二区主播在线| 久久综合九色综合97婷婷女人| 日本aⅴ精品一区二区三区| 欧美精品三级日韩久久| 日韩高清在线不卡| 91精品国产高清一区二区三区 | 国产精品久久久久久久久图文区 | 麻豆91在线播放免费| 7777女厕盗摄久久久| 日韩在线一区二区三区| 日韩一级黄色片| 久久99精品视频| 久久综合色天天久久综合图片| 国产一区二区免费视频| 欧美激情一区二区三区不卡 | 久久精品视频网| 国产精品1区2区| 欧美极品aⅴ影院| 欧美日韩精品欧美日韩精品一| 男人的j进女人的j一区| 欧美精品一区二区三| 成人午夜私人影院| 亚洲国产一区二区视频| 欧美一区二区大片| 国产精品一区二区三区99| 欧美韩国日本一区| 欧美性一二三区| 麻豆一区二区99久久久久| 欧美国产乱子伦| 色综合色综合色综合色综合色综合| 一区二区三区在线观看欧美| 91精品国产综合久久久久久久久久 | 亚洲综合成人在线| 久久久久久久电影| 6080国产精品一区二区| 91在线你懂得| 国产精品自在在线| 五月天婷婷综合| 亚洲视频在线一区| 国产欧美精品在线观看| 日韩免费一区二区| 欧美日韩国产精品成人| 成人app在线观看| 国产一区二区视频在线| 亚洲.国产.中文慕字在线| 中文字幕一区二区三区在线观看 | 国产精品99久久久久久有的能看| 亚洲国产另类av| 亚洲欧美综合网| 国产欧美一区二区在线观看| 欧美一级一区二区| 欧美日韩亚洲国产综合| 91猫先生在线| 成人av电影在线观看| 国产·精品毛片| 国产精品资源站在线| 蜜臀av性久久久久蜜臀aⅴ流畅 | 久久福利视频一区二区| 亚洲成人在线免费| 亚洲资源在线观看| 一区二区三区.www| 亚洲欧美二区三区| 亚洲欧美在线aaa| 中文在线免费一区三区高中清不卡| 精品国产在天天线2019| 日韩三级高清在线| 欧美一级片在线观看| 7777精品伊人久久久大香线蕉超级流畅 | 色婷婷久久久久swag精品 | 欧美日韩一级二级三级| 国产婷婷一区二区| 亚洲综合成人网| 久久精品人人做| 精品国产三级电影在线观看| 777久久久精品| 欧美精品在线一区二区| 欧美日韩成人综合| 欧美区视频在线观看| 欧美精品一级二级| 91精品国产手机| 在线不卡免费av| 欧美一区二区美女| 精品国产乱码久久久久久闺蜜| 欧美变态tickling挠脚心| 精品日本一线二线三线不卡| 欧美丰满少妇xxxxx高潮对白| 欧美精品自拍偷拍| 日韩一级成人av| 精品国偷自产国产一区| 国产亚洲欧美激情| 中文字幕av一区二区三区高| 欧美国产日韩a欧美在线观看| 中文字幕不卡在线播放| 亚洲女性喷水在线观看一区| 亚洲综合网站在线观看| 亚洲午夜久久久久久久久电影网| 日韩影院精彩在线| 国产一区二区电影| 99精品久久久久久| 欧美午夜精品久久久久久超碰| 777久久久精品| 久久午夜羞羞影院免费观看| 国产精品国产三级国产aⅴ中文| 亚洲精品老司机| 秋霞电影网一区二区| 精品一区二区国语对白| 成人91在线观看| 在线成人免费视频| 国产女同性恋一区二区| 亚洲国产精品精华液网站| 蜜桃传媒麻豆第一区在线观看| 国产成人欧美日韩在线电影| 在线亚洲免费视频| 欧美电影免费观看高清完整版在线| 国产欧美日韩麻豆91| 图片区小说区国产精品视频| 韩国精品免费视频| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲国产成人自拍| 爽好久久久欧美精品| 国产a精品视频| 欧美久久一区二区| 国产精品不卡在线| 麻豆精品视频在线观看视频| 91免费看`日韩一区二区| 日韩免费一区二区三区在线播放| 国产精品免费看片| 三级在线观看一区二区| 99re这里都是精品| 日韩视频国产视频| 一区二区三区在线视频观看58| 青草av.久久免费一区| 色综合久久88色综合天天6| 久久亚洲影视婷婷| 日本一不卡视频| 91美女精品福利| 亚洲国产精品黑人久久久| 美女网站一区二区| 欧美亚洲高清一区| 最新久久zyz资源站| 国产美女在线观看一区| 欧美一区二区三区视频在线观看| 亚洲乱码日产精品bd| heyzo一本久久综合| 久久久久久久免费视频了| 美女一区二区视频| 在线91免费看| 亚洲va欧美va人人爽| 91免费看视频| 亚洲人妖av一区二区| eeuss影院一区二区三区| 欧美精品一区二区三区四区| 日本欧美加勒比视频| 555夜色666亚洲国产免| 亚洲国产美国国产综合一区二区| 99精品国产热久久91蜜凸| 中文字幕精品一区二区三区精品| 精品一区二区成人精品| 日韩一区二区在线观看视频| 日韩高清在线一区| 3d动漫精品啪啪1区2区免费| 亚洲影院免费观看| 欧美在线播放高清精品| 亚洲激情图片一区| 成人av电影观看| 国产精品久久久久婷婷| 91网址在线看| 亚洲资源中文字幕| 欧美天堂一区二区三区| 香蕉久久夜色精品国产使用方法 | 日日夜夜精品视频天天综合网| 91亚洲午夜精品久久久久久| 中文字幕一区二区在线播放| 91麻豆免费在线观看| 亚洲免费成人av| 欧美日韩一卡二卡三卡| 青青草原综合久久大伊人精品优势| 日韩一区二区影院| 国产成人午夜视频| 亚洲同性同志一二三专区| 91精品1区2区| 偷拍日韩校园综合在线| 日韩精品一区二区三区在线观看 | 1024成人网| 在线欧美小视频| 视频在线观看91| 精品国产髙清在线看国产毛片 | 国产精品毛片久久久久久久 | 欧美美女bb生活片| 狠狠色丁香九九婷婷综合五月| 国产人成一区二区三区影院| 97久久人人超碰| 丝袜美腿高跟呻吟高潮一区| 久久久久国色av免费看影院| aaa欧美大片|