⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 klconflib.c

📁 广州斯道2410普及版II的源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
	serial_string = serial_string + strlen(serial_pattern);	/*  Copy the serial number information from the klconfig */	i = 0;	while (serial_string[i] != ';') {		serial_number[i] = serial_string[i];		i++;	}	serial_number[i] = 0;		return(0);}/* * Get the serial number of a board * Returns 0 if a valid serial number is found * 1 otherwise. */intboard_serial_number_get(lboard_t *board,char *serial_number){	ASSERT(board && serial_number);	if (!board || !serial_number)		return(1);	strcpy(serial_number,"");	switch(KLCLASS(board->brd_type)) {	case KLCLASS_CPU: {	/* Node board */		klhub_t	*hub;				/* Get the hub component information */		hub = (klhub_t *)find_first_component(board,						      KLSTRUCT_HUB);		/* If we don't have a hub component on an IP27		 * then we have a weird klconfig.		 */		if (!hub)			return(1);		/* Get the serial number information from		 * the hub's manufacturing nic info		 */		if (component_serial_number_get(board,						hub->hub_mfg_nic,						serial_number,#if defined(CONFIG_SGI_IP35) || defined(CONFIG_IA64_SGI_SN1) || defined(CONFIG_IA64_GENERIC)						"IP35"))#else						"IP27"))			/* Try with IP31 key if IP27 key fails */			if (component_serial_number_get(board,							hub->hub_mfg_nic,							serial_number,							"IP31"))#endif /* CONFIG_SGI_IP35 || CONFIG_IA64_SGI_SN1 */				return(1);		break;	}	case KLCLASS_IO: {	/* IO board */		if (KLTYPE(board->brd_type) == KLTYPE_TPU) {		/* Special case for TPU boards */			kltpu_t *tpu;						/* Get the tpu component information */			tpu = (kltpu_t *)find_first_component(board,						      KLSTRUCT_TPU);			/* If we don't have a tpu component on a tpu board			 * then we have a weird klconfig.			 */			if (!tpu)				return(1);			/* Get the serial number information from			 * the tpu's manufacturing nic info			 */			if (component_serial_number_get(board,						tpu->tpu_mfg_nic,						serial_number,						""))				return(1);			break;		} else  if ((KLTYPE(board->brd_type) == KLTYPE_GSN_A) ||		            (KLTYPE(board->brd_type) == KLTYPE_GSN_B)) {		/* Special case for GSN boards */			klgsn_t *gsn;						/* Get the gsn component information */			gsn = (klgsn_t *)find_first_component(board,			      ((KLTYPE(board->brd_type) == KLTYPE_GSN_A) ?					KLSTRUCT_GSN_A : KLSTRUCT_GSN_B));			/* If we don't have a gsn component on a gsn board			 * then we have a weird klconfig.			 */			if (!gsn)				return(1);			/* Get the serial number information from			 * the gsn's manufacturing nic info			 */			if (component_serial_number_get(board,						gsn->gsn_mfg_nic,						serial_number,						""))				return(1);			break;		} else {		     	klbri_t	*bridge;					/* Get the bridge component information */			bridge = (klbri_t *)find_first_component(board,							 KLSTRUCT_BRI);			/* If we don't have a bridge component on an IO board			 * then we have a weird klconfig.			 */			if (!bridge)				return(1);			/* Get the serial number information from		 	 * the bridge's manufacturing nic info			 */			if (component_serial_number_get(board,						bridge->bri_mfg_nic,						serial_number,						""))				return(1);			break;		}	}	case KLCLASS_ROUTER: {	/* Router board */		klrou_t *router;					/* Get the router component information */		router = (klrou_t *)find_first_component(board,							 KLSTRUCT_ROU);		/* If we don't have a router component on a router board		 * then we have a weird klconfig.		 */		if (!router)			return(1);		/* Get the serial number information from		 * the router's manufacturing nic info		 */		if (component_serial_number_get(board,						router->rou_mfg_nic,						serial_number,						""))			return(1);		break;	}	case KLCLASS_GFX: {	/* Gfx board */		klgfx_t *graphics;				/* Get the graphics component information */		graphics = (klgfx_t *)find_first_component(board, KLSTRUCT_GFX);		/* If we don't have a gfx component on a gfx board		 * then we have a weird klconfig.		 */		if (!graphics)			return(1);		/* Get the serial number information from		 * the graphics's manufacturing nic info		 */		if (component_serial_number_get(board,						graphics->gfx_mfg_nic,						serial_number,						""))			return(1);		break;	}	default:		strcpy(serial_number,"");		break;	}	return(0);}#include "asm/sn/sn_private.h"xwidgetnum_tnodevertex_widgetnum_get(devfs_handle_t node_vtx){	hubinfo_t hubinfo_p;	hwgraph_info_get_LBL(node_vtx, INFO_LBL_NODE_INFO, 			     (arbitrary_info_t *) &hubinfo_p);	return(hubinfo_p->h_widgetid);}devfs_handle_tnodevertex_xbow_peer_get(devfs_handle_t node_vtx){	hubinfo_t hubinfo_p;	nasid_t xbow_peer_nasid;	cnodeid_t xbow_peer;	hwgraph_info_get_LBL(node_vtx, INFO_LBL_NODE_INFO,				     (arbitrary_info_t *) &hubinfo_p);	xbow_peer_nasid = hubinfo_p->h_nodepda->xbow_peer;	if(xbow_peer_nasid == INVALID_NASID) 			return ( (devfs_handle_t)-1);	xbow_peer = NASID_TO_COMPACT_NODEID(xbow_peer_nasid);	return(NODEPDA(xbow_peer)->node_vertex);}/* NIC Sorting Support */#define MAX_NICS_PER_STRING 	32#define MAX_NIC_NAME_LEN	32static char *get_nic_string(lboard_t *lb){        int         	i;        klinfo_t    	*k = NULL ;    	klconf_off_t    mfg_off = 0 ;    	char            *mfg_nic = NULL ;        for (i = 0; i < KLCF_NUM_COMPS(lb); i++) {                k = KLCF_COMP(lb, i) ;                switch(k->struct_type) {                        case KLSTRUCT_BRI:            			mfg_off = ((klbri_t *)k)->bri_mfg_nic ;				break ;                        case KLSTRUCT_HUB:            			mfg_off = ((klhub_t *)k)->hub_mfg_nic ;				break ;                        case KLSTRUCT_ROU:            			mfg_off = ((klrou_t *)k)->rou_mfg_nic ;				break ;                        case KLSTRUCT_GFX:            			mfg_off = ((klgfx_t *)k)->gfx_mfg_nic ;				break ;                        case KLSTRUCT_TPU:            			mfg_off = ((kltpu_t *)k)->tpu_mfg_nic ;				break ;                        case KLSTRUCT_GSN_A:                        case KLSTRUCT_GSN_B:            			mfg_off = ((klgsn_t *)k)->gsn_mfg_nic ;				break ;                        case KLSTRUCT_XTHD:                                mfg_off = ((klxthd_t *)k)->xthd_mfg_nic ;                                break;			default:				mfg_off = 0 ;                                break ;                }		if (mfg_off)			break ;        }	if ((mfg_off) && (k))		mfg_nic = (char *)NODE_OFFSET_TO_K0(k->nasid, mfg_off) ;        return mfg_nic ;}char *get_first_string(char **ptrs, int n){        int     i ;        char    *tmpptr ;        if ((ptrs == NULL) || (n == 0))                return NULL ;        tmpptr = ptrs[0] ;        if (n == 1)                return tmpptr ;        for (i = 0 ; i < n ; i++) {                if (strcmp(tmpptr, ptrs[i]) > 0)                        tmpptr = ptrs[i] ;        }        return tmpptr ;}intget_ptrs(char *idata, char **ptrs, int n, char *label){        int     i = 0 ;        char    *tmp = idata ;        if ((ptrs == NULL) || (idata == NULL) || (label == NULL) || (n == 0))                return 0 ;        while  ( (tmp = strstr(tmp, label)) ){                tmp += strlen(label) ;                /* check for empty name field, and last NULL ptr */                if ((i < (n-1)) && (*tmp != ';')) {                        ptrs[i++] = tmp ;                }        }        ptrs[i] = NULL ;        return i ;}/* * sort_nic_names * * 	Does not really do sorting. Find the alphabetically lowest *	name among all the nic names found in a nic string. * * Return: *	Nothing * * Side Effects: * *	lb->brd_name gets the new name found */static voidsort_nic_names(lboard_t *lb){	char 	*nic_str ;        char    *ptrs[MAX_NICS_PER_STRING] ;        char    name[MAX_NIC_NAME_LEN] ;        char    *tmp, *tmp1 ;	*name = 0 ;	/* Get the nic pointer from the lb */	if ((nic_str = get_nic_string(lb)) == NULL)		return ;        tmp = get_first_string(ptrs,                        get_ptrs(nic_str, ptrs, MAX_NICS_PER_STRING, "Name:")) ;        if (tmp == NULL)		return ;        if  ( (tmp1 = strchr(tmp, ';')) ){                strncpy(name, tmp, tmp1-tmp) ;                name[tmp1-tmp] = 0 ;        } else {                strncpy(name, tmp, (sizeof(name) -1)) ;                name[sizeof(name)-1] = 0 ;        }	strcpy(lb->brd_name, name) ;}#if defined(CONFIG_SGI_IP35) || defined(CONFIG_IA64_SGI_SN1) || defined(CONFIG_IA64_GENERIC)char brick_types[MAX_BRICK_TYPES + 1] = "crikxdp789012345";/* * Format a module id for printing. */voidformat_module_id(char *buffer, moduleid_t m, int fmt){	int rack, position;	char brickchar;	rack = MODULE_GET_RACK(m);	ASSERT(MODULE_GET_BTYPE(m) < MAX_BRICK_TYPES);	brickchar = MODULE_GET_BTCHAR(m);	position = MODULE_GET_BPOS(m);	if (fmt == MODULE_FORMAT_BRIEF) {	    /* Brief module number format, eg. 002c15 */	    /* Decompress the rack number */	    *buffer++ = '0' + RACK_GET_CLASS(rack);	    *buffer++ = '0' + RACK_GET_GROUP(rack);	    *buffer++ = '0' + RACK_GET_NUM(rack);	    /* Add the brick type */	    *buffer++ = brickchar;	}	else if (fmt == MODULE_FORMAT_LONG) {	    /* Fuller hwgraph format, eg. rack/002/bay/15 */	    strcpy(buffer, EDGE_LBL_RACK "/");  buffer += strlen(buffer);	    *buffer++ = '0' + RACK_GET_CLASS(rack);	    *buffer++ = '0' + RACK_GET_GROUP(rack);	    *buffer++ = '0' + RACK_GET_NUM(rack);	    strcpy(buffer, "/" EDGE_LBL_RPOS "/");  buffer += strlen(buffer);	}	/* Add the bay position, using at least two digits */	if (position < 10)	    *buffer++ = '0';	sprintf(buffer, "%d", position);}/* * Parse a module id, in either brief or long form. * Returns < 0 on error. * The long form does not include a brick type, so it defaults to 0 (CBrick) */intparse_module_id(char *buffer){	unsigned int	v, rack, bay, type, form;	moduleid_t	m;	char 		c;	if (strstr(buffer, EDGE_LBL_RACK "/") == buffer) {		form = MODULE_FORMAT_LONG;		buffer += strlen(EDGE_LBL_RACK "/");		/* A long module ID must be exactly 5 non-template chars. */		if (strlen(buffer) != strlen("/" EDGE_LBL_RPOS "/") + 5)			return -1;	}	else {		form = MODULE_FORMAT_BRIEF;		/* A brief module id must be exactly 6 characters */		if (strlen(buffer) != 6)			return -2;	}	/* The rack number must be exactly 3 digits */	if (!(isdigit(buffer[0]) && isdigit(buffer[1]) && isdigit(buffer[2])))		return -3;	rack = 0;	v = *buffer++ - '0';	if (v > RACK_CLASS_MASK(rack) >> RACK_CLASS_SHFT(rack))		return -4;	RACK_ADD_CLASS(rack, v);	v = *buffer++ - '0';	if (v > RACK_GROUP_MASK(rack) >> RACK_GROUP_SHFT(rack))		return -5;	RACK_ADD_GROUP(rack, v);	v = *buffer++ - '0';	/* rack numbers are 1-based */	if (v-1 > RACK_NUM_MASK(rack) >> RACK_NUM_SHFT(rack))		return -6;	RACK_ADD_NUM(rack, v);	if (form == MODULE_FORMAT_BRIEF) {		/* Next should be a module type character.  Accept ucase or lcase. */		c = *buffer++;		if (!isalpha(c))			return -7;		/* strchr() returns a pointer into brick_types[], or NULL */		type = (unsigned int)(strchr(brick_types, tolower(c)) - brick_types);		if (type > MODULE_BTYPE_MASK >> MODULE_BTYPE_SHFT)			return -8;	}	else {		/* Hardcode the module type, and skip over the boilerplate */		type = MODULE_CBRICK;		if (strstr(buffer, "/" EDGE_LBL_RPOS "/") != buffer)			return -9;		buffer += strlen("/" EDGE_LBL_RPOS "/");	}			/* The bay number is last.  Make sure it's exactly two digits */	if (!(isdigit(buffer[0]) && isdigit(buffer[1]) && !buffer[2]))		return -10;	bay = 10 * (buffer[0] - '0') + (buffer[1] - '0');	if (bay > MODULE_BPOS_MASK >> MODULE_BPOS_SHFT)		return -11;	m = RBT_TO_MODULE(rack, bay, type);	/* avoid sign extending the moduleid_t */	return (int)(unsigned short)m;}#else /* CONFIG_SGI_IP35 || CONFIG_IA64_SGI_SN1 *//* * Format a module id for printing. */voidformat_module_id(char *buffer, moduleid_t m, int fmt){    if (fmt == MODULE_FORMAT_BRIEF) {		sprintf(buffer, "%d", m);    }    else if (fmt == MODULE_FORMAT_LONG) {		sprintf(buffer, EDGE_LBL_MODULE "/%d", m);    }}/* * Parse a module id, in either brief or long form. * Returns < 0 on error. */intparse_module_id(char *buffer){    moduleid_t m;    char c;    if (strstr(buffer, EDGE_LBL_MODULE "/") == buffer)	buffer += strlen(EDGE_LBL_MODULE "/");    m = 0;    while(c = *buffer++) {	if (!isdigit(c))	    return -1;	m = 10 * m + (c - '0');    }    /* avoid sign extending the moduleid_t */    return (int)(unsigned short)m;}#endif /* CONFIG_SGI_IP35 || CONFIG_IA64_SGI_SN1 */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -