Open Mobile Alliance UserPlane Location Protocol
diff --git a/examples/sample.source.ULP/Makefile b/examples/sample.source.ULP/Makefile
new file mode 100644
index 0000000..417be53
--- /dev/null
+++ b/examples/sample.source.ULP/Makefile
@@ -0,0 +1,339 @@
+ASN_MODULE_SOURCES= \
+ ULP-PDU.c \
+ UlpMessage.c \
+ SUPLINIT.c \
+ Notification.c \
+ NotificationType.c \
+ EncodingType.c \
+ FormatIndicator.c \
+ SLPMode.c \
+ MAC.c \
+ KeyIdentity.c \
+ SUPLSTART.c \
+ SETCapabilities.c \
+ PosTechnology.c \
+ PrefMethod.c \
+ PosProtocol.c \
+ SUPLRESPONSE.c \
+ SETAuthKey.c \
+ KeyIdentity4.c \
+ SUPLPOSINIT.c \
+ RequestedAssistData.c \
+ NavigationModel.c \
+ SatelliteInfo.c \
+ SatelliteInfoElement.c \
+ SUPLPOS.c \
+ PosPayLoad.c \
+ SUPLEND.c \
+ SUPLAUTHREQ.c \
+ SETNonce.c \
+ KeyIdentity2.c \
+ SUPLAUTHRESP.c \
+ SPCAuthKey.c \
+ KeyIdentity3.c \
+ Version.c \
+ SessionID.c \
+ SetSessionID.c \
+ SETId.c \
+ SlpSessionID.c \
+ IPAddress.c \
+ SLPAddress.c \
+ FQDN.c \
+ Ver.c \
+ LocationId.c \
+ Status.c \
+ CellInfo.c \
+ Position.c \
+ PositionEstimate.c \
+ AltitudeInfo.c \
+ CdmaCellInformation.c \
+ GsmCellInformation.c \
+ WcdmaCellInformation.c \
+ FrequencyInfo.c \
+ FrequencyInfoFDD.c \
+ FrequencyInfoTDD.c \
+ UARFCN.c \
+ NMR.c \
+ NMRelement.c \
+ MeasuredResultsList.c \
+ MeasuredResults.c \
+ CellMeasuredResultsList.c \
+ UTRA-CarrierRSSI.c \
+ CellMeasuredResults.c \
+ CellParametersID.c \
+ TGSN.c \
+ PrimaryCCPCH-RSCP.c \
+ TimeslotISCP.c \
+ TimeslotISCP-List.c \
+ PrimaryCPICH-Info.c \
+ CPICH-Ec-N0.c \
+ CPICH-RSCP.c \
+ Pathloss.c \
+ StatusCode.c \
+ QoP.c \
+ Velocity.c \
+ Horvel.c \
+ Horandvervel.c \
+ Horveluncert.c \
+ Horandveruncert.c \
+ PosMethod.c
+
+ASN_MODULE_HEADERS= \
+ ULP-PDU.h \
+ UlpMessage.h \
+ SUPLINIT.h \
+ Notification.h \
+ NotificationType.h \
+ EncodingType.h \
+ FormatIndicator.h \
+ SLPMode.h \
+ MAC.h \
+ KeyIdentity.h \
+ SUPLSTART.h \
+ SETCapabilities.h \
+ PosTechnology.h \
+ PrefMethod.h \
+ PosProtocol.h \
+ SUPLRESPONSE.h \
+ SETAuthKey.h \
+ KeyIdentity4.h \
+ SUPLPOSINIT.h \
+ RequestedAssistData.h \
+ NavigationModel.h \
+ SatelliteInfo.h \
+ SatelliteInfoElement.h \
+ SUPLPOS.h \
+ PosPayLoad.h \
+ SUPLEND.h \
+ SUPLAUTHREQ.h \
+ SETNonce.h \
+ KeyIdentity2.h \
+ SUPLAUTHRESP.h \
+ SPCAuthKey.h \
+ KeyIdentity3.h \
+ Version.h \
+ SessionID.h \
+ SetSessionID.h \
+ SETId.h \
+ SlpSessionID.h \
+ IPAddress.h \
+ SLPAddress.h \
+ FQDN.h \
+ Ver.h \
+ LocationId.h \
+ Status.h \
+ CellInfo.h \
+ Position.h \
+ PositionEstimate.h \
+ AltitudeInfo.h \
+ CdmaCellInformation.h \
+ GsmCellInformation.h \
+ WcdmaCellInformation.h \
+ FrequencyInfo.h \
+ FrequencyInfoFDD.h \
+ FrequencyInfoTDD.h \
+ UARFCN.h \
+ NMR.h \
+ NMRelement.h \
+ MeasuredResultsList.h \
+ MeasuredResults.h \
+ CellMeasuredResultsList.h \
+ UTRA-CarrierRSSI.h \
+ CellMeasuredResults.h \
+ CellParametersID.h \
+ TGSN.h \
+ PrimaryCCPCH-RSCP.h \
+ TimeslotISCP.h \
+ TimeslotISCP-List.h \
+ PrimaryCPICH-Info.h \
+ CPICH-Ec-N0.h \
+ CPICH-RSCP.h \
+ Pathloss.h \
+ StatusCode.h \
+ QoP.h \
+ Velocity.h \
+ Horvel.h \
+ Horandvervel.h \
+ Horveluncert.h \
+ Horandveruncert.h \
+ PosMethod.h
+
+ASN_MODULE_HEADERS+=BOOLEAN.h
+ASN_MODULE_SOURCES+=BOOLEAN.c
+ASN_MODULE_HEADERS+=ENUMERATED.h
+ASN_MODULE_SOURCES+=ENUMERATED.c
+ASN_MODULE_HEADERS+=INTEGER.h
+ASN_MODULE_HEADERS+=NativeEnumerated.h
+ASN_MODULE_HEADERS+=GeneralizedTime.h
+ASN_MODULE_SOURCES+=GeneralizedTime.c
+ASN_MODULE_HEADERS+=IA5String.h
+ASN_MODULE_SOURCES+=IA5String.c
+ASN_MODULE_SOURCES+=INTEGER.c
+ASN_MODULE_SOURCES+=NativeEnumerated.c
+ASN_MODULE_HEADERS+=NativeInteger.h
+ASN_MODULE_SOURCES+=NativeInteger.c
+ASN_MODULE_HEADERS+=UTCTime.h
+ASN_MODULE_SOURCES+=UTCTime.c
+ASN_MODULE_HEADERS+=VisibleString.h
+ASN_MODULE_SOURCES+=VisibleString.c
+ASN_MODULE_HEADERS+=asn_SEQUENCE_OF.h
+ASN_MODULE_SOURCES+=asn_SEQUENCE_OF.c
+ASN_MODULE_HEADERS+=asn_SET_OF.h
+ASN_MODULE_SOURCES+=asn_SET_OF.c
+ASN_MODULE_HEADERS+=constr_CHOICE.h
+ASN_MODULE_SOURCES+=constr_CHOICE.c
+ASN_MODULE_HEADERS+=constr_SEQUENCE.h
+ASN_MODULE_SOURCES+=constr_SEQUENCE.c
+ASN_MODULE_HEADERS+=constr_SEQUENCE_OF.h
+ASN_MODULE_SOURCES+=constr_SEQUENCE_OF.c
+ASN_MODULE_HEADERS+=constr_SET_OF.h
+ASN_MODULE_SOURCES+=constr_SET_OF.c
+ASN_MODULE_HEADERS+=asn_application.h
+ASN_MODULE_HEADERS+=asn_system.h
+ASN_MODULE_HEADERS+=asn_codecs.h
+ASN_MODULE_HEADERS+=asn_internal.h
+ASN_MODULE_HEADERS+=OCTET_STRING.h
+ASN_MODULE_SOURCES+=OCTET_STRING.c
+ASN_MODULE_HEADERS+=BIT_STRING.h
+ASN_MODULE_SOURCES+=BIT_STRING.c
+ASN_MODULE_SOURCES+=asn_codecs_prim.c
+ASN_MODULE_HEADERS+=asn_codecs_prim.h
+ASN_MODULE_HEADERS+=ber_tlv_length.h
+ASN_MODULE_SOURCES+=ber_tlv_length.c
+ASN_MODULE_HEADERS+=ber_tlv_tag.h
+ASN_MODULE_SOURCES+=ber_tlv_tag.c
+ASN_MODULE_HEADERS+=ber_decoder.h
+ASN_MODULE_SOURCES+=ber_decoder.c
+ASN_MODULE_HEADERS+=der_encoder.h
+ASN_MODULE_SOURCES+=der_encoder.c
+ASN_MODULE_HEADERS+=constr_TYPE.h
+ASN_MODULE_SOURCES+=constr_TYPE.c
+ASN_MODULE_HEADERS+=constraints.h
+ASN_MODULE_SOURCES+=constraints.c
+ASN_MODULE_HEADERS+=xer_support.h
+ASN_MODULE_SOURCES+=xer_support.c
+ASN_MODULE_HEADERS+=xer_decoder.h
+ASN_MODULE_SOURCES+=xer_decoder.c
+ASN_MODULE_HEADERS+=xer_encoder.h
+ASN_MODULE_SOURCES+=xer_encoder.c
+ASN_MODULE_HEADERS+=per_support.h
+ASN_MODULE_SOURCES+=per_support.c
+ASN_MODULE_HEADERS+=per_decoder.h
+ASN_MODULE_SOURCES+=per_decoder.c
+ASN_MODULE_HEADERS+=per_encoder.h
+ASN_MODULE_SOURCES+=per_encoder.c
+ASN_MODULE_HEADERS+=per_opentype.h
+ASN_MODULE_SOURCES+=per_opentype.c
+ASN_CONVERTER_SOURCES+=converter-sample.c
+
+
+lib_LTLIBRARIES=libsomething.la
+libsomething_la_SOURCES=$(ASN_MODULE_SOURCES) $(ASN_MODULE_HEADERS)
+
+# This file may be used as an input for make(3)
+# Remove the lines below to convert it into a pure .am file
+TARGET = ulp-dump
+CFLAGS += -DASN_CONVERTER_TITLE="OMA UserPlane Location Protocol decoder" -DHAVE_CONFIG_H -DJUNKTEST -DPDU=ULP_PDU -I.
+OBJS=${ASN_MODULE_SOURCES:.c=.o} ${ASN_CONVERTER_SOURCES:.c=.o}
+
+all: ULP-PDU.c $(TARGET)
+
+$(TARGET): ${OBJS}
+ $(CC) $(CFLAGS) -o $(TARGET) ${OBJS} $(LDFLAGS) $(LIBS)
+
+.SUFFIXES:
+.SUFFIXES: .c .o
+
+.c.o:
+ $(CC) $(CFLAGS) -o $@ -c $<
+
+clean:
+ rm -f $(TARGET)
+ rm -f $(OBJS)
+
+regen: regenerate-from-asn1-source
+
+regenerate-from-asn1-source:
+ ../../asn1c/asn1c -S ../../skeletons -pdu=ULP-PDU -fcompound-names -gen-PER ../ulp.asn1
+
+
+ULP-PDU.c: ../sample.makefile.regen ../ulp.asn1
+ make regen-makefile
+ @touch ULP-PDU.c
+ make
+
+regen-makefile:
+ TITLE="OMA UserPlane Location Protocol decoder" \
+ ASN1CMDOPTS="-fcompound-names -gen-PER" \
+ ASN1MODULES="../ulp.asn1" \
+ ASN1PDU=ULP-PDU \
+ PROGNAME=ulp-dump \
+ ../sample.makefile.regen
+
+check: ${TARGET} check-ber check-xer check-per
+ @echo ================
+ @echo All tests passed
+ @echo ================
+
+check-ber:
+ @if test -f sample-ULP-PDU-1.[db]er ; then \
+ for f in sample-ULP-PDU-*.[db]er; do \
+ for b in 1 17 33 980 8192; do \
+ echo "Recoding $$f into XER and back ($$b)..."; \
+ ./${TARGET} -b $$b -iber -oxer $$f > ./.tmp.1.$$$$ || exit 2; \
+ ./${TARGET} -b $$b -ixer -oxer ./.tmp.1.$$$$ > ./.tmp.2.$$$$ || exit 3; \
+ diff ./.tmp.1.$$$$ ./.tmp.2.$$$$ || exit 4; \
+ rm -f ./.tmp.[12].$$$$; \
+ echo "Test junking $$f (please wait)..."; \
+ ./${TARGET} -J0.0001 -n 1000 -b $$b -iber -onull $$f || exit 5; \
+ ./${TARGET} -J0.001 -n 1000 -b $$b -iber -onull $$f || exit 6; \
+ done; done; fi
+
+check-xer:
+ @if test -f sample-ULP-PDU-1.xer ; then \
+ for f in sample-ULP-PDU-*.xer; do \
+ for b in 1 17 33 980 8192; do \
+ echo "Recoding $$f into DER and back ($$b)..."; \
+ ./${TARGET} -b $$b -ixer -oder $$f > ./.tmp.1.$$$$ || exit 2; \
+ ./${TARGET} -b $$b -iber -oxer ./.tmp.1.$$$$ > ./.tmp.2.$$$$ || exit 3; \
+ diff $$f ./.tmp.2.$$$$ || exit 4; \
+ rm -f ./.tmp.[12].$$$$; \
+ echo "Test junking $$f (please wait)..."; \
+ ./${TARGET} -J0.0001 -n 1000 -b $$b -ixer -onull $$f || exit 5; \
+ ./${TARGET} -J0.001 -n 1000 -b $$b -ixer -onull $$f || exit 6; \
+ done; done; fi
+
+check-per:
+ @if test -f sample-ULP-PDU-1-nopad.per ; then \
+ for f in sample-ULP-PDU-[1-9]-nopad.per; do \
+ for b in 1 17 33 980 8192; do \
+ echo "Recoding non-padded $$f into DER into XER and back ($$b)..."; \
+ ./${TARGET} -b $$b -per-nopad -iper -oder $$f > ./.tmp.1.$$$$ || exit 2; \
+ ./${TARGET} -b $$b -iber -oxer ./.tmp.1.$$$$ > ./.tmp.2.$$$$ || exit 3; \
+ ./${TARGET} -b $$b -ixer -oder ./.tmp.2.$$$$ > ./.tmp.3.$$$$ || exit 4; \
+ diff ./.tmp.1.$$$$ ./.tmp.3.$$$$ || exit 5; \
+ rm -f ./.tmp.[123].$$$$; \
+ echo "Test junking $$f (please wait)..."; \
+ ./${TARGET} -J0.0001 -n 1000 -b $$b -per-nopad -iper -onull $$f || exit 6; \
+ ./${TARGET} -J0.001 -n 1000 -b $$b -per-nopad -iper -onull $$f || exit 7; \
+ done; done; fi
+ @if test -f sample-ULP-PDU-1.per ; then \
+ for f in sample-*-[1-9].per; do \
+ pdu=`echo $$f | sed -E -e "s/sample-([A-Za-z-]+)-[0-9].*/\1/"`; \
+ for b in 1 17 33 980 8192; do \
+ echo "Recoding $$f into DER into XER and back ($$b)..."; \
+ ./${TARGET} -b $$b -p $$pdu -iper -oder $$f > ./.tmp.1.$$$$ || exit 3; \
+ ./${TARGET} -b $$b -p $$pdu -iber -oxer ./.tmp.1.$$$$ > ./.tmp.2.$$$$ || exit 4; \
+ ./${TARGET} -b $$b -p $$pdu -ixer -oper ./.tmp.2.$$$$ > ./.tmp.1.$$$$ || exit 5; \
+ diff $$f ./.tmp.1.$$$$ || exit 6; \
+ rm -f ./.tmp.[12].$$$$; \
+ echo "Test junking $$f (please wait)..."; \
+ ./${TARGET} -J0.0001 -n 1000 -b $$b -iper -onull $$f || exit 7; \
+ ./${TARGET} -J0.001 -n 1000 -b $$b -iper -onull $$f || exit 8; \
+ done; done; fi
+
+distclean: clean
+ rm -f $(ASN_MODULE_SOURCES)
+ rm -f $(ASN_MODULE_HEADERS)
+ rm -f $(ASN_CONVERTER_SOURCES) $(ASN_CONVERTER_HEADERS)
+ rm -f Makefile.am.sample