initial import of new IPA test port
diff --git a/library/IPA_CodecPort.ttcn b/library/IPA_CodecPort.ttcn
new file mode 100644
index 0000000..70d3ccb
--- /dev/null
+++ b/library/IPA_CodecPort.ttcn
@@ -0,0 +1,44 @@
+module IPA_CodecPort {
+
+ import from IPL4asp_PortType all;
+ import from IPL4asp_Types all;
+ import from IPA_Types all;
+
+ type record IPA_RecvFrom {
+ ConnectionId connId,
+ IpaStreamId streamId,
+ octetstring msg
+ }
+
+ type record IPA_Send {
+ ConnectionId connId,
+ IpaStreamId streamId,
+ octetstring msg
+ }
+
+ private function IPL4_to_IPA_RecvFrom(in ASP_RecvFrom pin, out IPA_RecvFrom pout) {
+ var PDU_IPA ipa := dec_PDU_IPA(pin.msg);
+ pout.connId := pin.connId;
+ pout.streamId := ipa.streamId
+ pout.msg := ipa.payloadData;
+ } with { extension "prototype(fast)" }
+
+ private function IPA_to_IPL4_Send(in IPA_Send pin, out ASP_Send pout) {
+ var PDU_IPA ipa := { 0, pin.streamId, pin.msg };
+ pout.connId := pin.connId;
+ pout.proto := { tcp := {} };
+ pout.msg := enc_PDU_IPA(ipa);
+ } with { extension "prototype(fast)" }
+
+ type port IPA_CODEC_PT message {
+ out IPA_Send;
+ in IPA_RecvFrom,
+ ASP_ConnId_ReadyToRelease,
+ ASP_Event;
+ } with { extension "user IPL4asp_PT
+ out(IPA_Send -> ASP_Send:function(IPA_to_IPL4_Send))
+ in(ASP_RecvFrom -> IPA_RecvFrom: function(IPL4_to_IPA_RecvFrom);
+ ASP_ConnId_ReadyToRelease -> ASP_ConnId_ReadyToRelease: simple;
+ ASP_Event -> ASP_Event: simple)"
+ }
+}
diff --git a/library/IPA_CodecPort_CtrlFunct.ttcn b/library/IPA_CodecPort_CtrlFunct.ttcn
new file mode 100644
index 0000000..c0e7de6
--- /dev/null
+++ b/library/IPA_CodecPort_CtrlFunct.ttcn
@@ -0,0 +1,44 @@
+module IPA_CodecPort_CtrlFunct {
+
+ import from IPA_CodecPort all;
+ import from IPL4asp_Types all;
+
+ external function f_IPL4_listen(
+ inout IPA_CODEC_PT portRef,
+ in HostName locName,
+ in PortNumber locPort,
+ in ProtoTuple proto,
+ in OptionList options := {}
+ ) return Result;
+
+ external function f_IPL4_connect(
+ inout IPA_CODEC_PT portRef,
+ in HostName remName,
+ in PortNumber remPort,
+ in HostName locName,
+ in PortNumber locPort,
+ in ConnectionId connId,
+ in ProtoTuple proto,
+ in OptionList options := {}
+ ) return Result;
+
+ external function f_IPL4_close(
+ inout IPA_CODEC_PT portRef,
+ in ConnectionId id,
+ in ProtoTuple proto := { unspecified := {} }
+ ) return Result;
+
+ external function f_IPL4_setUserData(
+ inout IPA_CODEC_PT portRef,
+ in ConnectionId id,
+ in UserData userData
+ ) return Result;
+
+ external function f_IPL4_getUserData(
+ inout IPA_CODEC_PT portRef,
+ in ConnectionId id,
+ out UserData userData
+ ) return Result;
+
+}
+
diff --git a/library/IPA_CodecPort_CtrlFunctDef.cc b/library/IPA_CodecPort_CtrlFunctDef.cc
new file mode 100644
index 0000000..6d47305
--- /dev/null
+++ b/library/IPA_CodecPort_CtrlFunctDef.cc
@@ -0,0 +1,56 @@
+#include "IPL4asp_PortType.hh"
+#include "IPA_CodecPort.hh"
+#include "IPL4asp_PT.hh"
+
+namespace IPA__CodecPort__CtrlFunct {
+
+ IPL4asp__Types::Result f__IPL4__listen(
+ IPA__CodecPort::IPA__CODEC__PT& portRef,
+ const IPL4asp__Types::HostName& locName,
+ const IPL4asp__Types::PortNumber& locPort,
+ const IPL4asp__Types::ProtoTuple& proto,
+ const IPL4asp__Types::OptionList& options)
+ {
+ return f__IPL4__PROVIDER__listen(portRef, locName, locPort, proto, options);
+ }
+
+ IPL4asp__Types::Result f__IPL4__connect(
+ IPA__CodecPort::IPA__CODEC__PT& portRef,
+ const IPL4asp__Types::HostName& remName,
+ const IPL4asp__Types::PortNumber& remPort,
+ const IPL4asp__Types::HostName& locName,
+ const IPL4asp__Types::PortNumber& locPort,
+ const IPL4asp__Types::ConnectionId& connId,
+ const IPL4asp__Types::ProtoTuple& proto,
+ const IPL4asp__Types::OptionList& options)
+ {
+ return f__IPL4__PROVIDER__connect(portRef, remName, remPort,
+ locName, locPort, connId, proto, options);
+ }
+
+ IPL4asp__Types::Result f__IPL4__close(
+ IPA__CodecPort::IPA__CODEC__PT& portRef,
+ const IPL4asp__Types::ConnectionId& connId,
+ const IPL4asp__Types::ProtoTuple& proto)
+ {
+ return f__IPL4__PROVIDER__close(portRef, connId, proto);
+ }
+
+ IPL4asp__Types::Result f__IPL4__setUserData(
+ IPA__CodecPort::IPA__CODEC__PT& portRef,
+ const IPL4asp__Types::ConnectionId& connId,
+ const IPL4asp__Types::UserData& userData)
+ {
+ return f__IPL4__PROVIDER__setUserData(portRef, connId, userData);
+ }
+
+ IPL4asp__Types::Result f__IPL4__getUserData(
+ IPA__CodecPort::IPA__CODEC__PT& portRef,
+ const IPL4asp__Types::ConnectionId& connId,
+ IPL4asp__Types::UserData& userData)
+ {
+ return f__IPL4__PROVIDER__getUserData(portRef, connId, userData);
+ }
+
+}
+
diff --git a/library/IPA_Types.ttcn b/library/IPA_Types.ttcn
new file mode 100644
index 0000000..ceb31ce
--- /dev/null
+++ b/library/IPA_Types.ttcn
@@ -0,0 +1,31 @@
+/* (C) 2017 by Harald Welte <laforge@gnumonks.org> */
+
+module IPA_Types {
+
+import from Osmocom_Types all;
+
+type uint8_t IpaStreamId;
+
+external function enc_PDU_IPA(in PDU_IPA pdu) return octetstring
+with { extension "prototype(convert)"
+ extension "encode(RAW)"
+ }
+
+external function dec_PDU_IPA(in octetstring stream) return PDU_IPA
+with { extension "prototype(convert)"
+ extension "decode(RAW)"
+ }
+
+type record PDU_IPA
+{
+ uint16_t lengthInd,
+ IpaStreamId streamId,
+ octetstring payloadData
+} with {
+ variant (lengthInd) "LENGTHTO(lengthInd,streamId,payloadData)";
+ variant (lengthInd) "FIELDLENGTH(16)";
+ variant (lengthInd) "BYTEORDER(last)";
+ encode "RAW";
+}
+
+}