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

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

?? xenstat.c

?? xen 3.2.2 源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* libxenstat: statistics-collection library for Xen * Copyright (C) International Business Machines Corp., 2005 * Authors: Josh Triplett <josh@kernel.org> *          Judy Fischbach <jfisch@cs.pdx.edu> *          David Hendricks <cro_marmot@comcast.net> * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. *//* * Copyright 2007 Sun Microsystems, Inc.  All rights reserved. * Use is subject to license terms. */#include <stdlib.h>#include <string.h>#include <stdio.h>#include <unistd.h>#include "xenstat_priv.h"/* * Data-collection types *//* Called to collect the information for the node and all the domains on * it. When called, the domain information has already been collected.  * Return status is 0 if fatal error occurs, 1 for success. Collectors * may prune a domain from the list if it has been deleted between the * time the list was setup and the time the colector is called */typedef int (*xenstat_collect_func)(xenstat_node * node);/* Called to free the information collected by the collect function.  The free * function will only be called on a xenstat_node if that node includes * information collected by the corresponding collector. */typedef void (*xenstat_free_func)(xenstat_node * node);/* Called to free any information stored in the handle.  Note the lack of a * matching init function; the collect functions should initialize on first * use.  Also, the uninit function must handle the case that the collector has * never been initialized. */typedef void (*xenstat_uninit_func)(xenstat_handle * handle);typedef struct xenstat_collector {	unsigned int flag;	xenstat_collect_func collect;	xenstat_free_func free;	xenstat_uninit_func uninit;} xenstat_collector;static int  xenstat_collect_vcpus(xenstat_node * node);static int  xenstat_collect_xen_version(xenstat_node * node);static void xenstat_free_vcpus(xenstat_node * node);static void xenstat_free_networks(xenstat_node * node);static void xenstat_free_xen_version(xenstat_node * node);static void xenstat_free_vbds(xenstat_node * node);static void xenstat_uninit_vcpus(xenstat_handle * handle);static void xenstat_uninit_xen_version(xenstat_handle * handle);static char *xenstat_get_domain_name(xenstat_handle * handle, unsigned int domain_id);static void xenstat_prune_domain(xenstat_node *node, unsigned int entry);static xenstat_collector collectors[] = {	{ XENSTAT_VCPU, xenstat_collect_vcpus,	  xenstat_free_vcpus, xenstat_uninit_vcpus },	{ XENSTAT_NETWORK, xenstat_collect_networks,	  xenstat_free_networks, xenstat_uninit_networks },	{ XENSTAT_XEN_VERSION, xenstat_collect_xen_version,	  xenstat_free_xen_version, xenstat_uninit_xen_version },	{ XENSTAT_VBD, xenstat_collect_vbds,	  xenstat_free_vbds, xenstat_uninit_vbds }};#define NUM_COLLECTORS (sizeof(collectors)/sizeof(xenstat_collector))/* * libxenstat API */xenstat_handle *xenstat_init(void){	xenstat_handle *handle;	handle = (xenstat_handle *) calloc(1, sizeof(xenstat_handle));	if (handle == NULL)		return NULL;#if defined(PAGESIZE)	handle->page_size = PAGESIZE;#elif defined(PAGE_SIZE)	handle->page_size = PAGE_SIZE;#else	handle->page_size = sysconf(_SC_PAGE_SIZE);	if (handle->page_size < 0) {		perror("Failed to retrieve page size.");		free(handle);		return NULL;	}#endif	handle->xc_handle = xc_interface_open();	if (handle->xc_handle == -1) {		perror("xc_interface_open");		free(handle);		return NULL;	}	handle->xshandle = xs_daemon_open_readonly(); /* open handle to xenstore*/	if (handle->xshandle == NULL) {		perror("unable to open xenstore\n");		xc_interface_close(handle->xc_handle);		free(handle);		return NULL;	}	return handle;}void xenstat_uninit(xenstat_handle * handle){	unsigned int i;	if (handle) {		for (i = 0; i < NUM_COLLECTORS; i++)			collectors[i].uninit(handle);		xc_interface_close(handle->xc_handle);		xs_daemon_close(handle->xshandle);		free(handle->priv);		free(handle);	}}xenstat_node *xenstat_get_node(xenstat_handle * handle, unsigned int flags){#define DOMAIN_CHUNK_SIZE 256	xenstat_node *node;	xc_physinfo_t physinfo = { 0 };	xc_domaininfo_t domaininfo[DOMAIN_CHUNK_SIZE];	unsigned int new_domains;	unsigned int i;	/* Create the node */	node = (xenstat_node *) calloc(1, sizeof(xenstat_node));	if (node == NULL)		return NULL;	/* Store the handle in the node for later access */	node->handle = handle;	/* Get information about the physical system */	if (xc_physinfo(handle->xc_handle, &physinfo) < 0) {		free(node);		return NULL;	}	node->cpu_hz = ((unsigned long long)physinfo.cpu_khz) * 1000ULL;        node->num_cpus = physinfo.nr_cpus;	node->tot_mem = ((unsigned long long)physinfo.total_pages)	    * handle->page_size;	node->free_mem = ((unsigned long long)physinfo.free_pages)	    * handle->page_size;	/* malloc(0) is not portable, so allocate a single domain.  This will	 * be resized below. */	node->domains = malloc(sizeof(xenstat_domain));	if (node->domains == NULL) {		free(node);		return NULL;	}	node->num_domains = 0;	do {		xenstat_domain *domain, *tmp;		new_domains = xc_domain_getinfolist(handle->xc_handle,						    node->num_domains, 						    DOMAIN_CHUNK_SIZE, 						    domaininfo);		tmp = realloc(node->domains,			      (node->num_domains + new_domains)			      * sizeof(xenstat_domain));		if (tmp == NULL) {			free(node->domains);			free(node);			return NULL;		}		node->domains = tmp;		domain = node->domains + node->num_domains;		/* zero out newly allocated memory in case error occurs below */		memset(domain, 0, new_domains * sizeof(xenstat_domain));		for (i = 0; i < new_domains; i++) {			/* Fill in domain using domaininfo[i] */			domain->id = domaininfo[i].domain;			domain->name = xenstat_get_domain_name(handle, 							       domain->id);			if (domain->name == NULL) {				if (errno == ENOMEM) {					/* fatal error */					xenstat_free_node(node);					return NULL;				}				else {					/* failed to get name -- this means the					   domain is being destroyed so simply					   ignore this entry */					continue;				}			}			domain->state = domaininfo[i].flags;			domain->cpu_ns = domaininfo[i].cpu_time;			domain->num_vcpus = (domaininfo[i].max_vcpu_id+1);			domain->vcpus = NULL;			domain->cur_mem =			    ((unsigned long long)domaininfo[i].tot_pages)			    * handle->page_size;			domain->max_mem =			    domaininfo[i].max_pages == UINT_MAX			    ? (unsigned long long)-1			    : (unsigned long long)(domaininfo[i].max_pages						   * handle->page_size);			domain->ssid = domaininfo[i].ssidref;			domain->num_networks = 0;			domain->networks = NULL;			domain->num_vbds = 0;			domain->vbds = NULL;			domain++;			node->num_domains++;		}	} while (new_domains == DOMAIN_CHUNK_SIZE);	/* Run all the extra data collectors requested */	node->flags = 0;	for (i = 0; i < NUM_COLLECTORS; i++) {		if ((flags & collectors[i].flag) == collectors[i].flag) {			node->flags |= collectors[i].flag;			if(collectors[i].collect(node) == 0) {				xenstat_free_node(node);				return NULL;			}		}	}	return node;}void xenstat_free_node(xenstat_node * node){	int i;	if (node) {		if (node->domains) {			for (i = 0; i < node->num_domains; i++)				free(node->domains[i].name);			for (i = 0; i < NUM_COLLECTORS; i++)				if((node->flags & collectors[i].flag)				   == collectors[i].flag)					collectors[i].free(node);			free(node->domains);		}		free(node);	}}xenstat_domain *xenstat_node_domain(xenstat_node * node, unsigned int domid){	unsigned int i;	/* FIXME: binary search */	/* Find the appropriate domain entry in the node struct. */	for (i = 0; i < node->num_domains; i++) {		if (node->domains[i].id == domid)			return &(node->domains[i]);	}	return NULL;}xenstat_domain *xenstat_node_domain_by_index(xenstat_node * node,					     unsigned int index){	if (0 <= index && index < node->num_domains)		return &(node->domains[index]);	return NULL;}const char *xenstat_node_xen_version(xenstat_node * node){	return node->handle->xen_version;}unsigned long long xenstat_node_tot_mem(xenstat_node * node){	return node->tot_mem;}unsigned long long xenstat_node_free_mem(xenstat_node * node){	return node->free_mem;}unsigned int xenstat_node_num_domains(xenstat_node * node){	return node->num_domains;}unsigned int xenstat_node_num_cpus(xenstat_node * node){	return node->num_cpus;}/* Get information about the CPU speed */unsigned long long xenstat_node_cpu_hz(xenstat_node * node){	return node->cpu_hz;}/* Get the domain ID for this domain */unsigned xenstat_domain_id(xenstat_domain * domain){	return domain->id;}/* Get the domain name for the domain */char *xenstat_domain_name(xenstat_domain * domain){	return domain->name;}/* Get information about how much CPU time has been used */unsigned long long xenstat_domain_cpu_ns(xenstat_domain * domain){	return domain->cpu_ns;}/* Find the number of VCPUs for a domain */unsigned int xenstat_domain_num_vcpus(xenstat_domain * domain){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人性生交大片免费看在线播放 | 国产日本欧洲亚洲| 国产精品视频一二三| 亚洲午夜在线电影| 国产成+人+日韩+欧美+亚洲| 欧美日韩午夜影院| 国产精品国产自产拍高清av| 日本美女视频一区二区| 99久久er热在这里只有精品66| 日韩欧美中文字幕精品| 亚洲激情图片qvod| 东方欧美亚洲色图在线| 日韩欧美国产一区在线观看| 一区二区三区产品免费精品久久75| 国产乱码精品一区二区三区五月婷| 欧美性高清videossexo| 亚洲人成网站色在线观看| 丁香婷婷综合五月| 26uuu亚洲| 久久成人羞羞网站| 337p亚洲精品色噜噜狠狠| 一区二区三区日韩欧美精品| 99免费精品视频| 国产精品女主播在线观看| 国产成+人+日韩+欧美+亚洲| 26uuu色噜噜精品一区| 久久99精品国产.久久久久久| 884aa四虎影成人精品一区| 亚洲成人在线网站| 欧美日韩大陆一区二区| 伊人色综合久久天天| 色综合视频一区二区三区高清| 国产亚洲欧美日韩日本| 国产成人精品一区二区三区网站观看| 精品乱人伦一区二区三区| 美日韩一级片在线观看| 精品美女一区二区| 国产成人一区二区精品非洲| ww亚洲ww在线观看国产| 国产成人在线网站| 国产精品不卡一区二区三区| 成人av午夜电影| 亚洲欧美日本韩国| 欧美日韩一区不卡| 美女视频一区二区三区| 欧美精品一区二区三区蜜桃视频| 国产一区二区在线观看视频| 久久久久国产精品免费免费搜索| 国内精品久久久久影院一蜜桃| 国产婷婷色一区二区三区| 成人av资源在线| 亚洲欧美一区二区三区国产精品 | 亚洲人妖av一区二区| 色综合中文综合网| 不卡电影免费在线播放一区| 亚洲视频中文字幕| 色婷婷综合久久| 三级在线观看一区二区| 精品国产乱码久久久久久蜜臀| 国产一区在线视频| 亚洲色图制服诱惑| 91精品久久久久久久久99蜜臂| 国产毛片精品视频| 亚洲一区在线观看免费| 欧美一级xxx| av激情亚洲男人天堂| 午夜不卡在线视频| 国产日产精品一区| 欧美日韩一区二区三区在线| 国产乱码精品一区二区三区忘忧草| 亚洲欧美乱综合| 精品国产91亚洲一区二区三区婷婷| 91小视频在线免费看| 久久国产精品99久久久久久老狼| 国产精品久久久久影院| 欧美福利一区二区| 成人黄色av电影| 免费精品视频最新在线| 自拍偷拍欧美精品| 久久一留热品黄| 欧美日韩视频不卡| a4yy欧美一区二区三区| 久久国内精品自在自线400部| 亚洲女人****多毛耸耸8| 精品国产免费久久| 69久久夜色精品国产69蝌蚪网| 成人免费毛片嘿嘿连载视频| 久久电影网电视剧免费观看| 亚洲成人av一区| 亚洲免费av高清| 久久久久国产成人精品亚洲午夜| 欧美疯狂性受xxxxx喷水图片| av不卡免费在线观看| 国产精品一二三| 青青草国产成人av片免费| 亚洲综合成人在线| 18成人在线观看| 国产女主播一区| 欧美精品一区二区三区四区| 欧美乱熟臀69xxxxxx| 在线观看免费一区| av不卡在线观看| 成人精品在线视频观看| 国产一本一道久久香蕉| 国产一区二区不卡在线| 喷白浆一区二区| 免费在线观看视频一区| 日韩电影在线看| 日韩中文字幕91| 日本欧美大码aⅴ在线播放| 亚洲一区免费在线观看| 亚洲影视在线播放| 亚洲午夜电影网| 亚洲观看高清完整版在线观看| 亚洲黄色av一区| 夜夜揉揉日日人人青青一国产精品| 国产精品卡一卡二| 中文字幕一区二区视频| 综合久久久久久久| 亚洲欧美另类在线| 亚洲一区视频在线观看视频| 亚洲一区二区三区四区在线| 一区二区三区视频在线看| 亚洲精品免费电影| 性久久久久久久久久久久| 三级欧美韩日大片在线看| 日韩二区三区在线观看| 久久se精品一区二区| 国产精品综合在线视频| 成人黄色小视频在线观看| www.av亚洲| 在线中文字幕一区| 7777精品伊人久久久大香线蕉最新版 | 午夜av区久久| 奇米精品一区二区三区在线观看一| 久久国产精品色婷婷| 国产传媒久久文化传媒| 色先锋久久av资源部| 在线观看亚洲精品| 欧美一区二区三级| 国产蜜臀97一区二区三区| 亚洲人精品午夜| 美女在线一区二区| 丁香天五香天堂综合| 欧美日韩激情在线| 久久综合久色欧美综合狠狠| 国产精品二三区| 天天影视色香欲综合网老头| 国产精品小仙女| 欧美日韩一区二区在线观看视频| 日韩欧美亚洲国产精品字幕久久久| 中文字幕精品三区| 日日欢夜夜爽一区| av在线免费不卡| 日韩一级精品视频在线观看| 中文av一区特黄| 男人的天堂亚洲一区| 91麻豆国产福利精品| 精品成人一区二区三区四区| 亚洲人成网站精品片在线观看 | 欧美一区二区三区色| 久久九九影视网| 午夜精品久久久久| 成人网男人的天堂| 日韩午夜小视频| 尤物av一区二区| 国产麻豆9l精品三级站| 欧美性色黄大片| 中文字幕日韩精品一区| 精品在线免费观看| 欧美午夜影院一区| 1000部国产精品成人观看| 老色鬼精品视频在线观看播放| 91久久线看在观草草青青| 久久久亚洲欧洲日产国码αv| 亚洲成人av中文| 日本韩国精品一区二区在线观看| 久久蜜桃一区二区| 麻豆久久久久久| 欧美日韩第一区日日骚| 亚洲综合免费观看高清完整版在线 | 丁香婷婷深情五月亚洲| 欧美一区二区三区男人的天堂| 中文字幕在线不卡| 成人精品视频一区| 久久久久久久久久久黄色| 蜜桃视频免费观看一区| 欧美精品一二三| 亚洲国产综合91精品麻豆| 91国产成人在线| 亚洲欧美激情小说另类| 91免费在线看| 亚洲女子a中天字幕| 91在线观看下载| 亚洲精品一二三四区| 色国产综合视频| 亚洲最新在线观看| 欧美日韩国产大片| 午夜久久久久久电影| 欧美美女直播网站|