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

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

?? distnamelib.c

?? vxworks操作系統的源代碼 供研究學習
?? C
?? 第 1 頁 / 共 4 頁
字號:
        }#else    distNameRmtAdd (DIST_IF_BROADCAST_ADDR, name, nameLen, value,                    valueLen, type);#endif    return (OK);    /* return OK, always */    }/***************************************************************************** distNameLclAdd - bind name to value in local name database (VxFusion option)** This routine binds a name to a given value in name database. If <type>* is a distributed object preprocess and postprocess identifier.** NOTE: Before calling distNameLclAdd(), nameLen and valueLen* must been tested to prevent overflows.** AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: OK, if successful.** NOMANUAL*/LOCAL STATUS distNameLclAdd    (    char *         name,     /* name to enter in database */    int            nameLen,  /* strlen (name) */    void *         value,    /* value associated with name */    int            valueLen, /* size of value in bytes */    DIST_NAME_TYPE type      /* type associated with name */    )    {    DIST_NAME_DB_NODE * pDbNode;    DIST_OBJ_NODE *     pObjNode;    void *              pVal;    MSG_Q_ID            msgQId;    /* Preprocessing */    switch (type)        {        case T_DIST_MSG_Q:            {            /*             * A little tricky, what we do here: user gives us a             * message queue id. Check if it is a distributed             * message id. If not, return ERROR.             * Create a new DIST_OBJ_NODE and copy distributed             * id to new DIST_OBJ_NODE. Return the new MSG_Q_ID             * (which is in fact another reference to the MSG_Q_ID,             * the user gave us).             */            msgQId = *((MSG_Q_ID *) value);            if (!ID_IS_DISTRIBUTED (msgQId))                return (ERROR);    /* not a distributed message queue */            if (DIST_OBJ_VERIFY (msgQId) == ERROR)                return (ERROR);            pObjNode = MSG_Q_ID_TO_DIST_OBJ_NODE (msgQId);            if (! IS_DIST_MSG_Q_OBJ (pObjNode))                return (ERROR); /* legal object id, but not a message queue */            pVal = &(pObjNode->objNodeUniqId);            valueLen = sizeof (pObjNode->objNodeUniqId);            break;            }        default:            pVal = value;        }    /* Local database update (raw part). */    pDbNode = distNameLclAddRaw (name, nameLen, pVal, valueLen, type);    if (pDbNode == NULL)        return (ERROR);    /* Postprocessing */    switch (type)        {        case T_DIST_MSG_Q:            *((MSG_Q_ID *) value) = *((MSG_Q_ID *) &pDbNode->value);        }    return (OK);    }/***************************************************************************** distNameBurst - burst out name database (VxFusion option)** This routine is used by INCO to update the remote name database on* node <nodeId>. All entries in the database are transmitted.** AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: OK, if successful.** NOMANUAL*/STATUS distNameBurst    (    DIST_NODE_ID    nodeId    /* node receiving burst */    )    {    DIST_NAME_BURST    burst;    burst.burstNodeId = nodeId;    burst.burstStatus = OK;    distNameEach ((FUNCPTR) distNameBurstOne, (int) &burst);    return (burst.burstStatus);    }/***************************************************************************** distNameBurstOne - burst out single name database entry (VxFusion option)** This routine bursts out a single database entry to a node.** AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: TRUE, if burst out successful** NOMANUAL*/LOCAL BOOL distNameBurstOne    (    DIST_NAME_DB_NODE * pNode,   /* node receiving burst */    DIST_NAME_BURST *   pBurst   /* the entry to send */    )    {    char    *name = (char *) &pNode->symName;    if ((pBurst->burstStatus = distNameRmtAdd (pBurst->burstNodeId,            name, strlen (name), &pNode->value, pNode->valueLen,            pNode->type)) == ERROR)        return (FALSE);    return (TRUE);    }/***************************************************************************** distNameRmtAdd - bind name to value in remote name databases (VxFusion option)** This routine adds or updates a name/value pair in a remote node.** NOTE: Before calling distNameRmtAdd(), nameLen and valueLen* must been tested to prevent overflows.** AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: OK, if successful.** NOMANUAL*/LOCAL STATUS distNameRmtAdd    (    DIST_NODE_ID    nodeId,     /* node to address */    char *          name,       /* name to enter in database */    int             nameLen,    /* strlen (name) */    void *          value,      /* value associated with name */    int             valueLen,   /* size of value in bytes */    DIST_NAME_TYPE  type        /* type associated with name */    )    {    DIST_NAME_TYPE_ALL    valNet;    DIST_PKT_DNDB_ADD     pktDndbAdd;    DIST_IOVEC            IOVec[3];    STATUS                status;    void *                pValNet;    DIST_OBJ_UNIQ_ID *    pObjUniqId;    DIST_OBJ_NODE *       pObjNode;    MSG_Q_ID              msgQId;    /*     * We have to copy data, since some processors allow     * memory requests to non-aligned addresses, others     * don't.     */    switch (type)        {        case T_DIST_UINT8:            {            pValNet = value;            break;            }        case T_DIST_UINT16:            {            bcopy (value, (char *) &(valNet.uint16), valueLen);            valNet.uint16 = htons (valNet.uint16);            pValNet = &(valNet.uint16);            break;            }        case T_DIST_NODE:        case T_DIST_FLOAT:        case T_DIST_UINT32:            {            bcopy (value, (char *) &(valNet.uint32), valueLen);            valNet.uint32 = htonl (valNet.uint32);            pValNet = &valNet.uint32;            break;            }        case T_DIST_UINT64:        case T_DIST_DOUBLE:            {            bcopy (value, (char *) &(valNet.uint64), valueLen);            pValNet = distHton64((uint32_t*)&(valNet.uint64),type);            break;            }        case T_DIST_MSG_Q:        /* complex objects go here */            {            /*             * A little tricky, what we do here: user gives us a             * message queue id. Check if it is a distributed             * message id. If not, return ERROR.             * Get the distributed (unique!) id instead of the             * local MSG_Q_ID (local pointer).             */            msgQId = *((MSG_Q_ID *) value);            if (!ID_IS_DISTRIBUTED (msgQId))                return (ERROR);    /* not a distributed message queue */            if (DIST_OBJ_VERIFY (msgQId) == ERROR)                return (ERROR);            pObjNode = MSG_Q_ID_TO_DIST_OBJ_NODE (msgQId);            if (! IS_DIST_MSG_Q_OBJ (pObjNode))                return (ERROR); /* legal object id, but not a message queue */            bcopy ((char *) &(pObjNode->objNodeUniqId),                   (char *) &(valNet.objUniqId),                   sizeof (pObjNode->objNodeUniqId));            pObjUniqId = (DIST_OBJ_UNIQ_ID *) &(valNet.objUniqId);            pObjUniqId->objUniqReside    = htonl (pObjUniqId->objUniqReside);            pObjUniqId->objUniqId        = htonl (pObjUniqId->objUniqId);            pValNet = pObjUniqId;            valueLen = sizeof (*pObjUniqId);            break;            }        default:            pValNet = value;    /* user defined, do not know what to do */        }    /* Remote database update. */    pktDndbAdd.dndbAddHdr.pktType = DIST_PKT_TYPE_DNDB;    pktDndbAdd.dndbAddHdr.pktSubType = DIST_PKT_TYPE_DNDB_ADD;    pktDndbAdd.dndbAddType = htons (type);    pktDndbAdd.dndbAddValueLen = (UINT8) valueLen;    pktDndbAdd.dndbAddNameLen = (UINT8) nameLen;    IOVec[0].pIOBuffer = &pktDndbAdd;    IOVec[0].IOLen = DIST_PKT_HDR_SIZEOF (DIST_PKT_DNDB_ADD);    IOVec[1].pIOBuffer = pValNet;    IOVec[1].IOLen = valueLen;    IOVec[2].pIOBuffer = name;    IOVec[2].IOLen = nameLen;    status = distNetIOVSend (nodeId, &IOVec[0], 3, WAIT_FOREVER,            DIST_PKT_DNDB_PRIO);    return (status);    }/***************************************************************************** distNameFind - find an object by name in the local database (VxFusion option)** This routine searches the distributed name database for an object matching* a specified <name>. If the object is found, a pointer to the value and its* type are copied to the address pointed to by <pValue> and <pType>.* If the type is T_DIST_MSG_Q, the identifier returned can be used with* generic message queue handling routines in msgQLib, such as msgQSend(), * msgQReceive(), and msgQNumMsgs().** AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: OK, or ERROR if the search fails.** ERRNO:* \is* \i S_distNameLib_NAME_TOO_LONG* The name to be found in the database is too long.* \i S_distNameLib_INVALID_WAIT_TYPE* The wait type should be either NO_WAIT or WAIT_FOREVER .* \ie*/STATUS distNameFind    (    char *           name,    /* name to search for            */    void **          pValue,  /* where to return ptr to value */    DIST_NAME_TYPE * pType,   /* where to return type  */    int              waitType /* NO_WAIT or WAIT_FOREVER       */    )    {    DIST_NAME_DB_NODE * pNode;    DIST_NAME_DB_NODE   matchNode;    int                 nameLen;    if ((nameLen = strlen (name)) > DIST_NAME_MAX_LENGTH)        {        errnoSet (S_distNameLib_NAME_TOO_LONG);        return (ERROR);    /* name too long */        }    if (waitType != NO_WAIT && waitType != WAIT_FOREVER)        {        errnoSet (S_distNameLib_INVALID_WAIT_TYPE);        return (ERROR); /* wait type is invalid */        }    bcopy (name, (char *) &matchNode.symName, nameLen + 1);again:    distNameLclLock();    pNode = (DIST_NAME_DB_NODE *) hashTblFind (distNameDbId,            (HASH_NODE *)&matchNode, KEY_CMP_ARG);    distNameLclUnlock();    if (!pNode)        {        if (waitType == WAIT_FOREVER)            {            /* object not found; we have to wait ... */            distNameLclBlockOnAdd();            goto again;            }        else            return (ERROR);    /* object not found */        }        *pType = pNode->type;    *pValue = &pNode->value;    return (OK);    }/***************************************************************************** distNameFindByValueAndType - look up the name of an object by value and type (VxFusion option)** This routine searches the distributed name database for an object matching* a specified <value> and <type>. If the object is found, its name is * copied to the address pointed to by <name>.** NOTE:* Unlike the smNameFindByValue() routine, used with the shared-memory * objects name database, this routine must know the type of the object* being searched for. Searching on the value only might not return a* unique object.* * AVAILABILITY* This routine is distributed as a component of the unbundled distributed* message queues option, VxFusion.** RETURNS: OK, or ERROR if the search fails.*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩三区| 91在线视频播放| 久久这里只有精品首页| 久久91精品国产91久久小草 | 国产高清精品网站| 久久久久国产精品人| 国产福利精品导航| 国产精品黄色在线观看| 在线精品国精品国产尤物884a| 亚洲一区二区在线观看视频| 欧美日韩一卡二卡三卡| 日本欧美一区二区| 国产色一区二区| 91免费视频网| 日本中文字幕一区| 日本一区二区久久| 欧美影院一区二区三区| 久久99久久99| 一区二区三区蜜桃| 26uuu久久综合| 日本道色综合久久| 国产一区二区网址| 亚洲自拍偷拍麻豆| 精品精品欲导航| 一本大道av一区二区在线播放| 午夜精品免费在线观看| 久久人人超碰精品| 欧美亚洲免费在线一区| 国产一区二区三区久久悠悠色av | 亚洲综合成人在线视频| 日韩欧美高清dvd碟片| 91亚洲资源网| 久久99最新地址| 亚洲精品国久久99热| 欧美精品一区二| 欧美日韩精品三区| caoporen国产精品视频| 另类中文字幕网| 亚洲免费在线视频一区 二区| 欧美一区二区三区爱爱| 色综合中文综合网| 一区二区三区中文字幕| 精品sm在线观看| 欧美在线不卡一区| 成人av在线观| 国产一区欧美二区| 偷窥国产亚洲免费视频| 亚洲日本一区二区| 久久久久久99精品| 日韩欧美在线综合网| 日本精品视频一区二区三区| 国产传媒日韩欧美成人| 青青草一区二区三区| 亚洲国产cao| 亚洲免费看黄网站| 国产亚洲综合色| 精品国产乱码久久久久久1区2区| 欧美网站一区二区| 91片黄在线观看| 成人av在线网站| 成人三级在线视频| 黑人精品欧美一区二区蜜桃| 亚洲成av人片www| 一二三四区精品视频| 国产精品白丝在线| ●精品国产综合乱码久久久久| 久久久久国产精品麻豆ai换脸 | 国产电影一区在线| 韩国一区二区三区| 老司机免费视频一区二区三区| 亚洲一区免费视频| 夜夜精品视频一区二区| 国产精品色哟哟网站| 欧美国产日本视频| 国产香蕉久久精品综合网| 欧美mv日韩mv亚洲| xnxx国产精品| 久久美女高清视频| 国产片一区二区| 中文字幕不卡在线播放| 亚洲国产高清在线观看视频| 国产亚洲福利社区一区| 久久久另类综合| 亚洲精品一区在线观看| 久久一区二区三区国产精品| 精品国产乱码久久久久久浪潮| 亚洲精品一区二区三区在线观看 | 亚洲午夜av在线| 午夜不卡av在线| 蜜臀国产一区二区三区在线播放| 蜜桃av一区二区三区电影| 久久国产人妖系列| av在线播放不卡| 色88888久久久久久影院野外| 欧美调教femdomvk| 日韩小视频在线观看专区| 日韩精品中文字幕一区| 久久中文字幕电影| 1024亚洲合集| 亚洲高清视频中文字幕| 午夜成人免费视频| 国产中文字幕一区| 99这里都是精品| 欧美日本高清视频在线观看| 精品久久一二三区| 国产精品视频一区二区三区不卡| 国产精品久久毛片| 亚洲国产精品久久人人爱蜜臀 | 欧美喷潮久久久xxxxx| 日韩欧美一级在线播放| 欧美极品少妇xxxxⅹ高跟鞋 | 成人免费在线观看入口| 午夜日韩在线观看| 国产精品一线二线三线精华| 97国产一区二区| 日韩欧美国产电影| 国产精品电影一区二区| 五月婷婷综合网| 国产成人综合在线| 色噜噜偷拍精品综合在线| 欧美一区二区三区日韩视频| 欧美国产激情一区二区三区蜜月| 亚洲一区二区三区在线看| 精品系列免费在线观看| 色中色一区二区| 国产亚洲欧美一级| 天堂久久久久va久久久久| 国产精品原创巨作av| 欧美日韩三级视频| 中文字幕在线免费不卡| 麻豆精品国产传媒mv男同| 91免费视频大全| 久久久精品综合| 欧美aaaaa成人免费观看视频| 成人久久久精品乱码一区二区三区| 欧美日韩精品欧美日韩精品| 国产精品久久久久7777按摩| 男女视频一区二区| 一本色道久久综合狠狠躁的推荐| 精品国产3级a| 天堂一区二区在线| 99re热这里只有精品视频| 自拍视频在线观看一区二区| 国内国产精品久久| 欧美另类变人与禽xxxxx| 亚洲欧洲日本在线| 成人午夜在线免费| 精品国产露脸精彩对白| 日韩va亚洲va欧美va久久| 色激情天天射综合网| 亚洲欧美日韩综合aⅴ视频| 国产精品99久久久久久久vr| 日韩欧美国产一区二区三区 | 免费观看久久久4p| 精品视频1区2区3区| 亚洲免费观看高清| av中文一区二区三区| 国产喂奶挤奶一区二区三区| 黄页视频在线91| 亚洲精品在线网站| 美腿丝袜亚洲一区| 欧美一区二区三区公司| 日本va欧美va精品发布| 欧美老女人在线| 午夜av区久久| 91精品国产91热久久久做人人 | 亚洲欧美区自拍先锋| 成人18视频日本| 亚洲欧洲无码一区二区三区| 国产不卡在线视频| 国产精品久久精品日日| av影院午夜一区| 亚洲日本韩国一区| 色偷偷88欧美精品久久久| 亚洲欧洲中文日韩久久av乱码| 91在线视频播放| 亚洲成人免费电影| 日韩欧美亚洲一区二区| 国内精品国产成人国产三级粉色| 精品国产不卡一区二区三区| 国产久卡久卡久卡久卡视频精品| 国产日产欧美一区| 99r国产精品| 午夜欧美2019年伦理| 在线播放日韩导航| 狠狠色综合日日| 中国色在线观看另类| 91丨porny丨蝌蚪视频| 亚洲在线视频免费观看| 91精品国产91综合久久蜜臀| 韩国女主播成人在线观看| 国产精品视频免费看| 91麻豆福利精品推荐| 亚洲国产日韩a在线播放性色| 欧美日韩综合不卡| 蜜桃av噜噜一区二区三区小说| 久久久久久久久99精品| 91福利在线播放| 久久精品国产99久久6| 国产精品国产三级国产普通话99|