blob: a2b7b6be3c8eeb7b4fecdc85577b7af3e2a5679a [file] [log] [blame]
Holger Hildebrandtfa074992020-03-27 15:42:06 +00001/*
2 * Copyright (c) 2018 - present. Boling Consulting Solutions (bcsw.net)
3 * Copyright 2020-present Open Networking Foundation
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +00004 *
Holger Hildebrandtfa074992020-03-27 15:42:06 +00005 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +00008 *
Holger Hildebrandtfa074992020-03-27 15:42:06 +00009 * http://www.apache.org/licenses/LICENSE-2.0
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +000010 *
Holger Hildebrandtfa074992020-03-27 15:42:06 +000011 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
David K. Bainbridged80007b2021-04-12 12:22:29 +000017/*
Holger Hildebrandtfa074992020-03-27 15:42:06 +000018 * NOTE: This file was generated, manual edits will be overwritten!
19 *
20 * Generated by 'goCodeGenerator.py':
21 * https://github.com/cboling/OMCI-parser/README.md
22 */
23
24package generated
25
26import "github.com/deckarep/golang-set"
27
28// Vdsl2LineInventoryAndStatusDataPart2ClassID is the 16-bit ID for the OMCI
29// Managed entity VDSL2 line inventory and status data part 2
mpagenko836a1fd2021-11-01 16:12:42 +000030const Vdsl2LineInventoryAndStatusDataPart2ClassID = ClassID(169) // 0x00a9
Holger Hildebrandtfa074992020-03-27 15:42:06 +000031
32var vdsl2lineinventoryandstatusdatapart2BME *ManagedEntityDefinition
33
mpagenko836a1fd2021-11-01 16:12:42 +000034// Vdsl2LineInventoryAndStatusDataPart2 (Class ID: #169 / 0x00a9)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000035// This ME extends the xDSL line configuration MEs. The ME name was chosen because its attributes
36// were initially unique to ITU-T G.993.2 VDSL2. Due to continuing standards development, some
37// attributes - and therefore this ME - have also become applicable to other Recommendations,
38// specifically [ITU-T G.992.3] and [ITU-T G.992.5].
39//
40// This ME contains upstream attributes.
41//
42// Relationships
43// This is one of the status data MEs associated with an xDSL UNI. It is meaningful if the PPTP
44// supports [ITU-T G.992.3], [ITU-T G.992.5] or [ITU-T G.993.2]. The ONU automatically creates or
45// deletes an instance of this ME upon creation and deletion of a PPTP xDSL UNI part 1 that
46// supports these attributes.
47//
48// Attributes
49// Managed Entity Id
mpagenko836a1fd2021-11-01 16:12:42 +000050// This attribute uniquely identifies each instance of this ME. Through an identical ID, this ME is
51// implicitly linked to an instance of the PPTP xDSL UNI part 1 ME. (R) (mandatory) (2-bytes)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000052//
53// Vdsl2 Transmission System Capability Xtu_R
54// VDSL2 transmission system capability xTU-R: This attribute extends the xTU-R transmission system
55// capability attribute of the xDSL line inventory and status data part 1 to include xTUR VDSL2
56// capabilities. It is a defined by bits 57..64 of Table 9.7.12-1. (R) (mandatory) (1-byte)
57//
58// Actsnrmodeus
mpagenko836a1fd2021-11-01 16:12:42 +000059// 1 Virtual noise inactive
60//
61// 2 Virtual noise active
62//
Holger Hildebrandtfa074992020-03-27 15:42:06 +000063// (R) (mandatory) (1-byte)
64//
mpagenko836a1fd2021-11-01 16:12:42 +000065// This attribute indicates whether transmitter-referred virtual noise is active on the line in the
66// upstream direction.
67//
Holger Hildebrandtfa074992020-03-27 15:42:06 +000068// Upbokle
mpagenko836a1fd2021-11-01 16:12:42 +000069// This attribute contains the electrical length estimated by the VTU-O expressed in decibels at
70// 1-MHz, kl0 (see O-UPDATE in clause 12.3.3.2.1.2 of [ITUT-G.993.2]). This is the final electrical
71// length that would have been sent from the VTU-O to the VTU-R if the electrical length were not
72// forced by the OLT. The value lies in the range 0 (0.0-dB) to 1280 (128.0-dB) (R) (mandatory)
73// (2-bytes)
74//
75// The following four attributes have similar definitions. In each case, valid attribute values are
76// 1, 2, 4, 8. In ADSL applications, the corresponding value is fixed at 1, and therefore need not
77// be specified. For VDSL2, it is equal to the size of the subcarrier group used to compute these
78// attributes (see clause 11.4.1 of [ITUT G.993.2]).
Holger Hildebrandtfa074992020-03-27 15:42:06 +000079//
80// Hlingus
mpagenko836a1fd2021-11-01 16:12:42 +000081// This attribute is the number of subcarriers per group used to report HLINpsus. (R) (mandatory)
82// (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000083//
84// Hloggus
mpagenko836a1fd2021-11-01 16:12:42 +000085// This attribute is the number of subcarriers per group used to report HLOGpsus. (R) (mandatory)
86// (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000087//
88// Qlngus
mpagenko836a1fd2021-11-01 16:12:42 +000089// This attribute is the number of subcarriers per group used to report QLNpsus. (R) (mandatory)
90// (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000091//
92// Snrgus
mpagenko836a1fd2021-11-01 16:12:42 +000093// This attribute is the number of subcarriers per group used to report SNRpsus. (R) (mandatory)
94// (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +000095//
96// Mrefpsdus Table
mpagenko836a1fd2021-11-01 16:12:42 +000097// The upstream medley reference PSD attribute contains the set of breakpoints exchanged in the
98// MREFPSDus fields of the R-PRM message of [ITU-T G.993.2].
99//
100// The format is similar to that specified for the PSD descriptor in [ITUT-G.993.2]. In [ITU-T
101// G.993.2], the first byte gives the size of the table, each entry of which is 3-bytes. In the
102// OMCI definition, the first byte is omitted because the size of the table is known from the
103// response to the get command.
104//
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000105// (R) (mandatory) (3 * N bytes, where N is the number of breakpoints)
106//
107// Trellisus
mpagenko836a1fd2021-11-01 16:12:42 +0000108// This attribute reports whether trellis coding is in use in the upstream direction.
109//
110// 0 Trellis not used
111//
112// 1 Trellis used
113//
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000114// (R) (mandatory for ITU-T G.993.2 VDSL2, optional for others) (1-byte)
115//
116// Actualce
mpagenko836a1fd2021-11-01 16:12:42 +0000117// This attribute reports the cyclic extension used on the line. It is coded as an unsigned integer
118// from 2 to 16 in units of N/32 samples, where 2N is the IDFT size. (R) (mandatory) (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000119//
120// Upbokle_R
121// UPBOKLE-R: This attribute contains the electrical length estimated by the VTU-R expressed in
122// decibels at 1-MHz. This is the value contained in the message RMSG1 (see clause 12.3.3.2.2.1of
123// [ITUT G.993.2]). Its value lies in the range 0 (0.0-dB) to 1280 (128.0-dB) (R) (optional)
124// (2-bytes)
125//
126// Actual Rate Adaptation Mode Upstream
mpagenko836a1fd2021-11-01 16:12:42 +0000127// The ACT-RA-MODEus attribute indicates the actual active RA mode in the upstream direction.
128//
129// 1 MANUAL
130//
131// 2 AT_INIT
132//
133// 3 DYNAMIC
134//
135// 4 DYNAMIC with SOS ([ITU-T G.993.2] only)
136//
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000137// (R) (optional) (1-byte)
138//
139// Actual Impulse Noise Protection Roc Upstream
mpagenko836a1fd2021-11-01 16:12:42 +0000140// The ACTINP-ROC-us attribute reports the actual INP of the ROC in the upstream direction
141// expressed in multiples of T4k. The INP of this attribute is equal to the integer value
142// multiplied by 0.1 symbols. Valid values and usage are given in clause 7.5.1.34.2 of
143// [ITUT-G.997.1]. (R) (optional) (1-byte)
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000144//
145// Snr Margin Roc Upstream
mpagenko836a1fd2021-11-01 16:12:42 +0000146// The SNRM-ROC-us attribute reports the actual signal-to-noise margin of the ROC in the upstream
147// direction. Its value ranges from 0 (-64.0-dB) to 1270 (+63.0-dB). The special value 0xFFFF
148// indicates that the attribute is out of range. (R) (optional) (2-bytes)
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000149//
150type Vdsl2LineInventoryAndStatusDataPart2 struct {
151 ManagedEntityDefinition
152 Attributes AttributeValueMap
153}
154
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +0000155// Attribute name constants
156
157const Vdsl2LineInventoryAndStatusDataPart2_Vdsl2TransmissionSystemCapabilityXtuR = "Vdsl2TransmissionSystemCapabilityXtuR"
158const Vdsl2LineInventoryAndStatusDataPart2_Actsnrmodeus = "Actsnrmodeus"
159const Vdsl2LineInventoryAndStatusDataPart2_Upbokle = "Upbokle"
160const Vdsl2LineInventoryAndStatusDataPart2_Hlingus = "Hlingus"
161const Vdsl2LineInventoryAndStatusDataPart2_Hloggus = "Hloggus"
162const Vdsl2LineInventoryAndStatusDataPart2_Qlngus = "Qlngus"
163const Vdsl2LineInventoryAndStatusDataPart2_Snrgus = "Snrgus"
164const Vdsl2LineInventoryAndStatusDataPart2_MrefpsdusTable = "MrefpsdusTable"
165const Vdsl2LineInventoryAndStatusDataPart2_Trellisus = "Trellisus"
166const Vdsl2LineInventoryAndStatusDataPart2_Actualce = "Actualce"
167const Vdsl2LineInventoryAndStatusDataPart2_UpbokleR = "UpbokleR"
168const Vdsl2LineInventoryAndStatusDataPart2_ActualRateAdaptationModeUpstream = "ActualRateAdaptationModeUpstream"
169const Vdsl2LineInventoryAndStatusDataPart2_ActualImpulseNoiseProtectionRocUpstream = "ActualImpulseNoiseProtectionRocUpstream"
170const Vdsl2LineInventoryAndStatusDataPart2_SnrMarginRocUpstream = "SnrMarginRocUpstream"
171
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000172func init() {
173 vdsl2lineinventoryandstatusdatapart2BME = &ManagedEntityDefinition{
174 Name: "Vdsl2LineInventoryAndStatusDataPart2",
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +0000175 ClassID: Vdsl2LineInventoryAndStatusDataPart2ClassID,
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000176 MessageTypes: mapset.NewSetWith(
177 Get,
178 GetNext,
179 ),
180 AllowedAttributeMask: 0xfffc,
181 AttributeDefinitions: AttributeDefinitionMap{
Holger Hildebrandt3ac49bd2022-02-07 17:46:43 +0000182 0: Uint16Field(ManagedEntityID, PointerAttributeType, 0x0000, 0, mapset.NewSetWith(Read), false, false, false, 0),
183 1: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Vdsl2TransmissionSystemCapabilityXtuR, UnsignedIntegerAttributeType, 0x8000, 0, mapset.NewSetWith(Read), false, false, false, 1),
184 2: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Actsnrmodeus, UnsignedIntegerAttributeType, 0x4000, 0, mapset.NewSetWith(Read), false, false, false, 2),
185 3: Uint16Field(Vdsl2LineInventoryAndStatusDataPart2_Upbokle, UnsignedIntegerAttributeType, 0x2000, 0, mapset.NewSetWith(Read), false, false, false, 3),
186 4: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Hlingus, UnsignedIntegerAttributeType, 0x1000, 0, mapset.NewSetWith(Read), false, false, false, 4),
187 5: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Hloggus, UnsignedIntegerAttributeType, 0x0800, 0, mapset.NewSetWith(Read), false, false, false, 5),
188 6: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Qlngus, UnsignedIntegerAttributeType, 0x0400, 0, mapset.NewSetWith(Read), false, false, false, 6),
189 7: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Snrgus, UnsignedIntegerAttributeType, 0x0200, 0, mapset.NewSetWith(Read), false, false, false, 7),
190 8: TableField(Vdsl2LineInventoryAndStatusDataPart2_MrefpsdusTable, TableAttributeType, 0x0100, TableInfo{nil, 3}, mapset.NewSetWith(Read), false, false, false, 8),
191 9: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Trellisus, UnsignedIntegerAttributeType, 0x0080, 0, mapset.NewSetWith(Read), false, false, false, 9),
192 10: ByteField(Vdsl2LineInventoryAndStatusDataPart2_Actualce, UnsignedIntegerAttributeType, 0x0040, 0, mapset.NewSetWith(Read), false, false, false, 10),
193 11: Uint16Field(Vdsl2LineInventoryAndStatusDataPart2_UpbokleR, UnsignedIntegerAttributeType, 0x0020, 0, mapset.NewSetWith(Read), false, true, false, 11),
194 12: ByteField(Vdsl2LineInventoryAndStatusDataPart2_ActualRateAdaptationModeUpstream, UnsignedIntegerAttributeType, 0x0010, 0, mapset.NewSetWith(Read), false, true, false, 12),
195 13: ByteField(Vdsl2LineInventoryAndStatusDataPart2_ActualImpulseNoiseProtectionRocUpstream, UnsignedIntegerAttributeType, 0x0008, 0, mapset.NewSetWith(Read), false, true, false, 13),
196 14: Uint16Field(Vdsl2LineInventoryAndStatusDataPart2_SnrMarginRocUpstream, UnsignedIntegerAttributeType, 0x0004, 0, mapset.NewSetWith(Read), false, true, false, 14),
Holger Hildebrandtfa074992020-03-27 15:42:06 +0000197 },
198 Access: CreatedByOnu,
199 Support: UnknownSupport,
200 }
201}
202
203// NewVdsl2LineInventoryAndStatusDataPart2 (class ID 169) creates the basic
204// Managed Entity definition that is used to validate an ME of this type that
205// is received from or transmitted to the OMCC.
206func NewVdsl2LineInventoryAndStatusDataPart2(params ...ParamData) (*ManagedEntity, OmciErrors) {
207 return NewManagedEntity(*vdsl2lineinventoryandstatusdatapart2BME, params...)
208}