blob: 5e6d700df89e3dc242f64e5cb4aa30ca791ece3b [file] [log] [blame]
Chip Boling6e27b352020-02-14 09:10:01 -06001/*
2 * Copyright (c) 2018 - present. Boling Consulting Solutions (bcsw.net)
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 * http://www.apache.org/licenses/LICENSE-2.0
8 * Unless required by applicable law or agreed to in writing, software
9 * distributed under the License is distributed on an "AS IS" BASIS,
10 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11 * See the License for the specific language governing permissions and
12 * limitations under the License.
13 */
14/*
15 * NOTE: This file was generated, manual edits will be overwritten!
16 *
17 * Generated by 'goCodeGenerator.py':
18 * https://github.com/cboling/OMCI-parser/README.md
19 */
20
21package generated
22
23import "github.com/deckarep/golang-set"
24
25// XdslChannelUpstreamStatusDataClassID is the 16-bit ID for the OMCI
26// Managed entity xDSL channel upstream status data
27const XdslChannelUpstreamStatusDataClassID ClassID = ClassID(103)
28
29var xdslchannelupstreamstatusdataBME *ManagedEntityDefinition
30
31// XdslChannelUpstreamStatusData (class ID #103)
32// This ME contains upstream channel status data for an xDSL UNI. The ONU automatically creates or
33// deletes instances of this ME upon the creation or deletion of a PPTP xDSL UNI part 1.
34//
35// Relationships
36// One or more instances of this ME are associated with an instance of an xDSL UNI.
37//
38// Attributes
39// Managed Entity Id
40// Managed entity ID: This attribute uniquely identifies each instance of this ME. The two MSBs of
41// the first byte are the bearer channel ID. Excluding the first 2-bits of the first byte, the
42// remaining part of the ME ID is identical to that of this ME's parent PPTP xDSL UNI part 1. (R)
43// (mandatory) (2-bytes)
44//
45// Actual Interleaving Delay
46// Actual interleaving delay: This attribute is the actual one-way interleaving delay introduced by
47// the PMS-TC between the alpha and beta reference points, excluding the L1 and L2 states. In the
48// L1 and L2 states, this attribute contains the interleaving delay in the previous L0 state. For
49// ADSL, this attribute is derived from the S and D attributes as cap(S*D)/4-ms, where S is the
50// number of symbols per codeword, D is the interleaving depth and cap() denotes rounding to the
51// next higher integer. For [ITU-T G.993.2], this attribute is computed according to the formula in
52// clause 9.7 of [ITUT G.993.2]. The actual interleaving delay is coded in milliseconds, rounded to
53// the nearest millisecond. (R) (mandatory) (1-byte)
54//
55// Actual Data Rate
56// Actual data rate: This parameter reports the actual net data rate of the bearer channel,
57// excluding the L1 and L2 states. In the L1 or L2 state, the parameter contains the net data rate
58// in the previous L0 state. The data rate is coded in bits per second. (R) (mandatory) (4-bytes)
59//
60// Previous Data Rate
61// Previous data rate: This parameter reports the previous net data rate of the bearer channel just
62// before the latest rate change event occurred, excluding transitions between the L0 state and the
63// L1 or L2 state. A rate change can occur at a power management state transition, e.g., at full or
64// short initialization, fast retrain or power down, or at a dynamic rate adaptation. The rate is
65// coded in bits per second. (R) (mandatory) (4-bytes)
66//
67// Actual Impulse Noise Protection
68// Actual impulse noise protection: The ACTINP attribute reports the actual INP on the bearer
69// channel in the L0 state. In the L1 or L2 state, the attribute contains the INP in the previous
70// L0 state. The value is coded in fractions of DMT symbols with a granularity of 0.1 symbols. The
71// range is from 0 (0.0 symbols) to 254 (25.4 symbols). The special value 255 indicates an ACTINP
72// higher than 25.4. (R) (mandatory for ITU-T G.993.2 VDSL2, optional for other xDSL
73// Recommendations that support it) (1-byte)
74//
75// Impulse Noise Protection Reporting Mode
76// Impulse noise protection reporting mode: The INPREPORT attribute reports the method used to
77// compute the ACTINP. If set to 0, the ACTINP is computed according to the INP_no_erasure formula
78// (clause 9.6 of [ITUT G.993.2]). If set to 1, ACTINP is the value estimated by the xTU receiver.
79// (R) (mandatory for ITU-T G.993.2 VDSL2) (1-byte)
80//
81// Actual Size Of Reed_Solomon Codeword
82// Actual size of Reed-Solomon codeword: The NFEC attribute reports the actual Reed-Solomon
83// codeword size used in the latency path in which the bearer channel is transported. Its value is
84// coded in bytes in the range 0..255. (R) (mandatory for ITU-T G.993.2 VDSL2, optional for others)
85// (1-byte)
86//
87// Actual Number Of Reed_Solomon Redundancy Bytes
88// Actual number of Reed-Solomon redundancy bytes: The RFEC attribute reports the actual number of
89// Reed-Solomon redundancy bytes per codeword used in the latency path in which the bearer channel
90// is transported. Its value is coded in bytes in the range 0..16. The value 0 indicates no Reed-
91// Solomon coding. (R) (mandatory for ITUT-G.993.2 VDSL2, optional for others) (1-byte)
92//
93// Actual Number Of Bits Per Symbol
94// Actual number of bits per symbol: The LSYMB attribute reports the actual number of bits per
95// symbol assigned to the latency path in which the bearer channel is transported, excluding
96// trellis overhead. Its value is coded in bits in the range 0..65535. (R) (mandatory for
97// ITUT-G.993.2 VDSL2, optional for others) (2-bytes)
98//
99// Actual Interleaving Depth
100// Actual interleaving depth: The INTLVDEPTH attribute reports the actual depth of the interleaver
101// used in the latency path in which the bearer channel is transported. Its value ranges from
102// 1..4096 in steps of 1. The value 1 indicates no interleaving. (R) (mandatory for ITU-T G.993.2
103// VDSL2, optional for others) (2-bytes)
104//
105// Actual Interleaving Block Length
106// Actual interleaving block length: The INTLVBLOCK attribute reports the actual block length of
107// the interleaver used in the latency part in which the bearer channel is transported. Its value
108// ranges from 4..255 in steps of 1. (R) (mandatory forITU-T G.993.2 VDSL2, optional for others)
109// (1-byte)
110//
111// Actual Latency Path
112// Actual latency path: The LPATH attribute reports the index of the actual latency path in which
113// the bearer channel is transported. Valid values are 0..3. In [ITUT-G.992.1], the fast path is
114// mapped to latency index 0; the interleaved path to index 1. (R) (mandatory for ITU-T G.993.2
115// VDSL2, optional for others) (1-byte)
116//
117type XdslChannelUpstreamStatusData struct {
118 ManagedEntityDefinition
119 Attributes AttributeValueMap
120}
121
122func init() {
123 xdslchannelupstreamstatusdataBME = &ManagedEntityDefinition{
124 Name: "XdslChannelUpstreamStatusData",
125 ClassID: 103,
126 MessageTypes: mapset.NewSetWith(
127 Get,
128 ),
129 AllowedAttributeMask: 0xffe0,
130 AttributeDefinitions: AttributeDefinitionMap{
131 0: Uint16Field("ManagedEntityId", PointerAttributeType, 0x0000, 0, mapset.NewSetWith(Read), false, false, false, 0),
132 1: ByteField("ActualInterleavingDelay", UnsignedIntegerAttributeType, 0x8000, 0, mapset.NewSetWith(Read), false, false, false, 1),
133 2: Uint32Field("ActualDataRate", UnsignedIntegerAttributeType, 0x4000, 0, mapset.NewSetWith(Read), false, false, false, 2),
134 3: Uint32Field("PreviousDataRate", UnsignedIntegerAttributeType, 0x2000, 0, mapset.NewSetWith(Read), false, false, false, 3),
135 4: ByteField("ActualImpulseNoiseProtection", UnsignedIntegerAttributeType, 0x1000, 0, mapset.NewSetWith(Read), false, false, false, 4),
136 5: ByteField("ImpulseNoiseProtectionReportingMode", UnsignedIntegerAttributeType, 0x0800, 0, mapset.NewSetWith(Read), false, false, false, 5),
137 6: ByteField("ActualSizeOfReedSolomonCodeword", UnsignedIntegerAttributeType, 0x0400, 0, mapset.NewSetWith(Read), false, false, false, 6),
138 7: ByteField("ActualNumberOfReedSolomonRedundancyBytes", UnsignedIntegerAttributeType, 0x0200, 0, mapset.NewSetWith(Read), false, false, false, 7),
139 8: Uint16Field("ActualNumberOfBitsPerSymbol", UnsignedIntegerAttributeType, 0x0100, 0, mapset.NewSetWith(Read), false, false, false, 8),
140 9: Uint16Field("ActualInterleavingDepth", UnsignedIntegerAttributeType, 0x0080, 0, mapset.NewSetWith(Read), false, false, false, 9),
141 10: ByteField("ActualInterleavingBlockLength", UnsignedIntegerAttributeType, 0x0040, 0, mapset.NewSetWith(Read), false, false, false, 10),
142 11: ByteField("ActualLatencyPath", UnsignedIntegerAttributeType, 0x0020, 0, mapset.NewSetWith(Read), false, false, false, 11),
143 },
144 Access: CreatedByOnu,
145 Support: UnknownSupport,
146 }
147}
148
149// NewXdslChannelUpstreamStatusData (class ID 103) creates the basic
150// Managed Entity definition that is used to validate an ME of this type that
151// is received from or transmitted to the OMCC.
152func NewXdslChannelUpstreamStatusData(params ...ParamData) (*ManagedEntity, OmciErrors) {
153 return NewManagedEntity(*xdslchannelupstreamstatusdataBME, params...)
154}