Annotation of 43BSDReno/contrib/isode-beta/quipu/task_result.c, revision 1.1

1.1     ! root        1: /* task_result.c - */
        !             2: 
        !             3: #ifndef lint
        !             4: static char *rcsid = "$Header: /f/osi/quipu/RCS/task_result.c,v 7.0 89/11/23 22:18:14 mrose Rel $";
        !             5: #endif
        !             6: 
        !             7: /*
        !             8:  * $Header: /f/osi/quipu/RCS/task_result.c,v 7.0 89/11/23 22:18:14 mrose Rel $
        !             9:  *
        !            10:  *
        !            11:  * $Log:       task_result.c,v $
        !            12:  * Revision 7.0  89/11/23  22:18:14  mrose
        !            13:  * Release 6.0
        !            14:  * 
        !            15:  */
        !            16: 
        !            17: /*
        !            18:  *                                NOTICE
        !            19:  *
        !            20:  *    Acquisition, use, and distribution of this module and related
        !            21:  *    materials are subject to the restrictions of a license agreement.
        !            22:  *    Consult the Preface in the User's Manual for the full terms of
        !            23:  *    this agreement.
        !            24:  *
        !            25:  */
        !            26: 
        !            27: 
        !            28: /* LINTLIBRARY */
        !            29: 
        !            30: #include "rosap.h"
        !            31: #include "quipu/util.h"
        !            32: #include "quipu/connection.h"
        !            33: 
        !            34: extern  LLog    * log_dsap;
        !            35: void ros_log ();
        !            36: 
        !            37: /*
        !            38: * The DSA has produced a result for the task, encode the result,
        !            39: * generate an RO-RESULT.REQUEST and update the task block.
        !            40: */
        !            41: task_result(task)
        !            42: register        struct task_act * task;
        !            43: {
        !            44:     int                                  result;
        !            45:     struct DSAPindication        di_s;
        !            46:     struct DSAPindication      * di = &(di_s);
        !            47:     struct ds_op_res            * res;
        !            48:     struct connection          * cn = task->tk_conn;
        !            49: 
        !            50: #ifndef NO_STATS
        !            51:     extern LLog * log_stat;
        !            52:     LLOG (log_stat, LLOG_TRACE,("Result sent (%d)",cn->cn_ad));
        !            53: #endif
        !            54: 
        !            55:     DLOG(log_dsap, LLOG_TRACE, ("task_result"));
        !            56: 
        !            57:     if(task == NULLTASK)
        !            58:     {
        !            59:        LLOG(log_dsap, LLOG_FATAL, ("Task memerr 5"));
        !            60:        return;
        !            61:     }
        !            62: 
        !            63:     res = task->tk_result;
        !            64: 
        !            65:     switch (cn->cn_ctx)
        !            66:     {
        !            67:        case DS_CTX_X500_DAP:
        !            68:             watch_dog("DapResultRequest");
        !            69:            result = DapResultRequest (cn->cn_ad, task->tk_dx.dx_id,
        !            70:                                        &(res->dcr_dsres), di);
        !            71:             watch_dog_reset();
        !            72:            break;
        !            73:        case DS_CTX_X500_DSP:
        !            74:             watch_dog("DspResultRequest");
        !            75:            result = DspResultRequest (cn->cn_ad, task->tk_dx.dx_id, res, di);
        !            76:             watch_dog_reset();
        !            77:            break;
        !            78:        case DS_CTX_QUIPU_DSP:
        !            79:             watch_dog("QspResultRequest");
        !            80:            result = QspResultRequest (cn->cn_ad, task->tk_dx.dx_id, res, di);
        !            81:             watch_dog_reset();
        !            82:            break;
        !            83:        default:
        !            84:            LLOG (log_dsap, LLOG_EXCEPTIONS, ("task_result(): Unknown context %d", cn->cn_ctx));
        !            85:            break;
        !            86:     }
        !            87: 
        !            88:     if (result != OK)
        !            89:     {
        !            90:        if(di->di_type == DI_ABORT)
        !            91:        {
        !            92:            LLOG(log_dsap, LLOG_FATAL, ("D-RESULT.REQUEST: fatal reject - fail the connection"));
        !            93:            cn->cn_state = CN_FAILED;
        !            94:        }
        !            95:        else
        !            96:        {
        !            97:            send_ro_ureject(cn->cn_ad, &(task->tk_dx.dx_id), ROS_IP_RELEASE);
        !            98:        }
        !            99:     }
        !           100: 
        !           101:     if(cn->cn_state == CN_FAILED)
        !           102:     {
        !           103:        DLOG(log_dsap, LLOG_DEBUG, ("task_result(): extracting conn:"));
        !           104:        conn_log(cn);
        !           105:        conn_extract(cn);
        !           106:     }
        !           107: }
        !           108: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.