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

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

?? main.c

?? ARM 嵌入式 系統(tǒng) 設(shè)計與實例開發(fā) 實驗教材 二源碼
?? C
字號:
/*kHTTPd -- the next generationMain programkHTTPd TNG consists of 1 thread, this main-thread handles ALL connectionssimultanious. It does this by keeping queues with the requests in differentstages.The stages are<not accepted> 		-	TCP/IP connection is not accepted yetWaitForHeaders		-	Connection is accepted, waiting for headersDataSending		-	Headers decoded, sending file-dataUserspace		-	Requires userspace daemon Logging			-	The request is finished, cleanup and loggingA typical flow for a request would be:<not accepted>WaitForHeadersDataSendingLoggingor<not accepted>WaitForHeadersUserspace*//**************************************************************** *	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, 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. * ****************************************************************/static int errno;#define __KERNEL_SYSCALLS__#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/sched.h>#include <linux/signal.h>#include <linux/init.h>#include <linux/wait.h>#include <linux/smp_lock.h>#include <asm/unistd.h>#include "structure.h"#include "prototypes.h"#include "sysctl.h"struct khttpd_threadinfo threadinfo[CONFIG_KHTTPD_NUMCPU];  /* The actual work-queues */atomic_t	ConnectCount;atomic_t	DaemonCount;static int	ActualThreads; /* The number of actual, active threads */static int ConnectionsPending(int CPUNR){	if (threadinfo[CPUNR].DataSendingQueue!=NULL) return O_NONBLOCK;	if (threadinfo[CPUNR].WaitForHeaderQueue!=NULL) return O_NONBLOCK;	if (threadinfo[CPUNR].LoggingQueue!=NULL) return O_NONBLOCK;	if (threadinfo[CPUNR].UserspaceQueue!=NULL) return O_NONBLOCK;  return 0;}static wait_queue_head_t DummyWQ[CONFIG_KHTTPD_NUMCPU];static atomic_t Running[CONFIG_KHTTPD_NUMCPU]; static int MainDaemon(void *cpu_pointer){	int CPUNR;	sigset_t tmpsig;		DECLARE_WAITQUEUE(main_wait,current);		MOD_INC_USE_COUNT;		CPUNR=0;	if (cpu_pointer!=NULL)	CPUNR=(int)*(int*)cpu_pointer;	sprintf(current->comm,"khttpd - %i",CPUNR);	daemonize();		init_waitqueue_head(&(DummyWQ[CPUNR]));		/* Block all signals except SIGKILL, SIGSTOP and SIGHUP */	spin_lock_irq(&current->sigmask_lock);	tmpsig = current->blocked;	siginitsetinv(&current->blocked, sigmask(SIGKILL) | sigmask(SIGSTOP)| sigmask(SIGHUP));	recalc_sigpending(current);	spin_unlock_irq(&current->sigmask_lock);			if (MainSocket->sk==NULL)	 	return 0;	add_wait_queue_exclusive(MainSocket->sk->sleep,&(main_wait));	atomic_inc(&DaemonCount);	atomic_set(&Running[CPUNR],1);		while (sysctl_khttpd_stop==0)	{		int changes = 0;								changes +=AcceptConnections(CPUNR,MainSocket);		if (ConnectionsPending(CPUNR))		{			changes +=WaitForHeaders(CPUNR);			changes +=DataSending(CPUNR);			changes +=Userspace(CPUNR);			changes +=Logging(CPUNR);			/* Test for incoming connections _again_, because it is possible			   one came in during the other steps, and the wakeup doesn't happen			   then.			*/			changes +=AcceptConnections(CPUNR,MainSocket);		}				if (changes==0) 		{			(void)interruptible_sleep_on_timeout(&(DummyWQ[CPUNR]),1);				if (CPUNR==0) 				UpdateCurrentDate();		}					if (signal_pending(current)!=0)		{			(void)printk(KERN_NOTICE "kHTTPd: Ring Ring - signal received\n");			break;		  		}		}		remove_wait_queue(MainSocket->sk->sleep,&(main_wait));		StopWaitingForHeaders(CPUNR);	StopDataSending(CPUNR);	StopUserspace(CPUNR);	StopLogging(CPUNR);		atomic_set(&Running[CPUNR],0);	atomic_dec(&DaemonCount);	(void)printk(KERN_NOTICE "kHTTPd: Daemon %i has ended\n",CPUNR);	MOD_DEC_USE_COUNT;	return 0;}static int CountBuf[CONFIG_KHTTPD_NUMCPU];/*The ManagementDaemon has a very simple task: Start the real daemons when the user wants usto, and cleanup when the users wants to unload the module.Initially, kHTTPd didn't have this thread, but it is the only way to have "delayed activation",a feature required to prevent accidental activations resulting in unexpected backdoors.*/static int ManagementDaemon(void *unused){	sigset_t tmpsig;	int waitpid_result;		DECLARE_WAIT_QUEUE_HEAD(WQ);			sprintf(current->comm,"khttpd manager");	daemonize();		/* Block all signals except SIGKILL and SIGSTOP */	spin_lock_irq(&current->sigmask_lock);	tmpsig = current->blocked;	siginitsetinv(&current->blocked, sigmask(SIGKILL) | sigmask(SIGSTOP) );	recalc_sigpending(current);	spin_unlock_irq(&current->sigmask_lock);	/* main loop */	while (sysctl_khttpd_unload==0)	{		int I;						/* First : wait for activation */				sysctl_khttpd_start = 0;				while ( (sysctl_khttpd_start==0) && (!signal_pending(current)) && (sysctl_khttpd_unload==0) )		{			current->state = TASK_INTERRUPTIBLE;			interruptible_sleep_on_timeout(&WQ,HZ); 		}				if ( (signal_pending(current)) || (sysctl_khttpd_unload!=0) )		 	break;		 			/* Then start listening and spawn the daemons */		 			if (StartListening(sysctl_khttpd_serverport)==0)		{			continue;		}				ActualThreads = sysctl_khttpd_threads;		if (ActualThreads<1) 			ActualThreads = 1;					if (ActualThreads>CONFIG_KHTTPD_NUMCPU) 			ActualThreads = CONFIG_KHTTPD_NUMCPU;				/* Write back the actual value */				sysctl_khttpd_threads = ActualThreads;				InitUserspace(ActualThreads);				if (InitDataSending(ActualThreads)!=0)		{			StopListening();			continue;		}		if (InitWaitHeaders(ActualThreads)!=0)		{			I=0;			while (I<ActualThreads)			{				StopDataSending(I);				I++;			}			StopListening();			continue;		}			/* Clean all queues */		memset(threadinfo, 0, sizeof(struct khttpd_threadinfo));		 			I=0;		while (I<ActualThreads)		{			atomic_set(&Running[I],1);			(void)kernel_thread(MainDaemon,&(CountBuf[I]), CLONE_FS | CLONE_FILES | CLONE_SIGHAND);			I++;		}				/* Then wait for deactivation */		sysctl_khttpd_stop = 0;		while ( (sysctl_khttpd_stop==0) && (!signal_pending(current)) && (sysctl_khttpd_unload==0) )		{			if (atomic_read(&DaemonCount)<ActualThreads)			{				I=0;				while (I<ActualThreads)				{					if (atomic_read(&Running[I])==0)					{						atomic_set(&Running[I],1);						(void)kernel_thread(MainDaemon,&(CountBuf[I]), CLONE_FS | CLONE_FILES | CLONE_SIGHAND);						(void)printk(KERN_CRIT "kHTTPd: Restarting daemon %i \n",I);					}					I++;				}			}			interruptible_sleep_on_timeout(&WQ,HZ);						/* reap the daemons */			waitpid_result = waitpid(-1,NULL,__WCLONE|WNOHANG);					}						/* The user wants us to stop. So stop listening on the socket. */		if (sysctl_khttpd_stop!=0)			{			/* Wait for the daemons to stop, one second per iteration */			while (atomic_read(&DaemonCount)>0)		 		interruptible_sleep_on_timeout(&WQ,HZ);			StopListening();		}				}		sysctl_khttpd_stop = 1;	/* Wait for the daemons to stop, one second per iteration */	while (atomic_read(&DaemonCount)>0) 		interruptible_sleep_on_timeout(&WQ,HZ);					waitpid_result = 1;	/* reap the zombie-daemons */	while (waitpid_result>0)		waitpid_result = waitpid(-1,NULL,__WCLONE|WNOHANG);			StopListening();			(void)printk(KERN_NOTICE "kHTTPd: Management daemon stopped. \n        You can unload the module now.\n");	MOD_DEC_USE_COUNT;	return 0;}int __init khttpd_init(void){	int I;	MOD_INC_USE_COUNT;		I=0;	while (I<CONFIG_KHTTPD_NUMCPU)	{		CountBuf[I]=I;				I++;	}		atomic_set(&ConnectCount,0);	atomic_set(&DaemonCount,0);		/* Maybe the mime-types will be set-able through sysctl in the future */	   		 	AddMimeType(".htm","text/html"); 	AddMimeType("html","text/html"); 	AddMimeType(".gif","image/gif"); 	AddMimeType(".jpg","image/jpeg"); 	AddMimeType(".png","image/png"); 	AddMimeType("tiff","image/tiff"); 	AddMimeType(".zip","application/zip");	AddMimeType(".pdf","application/pdf"); 	AddMimeType("r.gz","application/x-gtar"); 	AddMimeType(".tgz","application/x-gtar");	AddMimeType(".deb","application/x-debian-package");	AddMimeType("lass","application/x-java");	AddMimeType(".mp3","audio/mpeg");	AddMimeType(".txt","text/plain");		AddDynamicString("..");	AddDynamicString("cgi-bin");	StartSysctl();		(void)kernel_thread(ManagementDaemon,NULL, CLONE_FS | CLONE_FILES | CLONE_SIGHAND);		return 0;}void khttpd_cleanup(void){	EndSysctl();}	module_init(khttpd_init)	module_exit(khttpd_cleanup)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人一道本在线| 亚洲不卡一区二区三区| 综合网在线视频| 亚洲综合丁香婷婷六月香| 亚洲国产精品久久人人爱| 日韩成人免费电影| 国产精品一级在线| 在线免费观看视频一区| 日韩欧美国产电影| 中文字幕一区二| 日韩不卡免费视频| 粉嫩蜜臀av国产精品网站| 色婷婷一区二区| 欧美成人伊人久久综合网| 国产精品高潮呻吟久久| 五月婷婷激情综合网| 国产精品影视在线| 欧美日韩综合色| 国产亚洲欧美日韩日本| 亚洲成av人片一区二区梦乃| 国产suv精品一区二区三区| 欧美日韩中文字幕精品| 久久综合狠狠综合| 亚洲永久免费视频| 国产精品一区专区| 欧美日韩国产bt| 中文字幕精品在线不卡| 日欧美一区二区| 成人黄色小视频| 日韩欧美国产一区二区三区| 亚洲人成影院在线观看| 韩国女主播一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 国产欧美一区二区精品久导航| 婷婷综合久久一区二区三区| 成人午夜av电影| 日韩欧美综合一区| 亚洲福利国产精品| 99re66热这里只有精品3直播| 2欧美一区二区三区在线观看视频| 一区二区三区美女视频| 高清国产午夜精品久久久久久| 欧美精品一级二级| 自拍偷自拍亚洲精品播放| 国产精品白丝av| 欧美一级搡bbbb搡bbbb| 亚洲成a人片在线观看中文| 国产不卡视频在线播放| 日韩欧美中文字幕公布| 丝袜a∨在线一区二区三区不卡| 99久久婷婷国产综合精品电影| 精品成人免费观看| 天天综合网 天天综合色| 一本色道久久综合狠狠躁的推荐 | 亚洲欧美偷拍另类a∨色屁股| 麻豆精品新av中文字幕| 欧美高清www午色夜在线视频| 自拍偷拍亚洲欧美日韩| 成人的网站免费观看| 欧美精品一区二区高清在线观看| 婷婷国产在线综合| 欧美丝袜丝nylons| 亚洲一区二区不卡免费| 一本一道波多野结衣一区二区| 中文字幕不卡的av| 成人小视频在线观看| 国产视频亚洲色图| 国产经典欧美精品| 国产欧美日韩综合精品一区二区| 玖玖九九国产精品| 日韩视频在线你懂得| 婷婷中文字幕综合| 欧美美女一区二区三区| 亚洲超碰精品一区二区| 欧美日韩久久一区二区| 亚洲成精国产精品女| 欧美日韩成人综合天天影院| 亚洲成人在线观看视频| 欧美群妇大交群中文字幕| 亚洲一区二区三区国产| 在线日韩一区二区| 亚洲图片一区二区| 欧美日韩成人综合天天影院| 日韩高清一区在线| 日韩免费高清视频| 激情五月婷婷综合网| 精品国产91乱码一区二区三区 | 欧美三级资源在线| 亚洲国产精品一区二区久久| 7777精品伊人久久久大香线蕉的 | 色拍拍在线精品视频8848| 亚洲免费视频中文字幕| 欧美在线一二三四区| 午夜精品成人在线| 欧美一级高清大全免费观看| 久久99国内精品| 久久久精品综合| 成人av集中营| 一区二区三区在线视频观看58| 欧美日韩国产高清一区二区三区| 美女一区二区久久| 国产日产精品一区| 91无套直看片红桃| 天堂蜜桃91精品| 欧美精品一区二区三区一线天视频| 国产精品一区久久久久| 亚洲视频免费观看| 欧美另类z0zxhd电影| 精品亚洲欧美一区| 国产精品第一页第二页第三页| 91成人在线精品| 蜜芽一区二区三区| 中文av字幕一区| 欧洲视频一区二区| 精东粉嫩av免费一区二区三区| 欧美激情在线一区二区| 欧美伊人久久久久久久久影院 | 欧美精品欧美精品系列| 国产美女久久久久| 亚洲男人天堂av| 精品国内二区三区| 91麻豆国产福利在线观看| 免费成人av在线播放| 中文字幕一区二区三区四区不卡| 欧美日韩一区二区三区四区五区| 老汉av免费一区二区三区| 中文字幕av一区二区三区| 欧美喷潮久久久xxxxx| 国产精品1区2区3区| 五月天欧美精品| 欧美激情一区二区三区不卡| 欧美日韩日日摸| 成人av先锋影音| 美日韩一区二区| 亚洲欧美日韩国产综合| 欧美一级日韩一级| 91高清视频在线| 国产精品系列在线播放| 日韩激情视频在线观看| 国产精品久久久久aaaa| 欧美一区二区私人影院日本| 99视频精品在线| 激情综合五月婷婷| 天天操天天干天天综合网| 国产精品成人免费在线| 精品欧美久久久| 欧美图片一区二区三区| 成人自拍视频在线观看| 久久99久久久久久久久久久| 一区二区三区日韩精品视频| 日本一区二区免费在线| 日韩精品一区在线| 欧美视频一区二区三区四区| 成人av网在线| 国产美女一区二区三区| 蜜桃一区二区三区四区| 亚洲影院久久精品| 国产精品网站在线播放| 精品国产乱码久久久久久闺蜜| 欧美亚洲国产怡红院影院| aaa欧美大片| 国产精品亚洲一区二区三区妖精 | 欧美综合天天夜夜久久| 成人av网站在线| 国产成人免费视频一区| 美国欧美日韩国产在线播放| 夜夜嗨av一区二区三区四季av| 亚洲国产高清aⅴ视频| 久久午夜羞羞影院免费观看| 欧美一区二区在线播放| 777奇米成人网| 欧美美女视频在线观看| 在线免费亚洲电影| 日本精品裸体写真集在线观看| 国产精品538一区二区在线| 国模无码大尺度一区二区三区| 久久精品久久99精品久久| 丝瓜av网站精品一区二区| 一区二区在线观看免费 | 欧美色图一区二区三区| 一本一道波多野结衣一区二区| 国产激情精品久久久第一区二区 | 91成人免费电影| 色呦呦日韩精品| 色综合久久久久综合| 91小视频在线观看| 99r精品视频| 99re6这里只有精品视频在线观看| eeuss鲁片一区二区三区在线观看| 国产成人免费视频| 国产盗摄一区二区| 国产成人综合精品三级| 成人一区二区三区视频 | 亚洲免费观看高清完整版在线| 综合久久国产九一剧情麻豆| 亚洲色图在线看| 一区二区三区**美女毛片| 亚洲一区二区精品久久av| 性感美女极品91精品| 日本va欧美va精品发布|