diff --git a/core/Encdec.cc b/core/Encdec.cc index f85fdc36371ad2cb788bce41d33208d21faa3893..cfa24d7f778974dfde5c109100ea558a9247ab92 100644 --- a/core/Encdec.cc +++ b/core/Encdec.cc @@ -743,9 +743,10 @@ void TTCN_Buffer::put_b(size_t len, const unsigned char *s, } /*printf("len:%d\r\n",len); printf("align:%d\r\n",align); -printf("coding bito:%s,byte:%s,field:%s\r\n",coding_par.bitorder==ORDER_MSB?"M":"L", +printf("coding bito:%s,byte:%s,field:%s, hex: %s\r\n",coding_par.bitorder==ORDER_MSB?"M":"L", coding_par.byteorder==ORDER_MSB?"M":"L", -coding_par.fieldorder==ORDER_MSB?"M":"L" +coding_par.fieldorder==ORDER_MSB?"M":"L", +coding_par.hexorder==ORDER_MSB?"M":"L" ); printf("local bito:%s,field:%s\r\n",local_bitorder==ORDER_MSB?"M":"L", local_fieldorder==ORDER_MSB?"M":"L" @@ -798,7 +799,7 @@ local_fieldorder==ORDER_MSB?"M":"L" //printf("new_size:%d new_bit_pos:%d\r\n",new_size,new_bit_pos); if(coding_par.hexorder==ORDER_MSB){ st2=(unsigned char*)Malloc((len+7)/8*sizeof(unsigned char)); - if(bit_pos==4){ + if(bit_pos==4 && local_fieldorder==ORDER_LSB){ st2[0]=s[0]; for(size_t a=1;a<(len+7)/8;a++){ unsigned char ch='\0'; @@ -1208,7 +1209,7 @@ void TTCN_Buffer::get_b(size_t len, unsigned char *s, } } if(coding_par.hexorder==ORDER_MSB){ - if(bit_pos==4){ + if(bit_pos==4 && local_fieldorder==ORDER_LSB){ for(size_t a=1;a<(len+7)/8;a++){ unsigned char ch='\0'; ch|=s[a-1]>>4; diff --git a/regression_test/EncodeDecode/RAW/Makefile b/regression_test/EncodeDecode/RAW/Makefile index 2b3e6a59143e1f85052fc367b6637c76ceb463ea..59cb8f9c49ad532c928f95a59b7ad572c8d75258 100644 --- a/regression_test/EncodeDecode/RAW/Makefile +++ b/regression_test/EncodeDecode/RAW/Makefile @@ -20,7 +20,7 @@ include $(TOPDIR)/Makefile.regression RDIRS = Examples HN25015 HQ26535 HQ49956 HS16977 ustr Annex_E_variants Bug521125 \ Lengthto_Offset Bug522656 RAW_bitstring RAW_EncDec RAW_integer RAW_repeat ForceOmit Bug546231 \ - Bug547385 IntX CSN1_LH Bug572603 Issue555 + Bug547385 IntX CSN1_LH Bug572603 Issue555 issue557 all dep clean run distclean: for dir in $(RDIRS); do (cd $$dir && $(MAKE) $@) || exit; done diff --git a/regression_test/EncodeDecode/RAW/issue557/.gitignore b/regression_test/EncodeDecode/RAW/issue557/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..384fefe014fdf19b702ffa4d25d2c3a6b5bfa7be --- /dev/null +++ b/regression_test/EncodeDecode/RAW/issue557/.gitignore @@ -0,0 +1,8 @@ +Issue557 +Issue557.exe +Issue557*.cc +Issue557*.hh +*.d +compile +Issue557*.log +result.txt diff --git a/regression_test/EncodeDecode/RAW/issue557/Issue557.ttcn b/regression_test/EncodeDecode/RAW/issue557/Issue557.ttcn new file mode 100644 index 0000000000000000000000000000000000000000..22a8a19688d4036d78e4c4d77700b262fa9083c7 --- /dev/null +++ b/regression_test/EncodeDecode/RAW/issue557/Issue557.ttcn @@ -0,0 +1,67 @@ +/****************************************************************************** + * Copyright (c) 2000-2021 Ericsson Telecom AB + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.html + * + * Contributors: + * Gabor, Szalai – initial implementation + * + ******************************************************************************/ + +module Issue557 { + + +type record R4{ + bitstring f1 length(4), + hexstring f2 +} with { + variant (f2) "HEXORDER(high)" + variant "FIELDORDER(msb)" +} + +type component CT{} + +template bitstring t_expected_encoded:=oct2bit('F123456789'O) +template R4 t_expected_decoded:={'1111'B, '123456789'H } + +testcase tc_issue557() runs on CT { + var R4 vl_pdu4:={'1111'B, '123456789'H } + var bitstring vl_encoded:=encvalue(vl_pdu4) + + log(vl_pdu4, " encoded as ",bit2oct(vl_encoded), " expected as ", bit2oct(valueof(t_expected_encoded))) + if(match(vl_encoded,t_expected_encoded)){ + setverdict(pass) + } else { + setverdict(fail, "wrong encoded value") + } + + vl_encoded:=valueof(t_expected_encoded) + var integer vl_res:=decvalue(vl_encoded,vl_pdu4) + + log("decode result: ", vl_res) + + if(vl_res == 0) { + setverdict(pass) + log(bit2oct(valueof(t_expected_encoded)), " decoded as ",vl_pdu4, " expected as ", t_expected_decoded) + if(match(vl_pdu4,t_expected_decoded)){ + setverdict(pass) + } else { + setverdict(fail, "wrong decoded value") + } + } else { + setverdict(fail, "Decoding failed") + } + + + +} + +control { + execute(tc_issue557()); +} + +} with { + encode "RAW" +} diff --git a/regression_test/EncodeDecode/RAW/issue557/Makefile b/regression_test/EncodeDecode/RAW/issue557/Makefile new file mode 100644 index 0000000000000000000000000000000000000000..c04153ffe28e313619888908328947e6e39e05fe --- /dev/null +++ b/regression_test/EncodeDecode/RAW/issue557/Makefile @@ -0,0 +1,149 @@ +############################################################################## +# Copyright (c) 2000-2021 Ericsson Telecom AB +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Eclipse Public License v2.0 +# which accompanies this distribution, and is available at +# https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.html +# +# Contributors: +# Gabor, Szalai – initial implementation +# +############################################################################## +TOPDIR := ../../.. +include $(TOPDIR)/Makefile.regression + +# WARNING! This Makefile can be used with GNU make only. +# Other versions of make may report syntax errors in it. + +# +# Do NOT touch this line... +# +.PHONY: all archive check clean dep objects + +.SUFFIXES: .d + +# +# Set these variables... +# + +# Flags for dependency generation +CXXDEPFLAGS = -MM + +ifeq ($(PLATFORM), WIN32) +# Silence linker warnings. +# Overridden by Makefile.cfg +endif + +# Flags for the TTCN-3 and ASN.1 compiler: +COMPILER_FLAGS += + +# Execution mode: (either ttcn3 or ttcn3-parallel) +TTCN3_LIB = ttcn3$(RT2_SUFFIX)$(DYNAMIC_SUFFIX) + + +# +# You may change these variables. Add your files if necessary... +# + +# TTCN-3 modules of this project: +TTCN3_MODULES = Issue557.ttcn + +# ASN.1 modules of this project: +ASN1_MODULES = + +# C++ source & header files generated from the TTCN-3 & ASN.1 modules of +# this project: +GENERATED_SOURCES = $(TTCN3_MODULES:.ttcn=.cc) $(ASN1_MODULES:.asn=.cc) +GENERATED_HEADERS = $(GENERATED_SOURCES:.cc=.hh) +ifdef SPLIT_TO_SLICES +POSTFIXES := $(foreach file, $(SPLIT_TO_SLICES), $(addsuffix $(file), _part_)) +POSTFIXES := $(foreach file, $(POSTFIXES), $(addprefix $(file), .cc)) +GENERATED_SOURCES2 := $(foreach file, $(GENERATED_SOURCES:.cc=), $(addprefix $(file), $(POSTFIXES))) +GENERATED_SOURCES += $(GENERATED_SOURCES2) +endif +# C/C++ Source & header files of Test Ports, external functions and +# other modules: +USER_SOURCES = +USER_HEADERS = $(USER_SOURCES:.cc=.hh) + +# Object files of this project that are needed for the executable test suite: +OBJECTS = $(GENERATED_OBJECTS) $(USER_OBJECTS) + +GENERATED_OBJECTS = $(GENERATED_SOURCES:.cc=.o) + +USER_OBJECTS = $(USER_SOURCES:.cc=.o) + +DEPFILES = $(USER_OBJECTS:.o=.d) $(GENERATED_OBJECTS:.o=.d) + + +# The name of the executable test suite: +TARGET = Issue557$(EXESUFFIX) + + +# Rules for building the executable... +# + +all: $(TARGET) + +objects: $(OBJECTS) ; + +$(TARGET): $(OBJECTS) + if $(CXX) $(LDFLAGS) -o $@ $^ \ + -L$(TTCN3_DIR)/lib -l$(TTCN3_LIB) \ + -L$(OPENSSL_DIR)/lib -lcrypto \ + -L$(XMLDIR)/lib $($(PLATFORM)_LIBS); \ + then : ; else $(TTCN3_DIR)/bin/titanver $(OBJECTS); exit 1; fi + +.cc.o .c.o: + $(CXX) -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $< + +.cc.d .c.d: + @echo Creating dependency file for '$<'; set -e; \ + $(CXX) $(CXXDEPFLAGS) $(CPPFLAGS) $(CXXFLAGS) $< \ + | sed 's/\($*\)\.o[ :]*/\1.o $@ : /g' > $@; \ + [ -s $@ ] || rm -f $@ + +$(GENERATED_SOURCES) $(GENERATED_HEADERS): compile + @if [ ! -f $@ ]; then $(RM) compile; $(MAKE) compile; fi + +compile: $(TTCN3_MODULES) $(ASN1_MODULES) + $(TTCN3_COMPILER) $(COMPILER_FLAGS) $^ - $? + touch $@ + + +clean: + -$(RM) $(TARGET) $(OBJECTS) $(GENERATED_HEADERS) \ + $(GENERATED_SOURCES) compile $(DEPFILES) \ + tags *.log + +distclean: clean + -$(RM) $(DEPFILES) + + +dep: $(GENERATED_SOURCES) $(USER_SOURCES) ; + +ifeq ($(findstring n,$(MAKEFLAGS)),) +ifeq ($(filter clean distclean check compile archive diag,$(MAKECMDGOALS)),) +-include $(DEPFILES) +endif +endif + + + +diag: + $(TTCN3_COMPILER) -v 2>&1 + $(TTCN3_DIR)/bin/mctr_cli -v 2>&1 + $(CXX) -v 2>&1 + @echo TTCN3_DIR=$(TTCN3_DIR) + @echo OPENSSL_DIR=$(OPENSSL_DIR) + @echo XMLDIR=$(XMLDIR) + @echo PLATFORM=$(PLATFORM) + +# +# Add your rules here if necessary... +# + +run: $(TARGET) ./config.cfg + ./$^ 2> result.txt + cat result.txt + grep "Overall verdict: pass" result.txt diff --git a/regression_test/EncodeDecode/RAW/issue557/config.cfg b/regression_test/EncodeDecode/RAW/issue557/config.cfg new file mode 100644 index 0000000000000000000000000000000000000000..9e6097f28b9fe3b2dfc4556df364532ae5d703f4 --- /dev/null +++ b/regression_test/EncodeDecode/RAW/issue557/config.cfg @@ -0,0 +1,20 @@ +############################################################################### +# Copyright (c) 2000-2021 Ericsson Telecom AB +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Eclipse Public License v2.0 +# which accompanies this distribution, and is available at +# https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.html +# +# Contributors: +# Botond, Baranyi +# +############################################################################### +[LOGGING] +LogFile := "Issue557.log" +FileMask := LOG_ALL +ConsoleMask := TTCN_ERROR | TTCN_TESTCASE | TTCN_STATISTICS +LogSourceInfo := Yes +[EXECUTE] +Issue557.control + +[TESTPORT_PARAMETERS]