Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ETSI ITS DENM ReferenceDenms extension flag problem #290

Open
MemoTrap opened this issue Jul 24, 2018 · 5 comments · May be fixed by #408
Open

ETSI ITS DENM ReferenceDenms extension flag problem #290

MemoTrap opened this issue Jul 24, 2018 · 5 comments · May be fixed by #408

Comments

@MemoTrap
Copy link

I am working with asn1c for half a year meanwhile. It's an excellent tool. Many thanks for it.

I may have found a generator bug now. The (ETSI ITS) DENM ASN.1 spec (attached) has a definition:

ReferenceDenms ::= SEQUENCE SIZE (1..8, ...) OF ActionID

It carries the extension marker. ActionID is a sequence of two elements, a complex type. In this combination it appears to be the only one of this kind in the entire DENM ASN.1 spec (and the imported ITS Common spec, included as integrated part in the attachment here).

In the C code produced by the asn1c generator for PER constraints I get

asn_per_constraints_t asn_PER_type_ReferenceDenms_constr_1 CC_NOTUSED = {
	{ APC_UNCONSTRAINED,	-1, -1,  0,  0 },
	{ APC_CONSTRAINED,	 3,  3,  1,  8 }	/* (SIZE(1..8)) */,
	0, 0	/* No PER value map */
};

I encoded with asn1c UPER and I tried to decode with http://asn1-playground.oss.com/ without success. ReferenceDenms (RoadworksContainer in AlacarteContainer) and everything hereafter is out of sync and asn1-playground reports an error.

I then manually added the extension flag:

asn_per_constraints_t asn_PER_type_ReferenceDenms_constr_1 CC_NOTUSED = {
	{ APC_UNCONSTRAINED,	-1, -1,  0,  0 },
	{ APC_CONSTRAINED | APC_EXTENSIBLE,  3,  3,  1,  8 }	/* (SIZE(1..8)) */,
	0, 0	/* No PER value map */
};

And now it all works, asn1-playground is happy.

ITS DENM v1.2.2.asn.zip

@brchiu
Copy link
Contributor

brchiu commented Jul 24, 2018

Looks like function asn1constraint_pullup() calling _remove_extensions(arg, ct_expr, 1); removes extension part of constraint SIZE(1..8,...).

Though simply removing the calling of _remove_extensions(arg, ct_expr, 1); can add APC_EXTENSIBLE flag to asn_PER_type_ReferenceDenms_constr_1, it also break several regression tests when perform make check.

I don't have enough knowledge to verdict whether these regression tests need to be revised ? Or asn1constraint_pullup() should only call _remove_extensions(arg, ct_expr, 1); under certain condition ?

@mouse07410
Copy link

@velichkov do you have any idea why it would ever make sense to remove extensions if they were specified?

@vlm any comment here?

Thanks!

@brchiu
Copy link
Contributor

brchiu commented Aug 1, 2018

@mouse07410 , according to X.680, I.4.2.3 & I.4.4, there must be some conditions that extension additions are to be discarded, but related code logic might need be revised.

I.4.2.3
There are two key points in the serial application of constraints:
– If a constrained type is extensible (and perhaps extended), the "extensible" flag and all extension
additions are discarded if a further constraint is subsequently serially applied. The extensibility of a
constrained type (and any extension additions) depends solely on the last constraint that is applied, which
can reference only values in the root of the type that is being further constrained (the parent type). Values
included in the root or the extension additions of the resulting type can only be values that are in the root
of the parent type.
– The serial application of constraints is (for complex cases) not the same as a set arithmetic intersection,
even when there is no extensibility involved. Firstly, the environment in which MIN and MAX are
interpreted, and secondly the abstract values that can be referenced in the second constraint are very
different in serial application from the situation where the two constraints are specified as an intersection
of values from a common parent.

I.4.4
Use of the Contained Subtype notation
A contained subtype may or may not be extensible, but when it is used in set arithmetic it is always 
treated as not extensible, and all its extension additions are discarded.

@mouse07410
Copy link

@brchiu the above seems to imply that the same ASN.1 file could produce encoding with member constraints either honored or dropped, depending on what format is used?

@riebl
Copy link

riebl commented Oct 30, 2020

DENM v1.3.1 defines ReferenceDenms ::= SEQUENCE (SIZE(1..8, ...)) OF ActionID. Please note the additional parentheses around SIZE(1..8, ...) compared to the original definition given by @MemoTrap.
Interestingly, asn1c seems to add APC_EXTENSIBLE only if these parentheses are present while other tools such as ffasn1c and https://asn1.io/asn1playground/ are less picky.
To be honest, I don't know at the moment which one is right.

riebl added a commit to riebl/asn1c that referenced this issue Oct 31, 2020
Fix vlm#290, vlm#383, vlm#470 where APC_EXTENSIBLE is lost for SEQUENCE SIZE(, ...) OF
@riebl riebl linked a pull request Oct 31, 2020 that will close this issue
riebl added a commit to riebl/asn1c that referenced this issue Oct 31, 2020
Fix vlm#290, vlm#383, vlm#407 where APC_EXTENSIBLE is lost for SEQUENCE SIZE(, ...) OF
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants