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

📄 telnet_server.pc

📁 无线网络仿真工具Glomosim2.03
💻 PC
字号:
/* * GloMoSim is COPYRIGHTED software.  Release 2.02 of GloMoSim is available  * at no cost to educational users only. * * Commercial use of this software requires a separate license.  No cost, * evaluation licenses are available for such purposes; please contact * info@scalable-networks.com * * By obtaining copies of this and any other files that comprise GloMoSim2.02, * you, the Licensee, agree to abide by the following conditions and * understandings with respect to the copyrighted software: * * 1.Permission to use, copy, and modify this software and its documentation *   for education and non-commercial research purposes only is hereby granted *   to Licensee, provided that the copyright notice, the original author's *   names and unit identification, and this permission notice appear on all *   such copies, and that no charge be made for such copies. Any entity *   desiring permission to use this software for any commercial or *   non-educational research purposes should contact:  * *   Professor Rajive Bagrodia  *   University of California, Los Angeles  *   Department of Computer Science  *   Box 951596  *   3532 Boelter Hall  *   Los Angeles, CA 90095-1596  *   rajive@cs.ucla.edu * * 2.NO REPRESENTATIONS ARE MADE ABOUT THE SUITABILITY OF THE SOFTWARE FOR ANY *   PURPOSE. IT IS PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY. * * 3.Neither the software developers, the Parallel Computing Lab, UCLA, or any *   affiliate of the UC system shall be liable for any damages suffered by *   Licensee from the use of this software. */// Use the latest version of Parsec if this line causes a compiler error./* * $Id: telnet_server.pc,v 1.15 2001/02/15 03:17:26 mineo Exp $ * * This file contains initialization function, message processing * function, and finalize function used by telnet server.  */#include <stdlib.h>#include <stdio.h>#include <string.h>#include <assert.h> #include "api.h"#include "structmsg.h"#include "fileio.h"#include "message.h"#include "application.h"#include "app_util.h"#include "telnet_server.h"#include "tcpapps.h"#include "tcp.h"/* * NAME:        AppLayerTelnetServer. * PURPOSE:     Models the behaviour of Telnet server on receiving the *              message encapsulated in msg. * PARAMETERS:  nodePtr - pointer to the node which received the message. *              msg - message received by the layer * RETURN:      none. */void AppLayerTelnetServer(GlomoNode *nodePtr, Message *msg){    char buf[GLOMO_MAX_STRING_LENGTH];    GlomoAppTelnetServer *serverPtr;    ctoa(simclock(), buf);    switch(msg->eventType)     {        case MSG_APP_FromTransListenResult:         {            TransportToAppListenResult *listenResult;            listenResult = (TransportToAppListenResult *) msg->info;             #ifdef DEBUG                printf("%s: node %u got listenResult\n",                        buf, nodePtr->nodeAddr);            #endif            if (listenResult->connectionId == -1)            {                nodePtr->appData.numAppTcpFailure ++;            }            break;        }        case MSG_APP_FromTransOpenResult:         {            TransportToAppOpenResult *openResult;            openResult = (TransportToAppOpenResult *) msg->info;             #ifdef DEBUG                printf("%s: node %u got OpenResult\n", buf, nodePtr->nodeAddr);            #endif            assert(openResult->type == TCP_CONN_PASSIVE_OPEN);            if (openResult->connectionId < 0)             {                nodePtr->appData.numAppTcpFailure ++;            }             else             {                GlomoAppTelnetServer *serverPtr;                 serverPtr = AppTelnetServerNewTelnetServer(nodePtr, openResult);                assert(serverPtr != NULL);            }            break;        }        case MSG_APP_FromTransDataSent:        {            TransportToAppDataSent *dataSent;            dataSent = (TransportToAppDataSent *) msg->info;                    #ifdef DEBUG                printf("%s: node %u sent data %ld\n", buf, nodePtr->nodeAddr,                       dataSent->length);             #endif            serverPtr = AppTelnetServerGetTelnetServer(nodePtr,                                         dataSent->connectionId);            assert(serverPtr != NULL);            serverPtr->numBytesSent += dataSent->length;            break;        }          case MSG_APP_FromTransDataReceived:         {            TransportToAppDataReceived *dataRecvd;            dataRecvd = (TransportToAppDataReceived *) msg->info;            #ifdef DEBUG                printf("%s: node %u received data %ld\n",                        buf, nodePtr->nodeAddr, msg->packetSize);            #endif            serverPtr = AppTelnetServerGetTelnetServer(nodePtr,                                                        dataRecvd->connectionId);            assert(serverPtr != NULL);            serverPtr->numBytesRecvd += msg->packetSize;            if (msg->packet[msg->packetSize - 1] == 'c')             {                /*                  * Client wants to close the session, so server also                 * initiates a close.                 */                AppTcpCloseConnection(nodePtr, TRANSPORT_PROTOCOL_TCP,                                    serverPtr->connectionId);                serverPtr->sessionFinish = simclock();                serverPtr->sessionIsClosed = TRUE;            }             else if (msg->packet[msg->packetSize - 1] == 'd')             {                /* Send a response packet back. */                if (serverPtr->sessionIsClosed == FALSE)                {                    AppTelnetServerSendResponse(nodePtr, serverPtr);                 }            }            else            {                assert(0);            }            break;        }        case MSG_APP_FromTransCloseResult:        {            TransportToAppCloseResult *closeResult;            closeResult = (TransportToAppCloseResult *) msg->info;            #ifdef DEBUG                printf("%s: node %u got close result\n",                        buf, nodePtr->nodeAddr);            #endif            serverPtr = AppTelnetServerGetTelnetServer(nodePtr,                                                  closeResult->connectionId);            assert(serverPtr != NULL);            if (serverPtr->sessionIsClosed == FALSE)             {                serverPtr->sessionIsClosed = TRUE;                serverPtr->sessionFinish = simclock();            }            break;        }        default:            ctoa(simclock(), buf);            printf("Time %s: Node %u received message of unknown type"                   " %ld.\n", buf, nodePtr->nodeAddr, msg->eventType);            assert(FALSE);    }    GLOMO_MsgFree(nodePtr, msg);}/* * NAME:        AppTelnetServerInit.  * PURPOSE:     listen on Telnet server port.  * PARAMETERS:  nodePtr - pointer to the node. * RETURN:      none.  */voidAppTelnetServerInit(GlomoNode *nodePtr){    AppTcpServerListen(nodePtr,                        TRANSPORT_PROTOCOL_TCP,                        APP_TELNET_SERVER,                       nodePtr->nodeAddr,                        (short)APP_TELNET_SERVER);}/* * NAME:        AppTelnetServerFinalize.  * PURPOSE:     Collect statistics of a Telnet session.  * PARAMETERS:  nodePtr - pointer to the node. *              serverPtr - pointer to the telnet server data structure.  * RETURN:      none.  */voidAppTelnetServerFinalize(GlomoNode *nodePtr, GlomoAppTelnetServer *serverPtr){    clocktype throughput;    char clockStr[GLOMO_MAX_STRING_LENGTH];    char startStr[GLOMO_MAX_STRING_LENGTH];    char closeStr[GLOMO_MAX_STRING_LENGTH];    char buf[GLOMO_MAX_STRING_LENGTH];    char throughputStr[GLOMO_MAX_STRING_LENGTH];    ctoa(serverPtr->sessionStart, startStr);    if (serverPtr->sessionIsClosed == FALSE)     {        serverPtr->sessionFinish = simclock();        ctoa(simclock(), clockStr);        sprintf(closeStr, "%s ns (not closed)", clockStr);    }     else     {        ctoa(serverPtr->sessionFinish, clockStr);        sprintf(closeStr, "%s ns (closed)", clockStr);    }    if (serverPtr->sessionFinish <= serverPtr->sessionStart)     {        throughput = 0;     }     else     {        throughput = (serverPtr->numBytesRecvd * 8.0 * SECOND) /                     (serverPtr->sessionFinish - serverPtr->sessionStart);    }    ctoa(throughput, throughputStr);    sprintf(buf, "from %ld to %ld (cid = %d), start = %s, end = %s, "            "bytes sent = %ld B, bytes recv =  %ld B, throughput = %s bps",            serverPtr->remoteAddr, serverPtr->localAddr,             serverPtr->connectionId, startStr, closeStr,            serverPtr->numBytesSent, serverPtr->numBytesRecvd,            throughputStr);    GLOMO_PrintStat(nodePtr, "AppTelnetServer", buf);}/* * NAME:        AppTelnetServerGetTelnetServer. * PURPOSE:     search for a telnet server data structure.  * PARAMETERS:  nodePtr - pointer to the node,  *              connId - connection ID of the telnet server.  * RETURN:      the pointer to the telnet server data structure, *              NULL if nothing found. */static GlomoAppTelnetServer *AppTelnetServerGetTelnetServer(GlomoNode *nodePtr, int connId){    AppInfo *appList = nodePtr->appData.appPtr;    GlomoAppTelnetServer *telnetServer;        for (; appList != NULL; appList = appList->appNext)     {        if (appList->appType == APP_TELNET_SERVER)         {            telnetServer = (GlomoAppTelnetServer *) appList->appDetail;            if (telnetServer->connectionId == connId)             {                return telnetServer;            }        }    }    return NULL;}/* * NAME:        AppTelnetServerNewTelnetServer. * PURPOSE:     create a new telnet server data structure, place it                at the beginning of the application list.  * PARAMETERS:  nodePtr - pointer to the node,  *              openResult - result of the open request.  * RETRUN:      the pointer to the created telnet server data structure, *              NULL if no data structure allocated.  */static GlomoAppTelnetServer *AppTelnetServerNewTelnetServer(GlomoNode *nodePtr,                                TransportToAppOpenResult *openResult){    AppInfo *newApp;    GlomoAppTelnetServer *telnetServer;    newApp = (AppInfo *) pc_malloc(sizeof(AppInfo));    if (newApp == NULL)     {        assert(FALSE);    }    telnetServer = (GlomoAppTelnetServer *)                     pc_malloc(sizeof(GlomoAppTelnetServer));    /*     * fill in connection id, etc.     */    newApp->appType = APP_TELNET_SERVER;    telnetServer->connectionId = openResult->connectionId;    telnetServer->localAddr = openResult->localAddr;    telnetServer->remoteAddr = openResult->remoteAddr;    telnetServer->sessionStart = simclock();    telnetServer->sessionFinish = 0;     telnetServer->sessionIsClosed = FALSE;     telnetServer->numBytesSent = 0;    telnetServer->numBytesRecvd = 0;    newApp->appDetail = telnetServer;    newApp->appNext = nodePtr->appData.appPtr;     nodePtr->appData.appPtr = newApp;    return telnetServer;}/* * NAME:        AppTelnetServerSendResponse. * PURPOSE:     call AppTelnetServerRespPktSize() to get the  *              response packet size,                 and send the packet.  * PARAMETERS:  nodePtr - pointer to the node,  *              serverPtr - pointer to the server data structure.  * RETRUN:      none.  */static voidAppTelnetServerSendResponse(GlomoNode *nodePtr, GlomoAppTelnetServer *serverPtr){    int pktSize;    char payload[MAX_APP_DATA_UNIT];    pktSize = AppTelnetServerRespPktSize(nodePtr);    AppTcpSendData(nodePtr, TRANSPORT_PROTOCOL_TCP, serverPtr->connectionId,                    payload, pktSize);}/* * NAME:        AppTelnetServerRespPktSize. * PURPOSE:     call tcplib function telnet_pktsize(). * PARAMETERS:  nodePtr - pointer to the node. * RETRUN:      telnet control packet size. */static int AppTelnetServerRespPktSize(GlomoNode *nodePtr){    int ctrlPktSize;    ctrlPktSize = telnet_pktsize(nodePtr->seed);    #ifdef DEBUG        printf("TELNET control pktsize = %d\n", ctrlPktSize);    #endif    return (ctrlPktSize);}

⌨️ 快捷键说明

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