about Megaco implementation

cy cy_tang@REDACTED
Fri Jul 12 03:46:38 CEST 2002


I have got a project on implementing a Megaco - MGC/MG for load generation
In using the megaco protocol stack with megaco_session for C interface,
I got the following problem in implementing the start of MG:
   It always return a {error, {bad_option,host}} for 
MegacoSessionUdp_open() from the megaco_session.
Am I composing the "ipOptions" wrongly or I still missed something?

By the way, is it possible to include a simple_MG in the megaco_session 
for example.

Best regards,
CY Tang
Advanced Telesoft Ltd.
(852)-2634-0246


Output from megaco_session :

Eshell V5.1.1  (abort with ^G)
(megaco_session@REDACTED)1> MSTI: init -> start transport
MSTI: init -> transport started: <0.87.0>
MSUI: init -> start transport
MSUI: init -> transport started: <0.92.0>
MSUI: open -> entry with
   RequestRef:    1
   ReplyTo:       <51.99.0>
   ReceiveHandle: 
{'Megaco_ReceiveHandle',{'MegacoMessage_MIdUnion','MIdChoice_deviceName',[109,121,95,109,103]},[109,101,103,97,99,111,95,112,114,101,116,116,121,95,116,101,120,116,95,101,110,99,111,100,101,114],[],[109,101,103,97,99,111,95,117,100,112]}
   Options:       
[{'MegacoSessionIp_IpOption','Ip_host',[114,104,108,105,110,117,120,49]},{'MegacoSessionIp_IpOption','Ip_port',2944}]
MSUI: open -> error:
   Error: {error,{bad_option,host}}

=ERROR REPORT==== 12-Jul-2002::09:15:37 ===
'Megaco_SessionFactory_impl'(<0.85.0>): SessionUser node died - mg@REDACTED




Source code from mg

Megaco_SessionUser_startUserResponse__rs*
Megaco_SessionUser_startUserResponse__cb(Megaco_SessionUser oe_obj,
                     CORBA_long *ref,
                     Megaco_Status *status,
                     CORBA_Environment *oe_env) {

   V( ("received startUserResponse\n") );
   ASSERT_OK(status);

     Megaco_ReceiveHandle      rh;
     MegacoSessionIp_IpOption  port[2];
     MegacoSessionIp_IpOptions ipOptions;

      V( ("setup restart\n") );

      rh.localMid = mid;

      // Setup text port for UDP
      port[0]._d      = MegacoSessionIp_Ip_host;
      port[0]._u.host = "rhlinux1";
      port[1]._d      = MegacoSessionIp_Ip_port;
      port[1]._u.port = 2944;

      ipOptions._buffer  = port;
      ipOptions._length  = 2;
      ipOptions._maximum = 2;

      prepare_udp(&dummy);

      /* prepare receive handle for udp text */
      rh.encodingMod    = (CORBA_char*)"megaco_pretty_text_encoder";
      rh.encodingConfig = (CORBA_char*)"";
      rh.sendMod        = (CORBA_char*)"megaco_udp";

      V( ("open UDP text (port 2944) connection\n") );
      MegacoSessionUdp_open(NULL,
               *ref,
               &session_user_pid,
               &rh,
               &ipOptions,
               send_env);
      ASSERT_SEND();
}  





More information about the erlang-questions mailing list