blob: 5799375de62f551273e4a71e1321439a33e65bc6 [file] [log] [blame]
Takahiro Suzuki241c10e2020-12-17 20:17:57 +09001/*
2 * Copyright (c) 2018 - present. Boling Consulting Solutions (bcsw.net)
3 * Copyright 2020-present Open Networking Foundation
4
5 * 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
8
9 * http://www.apache.org/licenses/LICENSE-2.0
10
11 * 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 */
17 /*
18 * 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// PseudowirePerformanceMonitoringHistoryDataClassID is the 16-bit ID for the OMCI
29// Managed entity Pseudowire performance monitoring history data
30const PseudowirePerformanceMonitoringHistoryDataClassID ClassID = ClassID(285)
31
32var pseudowireperformancemonitoringhistorydataBME *ManagedEntityDefinition
33
34// PseudowirePerformanceMonitoringHistoryData (class ID #285)
35// This ME collects PM for a pseudowire TP. Most of the attributes monitor packets received from
36// the PSN, and may therefore be considered egress PM. For the most part, ingress PM is collected
37// at the CES PPTP ME.
38//
39// NOTE - The pseudowire PM history data ME collects data similar, but not identical, to that
40// available from the MAC bridge port PM history data ME associated with a MAC bridge. When the
41// pseudowire is bridge-based, it may not be necessary to collect both.
42//
43// Instances of this ME are created and deleted by the OLT.
44//
45// For a complete discussion of generic PM architecture, refer to clause I.4.
46//
47// Relationships
48// An instance of this ME is associated with an instance of the pseudowire TP.
49//
50// Attributes
51// Managed Entity Id
52// Managed entity ID: This attribute uniquely identifies each instance of this ME. Through an
53// identical ID, this ME is implicitly linked to an instance of the pseudowire TP. (R, setbycreate)
54// (mandatory) (2-bytes)
55//
56// Interval End Time
57// Interval end time: This attribute identifies the most recently finished 15-min interval. (R)
58// (mandatory) (1-byte)
59//
60// Threshold Data 1_2 Id
61// Threshold data 1/2 ID: This attribute points to an instance of the threshold data 1 and 2 MEs
62// that contains PM threshold values. (R,-W, setbycreate) (mandatory) (2-bytes)
63//
64// Received Packets
65// Received packets: This attribute counts the total number of packets, both payload and
66// signalling, received in the PSN to the TDM direction. (R) (mandatory) (4-bytes)
67//
68// Transmitted Packets
69// Transmitted packets: This attribute counts the total number of packets, both payload and
70// signalling, transmitted in the TDM to the PSN direction. The count includes packets whose L bit
71// is set and which may therefore not contain a payload. (R) (mandatory) (4-bytes)
72//
73// Missing Packets
74// Missing packets: This attribute counts the number of lost packets, as indicated by gaps in the
75// control word numbering sequence. Both payload and signalling packets, if any, contribute to this
76// count. (R) (mandatory) (4-bytes)
77//
78// Misordered Packets, Usable
79// Misordered packets, usable: This attribute counts the number of packets received out of order,
80// but which were able to be successfully re-ordered and played out. Both payload and signalling
81// packets, if any, contribute to this count. (R) (mandatory) (4-bytes)
82//
83// Misordered Packets Dropped
84// Misordered packets dropped: This attribute counts the number of packets received out of sequence
85// that were discarded, either because the ONU did not support reordering or because it was too
86// late to reorder them. Both payload and signalling packets, if any, contribute to this count. (R)
87// (mandatory) (4-bytes)
88//
89// Playout Buffer Underruns_Overruns
90// Playout buffer underruns/overruns: This attribute counts the number of packets that were
91// discarded because they arrived too late or too early to be played out. Both payload and
92// signalling packets, if any, contribute to this count. (R) (mandatory) (4-bytes)
93//
94// Malformed Packets
95// Malformed packets: This attribute counts the number of malformed packets, e.g., because the
96// packet length was not as expected or because of an unexpected RTP payload type. Both payload and
97// signalling packets, if any, contribute to this count. (R) (mandatory) (4-bytes)
98//
99// Stray Packets
100// Stray packets: This attribute counts the number of packets whose ECID or RTP SSRC failed to
101// match the expected value, or which are otherwise known to have been misdelivered. Stray packets
102// are discarded without affecting any of the other PM counters. Both payload and signalling
103// packets, if any, contribute to this count. (R) (mandatory) (4-bytes)
104//
105// Remote Packet Loss
106// Remote packet loss: This attribute counts received packets whose R bit is set, indicating the
107// loss of packets at the far end. Both payload and signalling packets, if any, contribute to this
108// count. (R) (mandatory) (4-bytes)
109//
110// Tdm L_Bit Packets Transmitted
111// TDM L-bit packets transmitted: This attribute counts the number of packets transmitted with the
112// L bit set, indicating a near-end TDM fault. Both payload and signalling packets, if any,
113// contribute to this count. (R) (mandatory) (4-bytes)
114//
115// Es
116// ES: This attribute counts errored seconds. Any discarded, lost, malformed or unusable packet
117// received from the PSN during a given second causes this counter to increment. Both payload and
118// signalling packets, if any, contribute to this count. (R) (mandatory) (4-bytes)
119//
120// Ses
121// SES: This attribute counts severely errored seconds. The criterion for an SES may be configured
122// through the pseudowire maintenance profile ME. Both payload and signalling packets, if any,
123// contribute to this count. (R) (mandatory) (4-bytes)
124//
125// Uas
126// UAS: This attribute counts unavailable seconds. An unavailable second begins at the onset of 10
127// consecutive SES and ends at the onset of 10 consecutive seconds that are not severely errored. A
128// service is unavailable if either its payload or its signalling, if any, are unavailable. During
129// unavailable time, only UAS should be counted; other anomalies should not be counted. (R)
130// (mandatory) (4-bytes)
131//
132type PseudowirePerformanceMonitoringHistoryData struct {
133 ManagedEntityDefinition
134 Attributes AttributeValueMap
135}
136
137func init() {
138 pseudowireperformancemonitoringhistorydataBME = &ManagedEntityDefinition{
139 Name: "PseudowirePerformanceMonitoringHistoryData",
140 ClassID: 285,
141 MessageTypes: mapset.NewSetWith(
142 Create,
143 Delete,
144 Get,
145 Set,
146 ),
147 AllowedAttributeMask: 0xfffe,
148 AttributeDefinitions: AttributeDefinitionMap{
149 0: Uint16Field("ManagedEntityId", PointerAttributeType, 0x0000, 0, mapset.NewSetWith(Read, SetByCreate), false, false, false, 0),
150 1: ByteField("IntervalEndTime", UnsignedIntegerAttributeType, 0x8000, 0, mapset.NewSetWith(Read), false, false, false, 1),
151 2: Uint16Field("ThresholdData12Id", UnsignedIntegerAttributeType, 0x4000, 0, mapset.NewSetWith(Read, SetByCreate, Write), false, false, false, 2),
152 3: Uint32Field("ReceivedPackets", CounterAttributeType, 0x2000, 0, mapset.NewSetWith(Read), false, false, false, 3),
153 4: Uint32Field("TransmittedPackets", CounterAttributeType, 0x1000, 0, mapset.NewSetWith(Read), false, false, false, 4),
154 5: Uint32Field("MissingPackets", CounterAttributeType, 0x0800, 0, mapset.NewSetWith(Read), false, false, false, 5),
155 6: Uint32Field("MisorderedPackets,Usable", CounterAttributeType, 0x0400, 0, mapset.NewSetWith(Read), false, false, false, 6),
156 7: Uint32Field("MisorderedPacketsDropped", CounterAttributeType, 0x0200, 0, mapset.NewSetWith(Read), false, false, false, 7),
157 8: Uint32Field("PlayoutBufferUnderrunsOverruns", CounterAttributeType, 0x0100, 0, mapset.NewSetWith(Read), false, false, false, 8),
158 9: Uint32Field("MalformedPackets", CounterAttributeType, 0x0080, 0, mapset.NewSetWith(Read), false, false, false, 9),
159 10: Uint32Field("StrayPackets", CounterAttributeType, 0x0040, 0, mapset.NewSetWith(Read), false, false, false, 10),
160 11: Uint32Field("RemotePacketLoss", CounterAttributeType, 0x0020, 0, mapset.NewSetWith(Read), false, false, false, 11),
161 12: Uint32Field("TdmLBitPacketsTransmitted", CounterAttributeType, 0x0010, 0, mapset.NewSetWith(Read), false, false, false, 12),
162 13: Uint32Field("Es", CounterAttributeType, 0x0008, 0, mapset.NewSetWith(Read), false, false, false, 13),
163 14: Uint32Field("Ses", CounterAttributeType, 0x0004, 0, mapset.NewSetWith(Read), false, false, false, 14),
164 15: Uint32Field("Uas", CounterAttributeType, 0x0002, 0, mapset.NewSetWith(Read), false, false, false, 15),
165 },
166 Access: CreatedByOlt,
167 Support: UnknownSupport,
168 }
169}
170
171// NewPseudowirePerformanceMonitoringHistoryData (class ID 285) creates the basic
172// Managed Entity definition that is used to validate an ME of this type that
173// is received from or transmitted to the OMCC.
174func NewPseudowirePerformanceMonitoringHistoryData(params ...ParamData) (*ManagedEntity, OmciErrors) {
175 return NewManagedEntity(*pseudowireperformancemonitoringhistorydataBME, params...)
176}