[P4-dev] Is metadata considered in deparsing?
jblazquez at riotgames.com
Mon Jun 20 19:22:28 EDT 2016
I think of deparsing as simply the reversal of the parsing process, that
is, going through whatever `extract` operations have been executed and
copying those headers back from the Parsed Representation into the packet
In that scenario the use of metadata to switch among parsers shouldn't
change things because all that matters is what `extract` operations have
been performed on actual headers and in which order. Remember that metadata
is by definition not part of the actual packet on the wire so whatever
values your metadata headers have shouldn't matter when it comes to
assembling the packet for transmission.
However, an interesting side question that comes to mind is regarding the
`push`, `pop`, `add_header` and `remove_header` primitive actions. These
are not used during the parsing phase; they're used as part of compound
actions in the ingress or egress pipeline, but they affect the packet that
will be assembled for transmission.
So deparsing isn't _just_ the reversal of the parsing process, but also the
addition/removal of headers as per those primitives above? In which case,
does the order of headers in the transmitted packet follow the order in
which push/add_header/etc have executed for a given packet? And regarding
header stacks, I assume they're always serialized as a single block (i.e.
all valid headers in the stack following each other)? The 1.1 spec doesn't
seem to specify the order in which headers will be serialized to the output
On Mon, Jun 20, 2016 at 3:01 PM, Huynhtu Dang <huynh.tu.dang at usi.ch> wrote:
> Dear all,
> I wonder if metadata is considered in deparsing phase? As I set the value
> of metadata in an action and use this metadata value to switch among
> parsers. But it seems the deparser skips checking the value of metadata or
> the value of metadata is reset before deparsing.
> Tu Dang
> P4-dev mailing list
> P4-dev at lists.p4.org
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the P4-dev