aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/amazon/files/include/asm-mips/amazon/amazon_mei_app_ioctl.h
blob: d98f60b171181153f43d093485fae9d3733a7f64 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
// 603221:tc.chen 2006/03/21 added APIs to support the WEB related parameters for ADSL Statistics

#ifndef __AMAZON_MEI_APP_IOCTL_H
#define __AMAZON_MEI_APP_IOCTL_H

#ifdef __KERNEL__
#include "amazon_mei_ioctl.h"
#endif

/* Interface Name */
//#define INTERFACE_NAME <define the interface>

/* adslLineTable constants */
#define GET_ADSL_LINE_CODE		1

/* adslAtucPhysTable constants */
#define GET_ADSL_ATUC_PHY		4

/* adslAturPhysTable constants */
#define GET_ADSL_ATUR_PHY		10

/* adslAtucChanTable constants */
#define GET_ADSL_ATUC_CHAN_INFO 	15

/* adslAturChanTable constants */
#define GET_ADSL_ATUR_CHAN_INFO		18

/* adslAtucPerfDataTable constants */
#define GET_ADSL_ATUC_PERF_DATA		21

/* adslAturPerfDataTable constants */
#define GET_ADSL_ATUR_PERF_DATA		40

/* adslAtucIntervalTable constants */
#define GET_ADSL_ATUC_INTVL_INFO	60

/* adslAturIntervalTable constants */
#define GET_ADSL_ATUR_INTVL_INFO	65

/* adslAtucChanPerfDataTable constants */
#define GET_ADSL_ATUC_CHAN_PERF_DATA	70

/* adslAturChanPerfDataTable constants */
#define GET_ADSL_ATUR_CHAN_PERF_DATA	90

/* adslAtucChanIntervalTable constants */
#define GET_ADSL_ATUC_CHAN_INTVL_INFO	110

/* adslAturChanIntervalTable constants */
#define GET_ADSL_ATUR_CHAN_INTVL_INFO	115

/* adslLineAlarmConfProfileTable constants */
#define GET_ADSL_ALRM_CONF_PROF		120
#define SET_ADSL_ALRM_CONF_PROF		121

/* adslAturTrap constants */
#define ADSL_ATUR_TRAPS			135

//////////////////  RFC-3440 //////////////

#ifdef AMAZON_MEI_MIB_RFC3440
/* adslLineExtTable */
#define GET_ADSL_ATUC_LINE_EXT		201
#define SET_ADSL_ATUC_LINE_EXT		203

/* adslAtucPerfDateExtTable */
#define GET_ADSL_ATUC_PERF_DATA_EXT	205

/* adslAtucIntervalExtTable */
#define GET_ADSL_ATUC_INTVL_EXT_INFO	221

/* adslAturPerfDataExtTable */
#define GET_ADSL_ATUR_PERF_DATA_EXT	225

/* adslAturIntervalExtTable */
#define GET_ADSL_ATUR_INTVL_EXT_INFO	233

/* adslAlarmConfProfileExtTable */
#define GET_ADSL_ALRM_CONF_PROF_EXT	235
#define SET_ADSL_ALRM_CONF_PROF_EXT	236

/* adslAturExtTrap */
#define ADSL_ATUR_EXT_TRAPS		240

#endif

// 603221:tc.chen start
/* The following constants are added to support the WEB related ADSL Statistics */

/* adslLineStatus constants */
#define GET_ADSL_LINE_STATUS	245

/* adslLineRate constants */
#define GET_ADSL_LINE_RATE		250

/* adslLineInformation constants */
#define GET_ADSL_LINE_INFO		255

/* adslNearEndPerformanceStats constants */
#define GET_ADSL_NEAREND_STATS	270

/* adslFarEndPerformanceStats constants */
#define GET_ADSL_FAREND_STATS	290

// 603221:tc.chen end

/* Loop diagnostics mode of the ADSL line related constants */
#define GET_ADSL_LOOP_DIAGNOSTICS_MODE 	295
#define SET_ADSL_LOOP_DIAGNOSTICS_MODE 	296
#define IS_ADSL_LOOP_DIAGNOSTICS_MODE_COMPLETE	299

/* Sub-carrier related parameters */
#define GET_ADSL_ATUC_SUBCARRIER_STATS		297
#define GET_ADSL_ATUR_SUBCARRIER_STATS		298
#define GET_ADSL_LINE_INIT_STATS		150
#define GET_ADSL_POWER_SPECTRAL_DENSITY		151


///////////////////////////////////////////////////////////
// makeCMV(Opcode, Group, Address, Index, Size, Data)

/* adslLineCode Flags */
#define LINE_CODE_FLAG			0x1	/* BIT 0th position */

/* adslAtucPhysTable Flags */
#define ATUC_PHY_SER_NUM_FLAG		0x1	/* BIT 0th position */
#define ATUC_PHY_SER_NUM_FLAG_MAKECMV1	makeCMV(H2D_CMV_READ, INFO, 57, 0, 12, data) 
#define ATUC_PHY_SER_NUM_FLAG_MAKECMV2	makeCMV(H2D_CMV_READ, INFO, 57, 12, 4, data) 

#define ATUC_PHY_VENDOR_ID_FLAG		0x2	/* BIT 1 */
#define ATUC_PHY_VENDOR_ID_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 64, 0, 4, data)

#define ATUC_PHY_VER_NUM_FLAG		0x4	/* BIT 2 */
#define ATUC_PHY_VER_NUM_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 58, 0, 8, data)

#define ATUC_CURR_STAT_FLAG		0x8	/* BIT 3 */

#define ATUC_CURR_OUT_PWR_FLAG		0x10	/* BIT 4 */
#define ATUC_CURR_OUT_PWR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 5, 1, data)

#define ATUC_CURR_ATTR_FLAG		0x20	/* BIT 5 */
#define ATUC_CURR_ATTR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 0, 2, data)


/* adslAturPhysTable	Flags */
#define ATUR_PHY_SER_NUM_FLAG		0x1	/* BIT 0th position */
#define ATUR_PHY_SER_NUM_FLAG_MAKECMV1	makeCMV(H2D_CMV_READ, INFO, 62, 0, 12, data)
#define ATUR_PHY_SER_NUM_FLAG_MAKECMV2	makeCMV(H2D_CMV_READ, INFO, 62, 12, 4, data)

#define ATUR_PHY_VENDOR_ID_FLAG		0x2	/* BIT 1 */
#define ATUR_PHY_VENDOR_ID_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 65, 0, 4, data)

#define ATUR_PHY_VER_NUM_FLAG		0x4	/* BIT 2 */
#define ATUR_PHY_VER_NUM_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 61, 0, 8, data)

#define ATUR_SNRMGN_FLAG		0x8
#define ATUR_SNRMGN_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 4, 1, data)

#define ATUR_ATTN_FLAG			0x10
#define ATUR_ATTN_FLAG_MAKECMV		makeCMV(H2D_CMV_READ, INFO, 68, 2, 1, data)

#define ATUR_CURR_STAT_FLAG		0x20	/* BIT 3 */

#define ATUR_CURR_OUT_PWR_FLAG		0x40	/* BIT 4 */
#define ATUR_CURR_OUT_PWR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 5, 1, data)

#define ATUR_CURR_ATTR_FLAG		0x80	/* BIT 5 */
#define ATUR_CURR_ATTR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 0, 2, data)

/* adslAtucChanTable Flags */
#define ATUC_CHAN_INTLV_DELAY_FLAG	0x1	/* BIT 0th position */
#define ATUC_CHAN_INTLV_DELAY_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, RATE, 3, 1, 1, data)

#define ATUC_CHAN_CURR_TX_RATE_FLAG	0x2	/* BIT 1 */
#define ATUC_CHAN_CURR_TX_RATE_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, RATE, 1, 0, 2, data)

#define ATUC_CHAN_PREV_TX_RATE_FLAG	0x4	/* BIT 2 */

/* adslAturChanTable Flags */
#define ATUR_CHAN_INTLV_DELAY_FLAG	0x1	/* BIT 0th position */
#define ATUR_CHAN_INTLV_DELAY_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, RATE, 2, 1, 1, data)

#define ATUR_CHAN_CURR_TX_RATE_FLAG	0x2	/* BIT 1 */
#define ATUR_CHAN_CURR_TX_RATE_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, RATE, 0, 0, 2, data)

#define ATUR_CHAN_PREV_TX_RATE_FLAG	0x4	/* BIT 2 */

#define ATUR_CHAN_CRC_BLK_LEN_FLAG	0x8	/* BIT 3 */

/* adslAtucPerfDataTable Flags */
#define ATUC_PERF_LOFS_FLAG		0x1	/* BIT 0th position */
#define ATUC_PERF_LOSS_FLAG		0x2	/* BIT 1 */
#define ATUC_PERF_LO_FLAG_MAKECMV		makeCMV(H2D_CMV_READ, PLAM, 0, 0, 1, data)
#define ATUC_PERF_ESS_FLAG		0x4	/* BIT 2 */
#define ATUC_PERF_ESS_FLAG_MAKECMV		makeCMV(H2D_CMV_READ, PLAM, 7, 0, 1, data) 
#define ATUC_PERF_INITS_FLAG	0x8	/* BIT 3 */
#define ATUC_PERF_VALID_INTVLS_FLAG	0x10 /* BIT 4 */
#define ATUC_PERF_INVALID_INTVLS_FLAG	0x20 /* BIT 5 */
#define ATUC_PERF_CURR_15MIN_TIME_ELAPSED_FLAG	0x40 /* BIT 6 */
#define ATUC_PERF_CURR_15MIN_LOFS_FLAG	 	0x80 	 /* BIT 7 */
#define ATUC_PERF_CURR_15MIN_LOSS_FLAG		0x100 /* BIT 8 */
#define ATUC_PERF_CURR_15MIN_ESS_FLAG		0x200	/* BIT 9 */
#define ATUC_PERF_CURR_15MIN_INIT_FLAG		0x400 /* BIT 10 */
#define ATUC_PERF_CURR_1DAY_TIME_ELAPSED_FLAG 0x800 /* BIT 11 */
#define ATUC_PERF_CURR_1DAY_LOFS_FLAG		0x1000 /* BIT 12 */
#define ATUC_PERF_CURR_1DAY_LOSS_FLAG		0x2000 /* BIT 13 */
#define ATUC_PERF_CURR_1DAY_ESS_FLAG		0x4000 /* BIT 14 */
#define ATUC_PERF_CURR_1DAY_INIT_FLAG		0x8000 /* BIT 15 */
#define ATUC_PERF_PREV_1DAY_MON_SEC_FLAG	0x10000 /* BIT 16 */
#define ATUC_PERF_PREV_1DAY_LOFS_FLAG		0x20000 /* BIT 17 */
#define ATUC_PERF_PREV_1DAY_LOSS_FLAG		0x40000 /* BIT 18 */
#define ATUC_PERF_PREV_1DAY_ESS_FLAG		0x80000 /* BIT 19 */
#define ATUC_PERF_PREV_1DAY_INITS_FLAG		0x100000 /* BIT 20 */

/* adslAturPerfDataTable Flags */
#define ATUR_PERF_LOFS_FLAG		0x1	/* BIT 0th position */
#define ATUR_PERF_LOSS_FLAG		0x2	/* BIT 1 */
#define ATUR_PERF_LPR_FLAG		0x4	/* BIT 2 */
#define ATUR_PERF_LO_FLAG_MAKECMV		makeCMV(H2D_CMV_READ, PLAM, 1, 0, 1, data)
#define ATUR_PERF_ESS_FLAG		0x8	/* BIT 3 */
#define ATUR_PERF_ESS_FLAG_MAKECMV		makeCMV(H2D_CMV_READ, PLAM, 33, 0, 1, data)
#define ATUR_PERF_VALID_INTVLS_FLAG	0x10 /* BIT 4 */
#define ATUR_PERF_INVALID_INTVLS_FLAG	0x20 /* BIT 5 */
#define ATUR_PERF_CURR_15MIN_TIME_ELAPSED_FLAG	0x40 /* BIT 6 */
#define ATUR_PERF_CURR_15MIN_LOFS_FLAG	 	0x80 	 /* BIT 7 */
#define ATUR_PERF_CURR_15MIN_LOSS_FLAG		0x100 /* BIT 8 */
#define ATUR_PERF_CURR_15MIN_LPR_FLAG		0x200 /* BIT 9 */
#define ATUR_PERF_CURR_15MIN_ESS_FLAG		0x400	/* BIT 10 */
#define ATUR_PERF_CURR_1DAY_TIME_ELAPSED_FLAG 	0x800 /* BIT 11 */
#define ATUR_PERF_CURR_1DAY_LOFS_FLAG		0x1000 /* BIT 12 */
#define ATUR_PERF_CURR_1DAY_LOSS_FLAG		0x2000 /* BIT 13 */
#define ATUR_PERF_CURR_1DAY_LPR_FLAG		0x4000 /* BIT 14 */
#define ATUR_PERF_CURR_1DAY_ESS_FLAG		0x8000 /* BIT 15 */
#define ATUR_PERF_PREV_1DAY_MON_SEC_FLAG	0x10000 /* BIT 16 */
#define ATUR_PERF_PREV_1DAY_LOFS_FLAG		0x20000 /* BIT 17 */
#define ATUR_PERF_PREV_1DAY_LOSS_FLAG		0x40000 /* BIT 18 */
#define ATUR_PERF_PREV_1DAY_LPR_FLAG		0x80000 /* BIT 19 */
#define ATUR_PERF_PREV_1DAY_ESS_FLAG		0x100000 /* BIT 20 */

/* adslAtucIntervalTable Flags */
#define ATUC_INTVL_LOF_FLAG		0x1	/* BIT 0th position */
#define ATUC_INTVL_LOS_FLAG		0x2 	/* BIT 1 */
#define ATUC_INTVL_ESS_FLAG		0x4	/* BIT 2 */
#define ATUC_INTVL_INIT_FLAG		0x8   /* BIT 3 */
#define ATUC_INTVL_VALID_DATA_FLAG 	0x10 /* BIT 4 */

/* adslAturIntervalTable Flags */
#define ATUR_INTVL_LOF_FLAG		0x1	/* BIT 0th position */
#define ATUR_INTVL_LOS_FLAG		0x2 	/* BIT 1 */
#define ATUR_INTVL_LPR_FLAG		0x4 	/* BIT 2 */
#define ATUR_INTVL_ESS_FLAG		0x8	/* BIT 3 */
#define ATUR_INTVL_VALID_DATA_FLAG 	0x10 /* BIT 4 */

/* adslAtucChanPerfDataTable Flags */
#define ATUC_CHAN_RECV_BLK_FLAG	0x01	/* BIT 0th position */
#define ATUC_CHAN_TX_BLK_FLAG	0x02	/* BIT 1 */
#define ATUC_CHAN_CORR_BLK_FLAG	0x04	/* BIT 2 */
#define ATUC_CHAN_UNCORR_BLK_FLAG 0x08	/* BIT 3 */
#define ATUC_CHAN_PERF_VALID_INTVL_FLAG 0x10 /* BIT 4 */
#define ATUC_CHAN_PERF_INVALID_INTVL_FLAG 0x20 /* BIT 5 */
#define ATUC_CHAN_PERF_CURR_15MIN_TIME_ELAPSED_FLAG 0x40 /* BIT 6 */
#define ATUC_CHAN_PERF_CURR_15MIN_RECV_BLK_FLAG	0x80 /* BIT 7 */
#define ATUC_CHAN_PERF_CURR_15MIN_TX_BLK_FLAG 0x100 /* BIT 8 */
#define ATUC_CHAN_PERF_CURR_15MIN_CORR_BLK_FLAG 0x200 /* BIT 9 */
#define ATUC_CHAN_PERF_CURR_15MIN_UNCORR_BLK_FLAG 0x400 /* BIT 10 */
#define ATUC_CHAN_PERF_CURR_1DAY_TIME_ELAPSED_FLAG 0x800 /* BIT 11*/
#define ATUC_CHAN_PERF_CURR_1DAY_RECV_BLK_FLAG 0x1000 /* BIT 12 */
#define ATUC_CHAN_PERF_CURR_1DAY_TX_BLK_FLAG 0x2000 /* BIT 13 */
#define ATUC_CHAN_PERF_CURR_1DAY_CORR_BLK_FLAG 0x4000 /* BIT 14 */
#define ATUC_CHAN_PERF_CURR_1DAY_UNCORR_BLK_FLAG 0x8000 /* BIT 15 */
#define ATUC_CHAN_PERF_PREV_1DAY_MONI_SEC_FLAG 0x10000 /* BIT 16 */
#define ATUC_CHAN_PERF_PREV_1DAY_RECV_BLK_FLAG 0x20000 /* BIT 17 */
#define ATUC_CHAN_PERF_PREV_1DAY_TX_BLK_FLAG 0x40000 /* BIT 18 */
#define ATUC_CHAN_PERF_PREV_1DAY_CORR_BLK_FLAG 0x80000 /* BIT 19 */
#define ATUC_CHAN_PERF_PREV_1DAY_UNCORR_BLK_FLAG 0x100000 /* BIT 20 */


/* adslAturChanPerfDataTable Flags */
#define ATUR_CHAN_RECV_BLK_FLAG   0x01 	/* BIT 0th position */ 
#define ATUR_CHAN_RECV_BLK_FLAG_MAKECMV_LSW		makeCMV(H2D_CMV_READ, PLAM, 20, 0, 1, data)
#define ATUR_CHAN_RECV_BLK_FLAG_MAKECMV_MSW		makeCMV(H2D_CMV_READ, PLAM, 21, 0, 1, data)
#define ATUR_CHAN_TX_BLK_FLAG     0x02 	/* BIT 1 */
#define ATUR_CHAN_TX_BLK_FLAG_MAKECMV_LSW		makeCMV(H2D_CMV_READ, PLAM, 20, 0, 1, data)
#define ATUR_CHAN_TX_BLK_FLAG_MAKECMV_MSW		makeCMV(H2D_CMV_READ, PLAM, 21, 0, 1, data)
#define ATUR_CHAN_CORR_BLK_FLAG   0x04 	/* BIT 2 */
#define ATUR_CHAN_CORR_BLK_FLAG_MAKECMV_INTL		makeCMV(H2D_CMV_READ, PLAM, 3, 0, 1, data)
#define ATUR_CHAN_CORR_BLK_FLAG_MAKECMV_FAST		makeCMV(H2D_CMV_READ, PLAM, 3, 1, 1, data)
#define ATUR_CHAN_UNCORR_BLK_FLAG 0x08		/* BIT 3 */
#define ATUR_CHAN_UNCORR_BLK_FLAG_MAKECMV_INTL		makeCMV(H2D_CMV_READ, PLAM, 2, 0, 1, data)
#define ATUR_CHAN_UNCORR_BLK_FLAG_MAKECMV_FAST		makeCMV(H2D_CMV_READ, PLAM, 2, 1, 1, data)
#define ATUR_CHAN_PERF_VALID_INTVL_FLAG   0x10 	/* BIT 4 */
#define ATUR_CHAN_PERF_INVALID_INTVL_FLAG 0x20 	/* BIT 5 */
#define ATUR_CHAN_PERF_CURR_15MIN_TIME_ELAPSED_FLAG 0x40 /* BIT 6 */
#define ATUR_CHAN_PERF_CURR_15MIN_RECV_BLK_FLAG    0x80   /* BIT 7 */
#define ATUR_CHAN_PERF_CURR_15MIN_TX_BLK_FLAG      0x100 /* BIT 8 */
#define ATUR_CHAN_PERF_CURR_15MIN_CORR_BLK_FLAG    0x200 /* BIT 9 */
#define ATUR_CHAN_PERF_CURR_15MIN_UNCORR_BLK_FLAG  0x400 /* BIT 10 */
#define ATUR_CHAN_PERF_CURR_1DAY_TIME_ELAPSED_FLAG 0x800 /* BIT 11 */
#define ATUR_CHAN_PERF_CURR_1DAY_RECV_BLK_FLAG     0x1000 /* BIT 12 */
#define ATUR_CHAN_PERF_CURR_1DAY_TX_BLK_FLAG       0x2000 /* BIT 13 */
#define ATUR_CHAN_PERF_CURR_1DAY_CORR_BLK_FLAG     0x4000 /* BIT 14 */
#define ATUR_CHAN_PERF_CURR_1DAY_UNCORR_BLK_FLAG   0x8000 /* BIT 15 */
#define ATUR_CHAN_PERF_PREV_1DAY_MONI_SEC_FLAG     0x10000 /* BIT 16 */
#define ATUR_CHAN_PERF_PREV_1DAY_RECV_BLK_FLAG     0x20000 /* BIT 17 */
#define ATUR_CHAN_PERF_PREV_1DAY_TRANS_BLK_FLAG    0x40000 /* BIT 18 */
#define ATUR_CHAN_PERF_PREV_1DAY_CORR_BLK_FLAG     0x80000 /* BIT 19 */
#define ATUR_CHAN_PERF_PREV_1DAY_UNCORR_BLK_FLAG   0x100000 /* BIT 20 */

/* adslAtucChanIntervalTable Flags */
#define ATUC_CHAN_INTVL_NUM_FLAG   	     	0x1 	/* BIT 0th position */
#define ATUC_CHAN_INTVL_RECV_BLK_FLAG  		0x2 	/* BIT 1 */
#define ATUC_CHAN_INTVL_TX_BLK_FLAG  		0x4	/* BIT 2 */
#define ATUC_CHAN_INTVL_CORR_BLK_FLAG   	0x8 	/* BIT 3 */
#define ATUC_CHAN_INTVL_UNCORR_BLK_FLAG   	0x10 	/* BIT 4 */
#define ATUC_CHAN_INTVL_VALID_DATA_FLAG 	0x20 	/* BIT 5 */

/* adslAturChanIntervalTable Flags */
#define ATUR_CHAN_INTVL_NUM_FLAG   	     	0x1 	/* BIT 0th Position */
#define ATUR_CHAN_INTVL_RECV_BLK_FLAG  		0x2 	/* BIT 1 */
#define ATUR_CHAN_INTVL_TX_BLK_FLAG  		0x4	/* BIT 2 */
#define ATUR_CHAN_INTVL_CORR_BLK_FLAG   	0x8 	/* BIT 3 */
#define ATUR_CHAN_INTVL_UNCORR_BLK_FLAG   	0x10 	/* BIT 4 */
#define ATUR_CHAN_INTVL_VALID_DATA_FLAG 	0x20 	/* BIT 5 */

/* adslLineAlarmConfProfileTable Flags */
#define ATUC_THRESH_15MIN_LOFS_FLAG   		0x01   /* BIT 0th position */
#define ATUC_THRESH_15MIN_LOSS_FLAG   		0x02   /* BIT 1 */
#define ATUC_THRESH_15MIN_ESS_FLAG      	0x04   /* BIT 2 */
#define ATUC_THRESH_FAST_RATEUP_FLAG     	0x08   /* BIT 3 */
#define ATUC_THRESH_INTERLEAVE_RATEUP_FLAG	0x10   /* BIT 4 */
#define ATUC_THRESH_FAST_RATEDOWN_FLAG		0x20	 /* BIT 5 */
#define ATUC_THRESH_INTERLEAVE_RATEDOWN_FLAG   	0x40	/* BIT 6 */
#define ATUC_INIT_FAILURE_TRAP_ENABLE_FLAG	0x80 	/* BIT 7 */
#define ATUR_THRESH_15MIN_LOFS_FLAG   		0x100  	/* BIT 8 */
#define ATUR_THRESH_15MIN_LOSS_FLAG   		0x200  	/* BIT 9 */
#define ATUR_THRESH_15MIN_LPRS_FLAG    		0x400  	/* BIT 10 */
#define ATUR_THRESH_15MIN_ESS_FLAG      	0x800   	/* BIT 11 */
#define ATUR_THRESH_FAST_RATEUP_FLAG     	0x1000  	/* BIT 12 */
#define ATUR_THRESH_INTERLEAVE_RATEUP_FLAG	0x2000  	/* BIT 13 */
#define ATUR_THRESH_FAST_RATEDOWN_FLAG     	0x4000 	/* BIT 14 */
#define ATUR_THRESH_INTERLEAVE_RATEDOWN_FLAG	0x8000   	/* BIT 15 */
#define LINE_ALARM_CONF_PROFILE_ROWSTATUS_FLAG  0x10000   	/* BIT 16 */


/* adslAturTraps Flags */
#define ATUC_PERF_LOFS_THRESH_FLAG   	     	0x1 	/* BIT 0th position */
#define ATUC_PERF_LOSS_THRESH_FLAG  	 	0x2 	/* BIT 1 */
#define ATUC_PERF_ESS_THRESH_FLAG  	 	0x4 	/* BIT 2 */
#define ATUC_RATE_CHANGE_FLAG	  	 	0x8 	/* BIT 3 */
#define ATUR_PERF_LOFS_THRESH_FLAG   	     	0x10 	/* BIT 4 */
#define ATUR_PERF_LOSS_THRESH_FLAG  	 	0x20 	/* BIT 5 */
#define ATUR_PERF_LPRS_THRESH_FLAG  	 	0x40 	/* BIT 6 */
#define ATUR_PERF_ESS_THRESH_FLAG  	 	0x80 	/* BIT 7 */
#define ATUR_RATE_CHANGE_FLAG	  	 	0x100	/* BIT 8 */

//RFC- 3440 FLAG DEFINITIONS

#ifdef AMAZON_MEI_MIB_RFC3440
/* adslLineExtTable flags */
#define ATUC_LINE_TRANS_CAP_FLAG	 	0x1		/* BIT 0th position */
#define ATUC_LINE_TRANS_CAP_FLAG_MAKECMV	makeCMV(H2D_CMV_READ,INFO, 67, 0, 1, data)
#define ATUC_LINE_TRANS_CONFIG_FLAG	 	0x2		/* BIT 1 */
#define ATUC_LINE_TRANS_CONFIG_FLAG_MAKECMV	makeCMV(H2D_CMV_READ,INFO, 67, 0, 1, data)
#define ATUC_LINE_TRANS_CONFIG_FLAG_MAKECMV_WR	makeCMV(H2D_CMV_WRITE,INFO, 67, 0, 1, data)
#define ATUC_LINE_TRANS_ACTUAL_FLAG	 	0x4		/* BIT 2 */
#define ATUC_LINE_TRANS_ACTUAL_FLAG_MAKECMV	makeCMV(H2D_CMV_READ,STAT, 1, 0, 1, data)
#define LINE_GLITE_POWER_STATE_FLAG 	 	0x8		/* BIT 3 */
#define LINE_GLITE_POWER_STATE_FLAG_MAKECMV	makeCMV(H2D_CMV_READ,STAT, 0, 0, 1, data) 

/* adslAtucPerfDataExtTable flags */
#define ATUC_PERF_STAT_FASTR_FLAG	   0x1 /* BIT 0th position */
#define ATUC_PERF_STAT_FASTR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, STAT, 0, 0, 1, data)
#define ATUC_PERF_STAT_FAILED_FASTR_FLAG 0x2 /* BIT 1 */
#define ATUC_PERF_STAT_FAILED_FASTR_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, STAT, 0, 0, 1, data)
#define ATUC_PERF_STAT_SESL_FLAG 	   0X4	/* BIT 2 */
#define ATUC_PERF_STAT_SESL_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 8, 0, 1, data)
#define ATUC_PERF_STAT_UASL_FLAG		   0X8	/* BIT 3 */
#define ATUC_PERF_STAT_UASL_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 10, 0, 1, data)
#define ATUC_PERF_CURR_15MIN_FASTR_FLAG	   0X10	/* BIT 4 */
#define ATUC_PERF_CURR_15MIN_FAILED_FASTR_FLAG 0X20	/* BIT 5 */
#define ATUC_PERF_CURR_15MIN_SESL_FLAG	         0X40	/* BIT 6 */
#define ATUC_PERF_CURR_15MIN_UASL_FLAG		    0X80	/* BIT 7 */
#define ATUC_PERF_CURR_1DAY_FASTR_FLAG		    0X100	/* BIT 8 */
#define ATUC_PERF_CURR_1DAY_FAILED_FASTR_FLAG	0X200	/* BIT 9 */
#define ATUC_PERF_CURR_1DAY_SESL_FLAG			0X400	/* BIT 10 */
#define ATUC_PERF_CURR_1DAY_UASL_FLAG			0X800	/* BIT 11 */
#define ATUC_PERF_PREV_1DAY_FASTR_FLAG		     0X1000 /* BIT 12 */
#define ATUC_PERF_PREV_1DAY_FAILED_FASTR_FLAG	0X2000 /* BIT 13 */
#define ATUC_PERF_PREV_1DAY_SESL_FLAG			0X4000 /* BIT 14 */
#define ATUC_PERF_PREV_1DAY_UASL_FLAG			0X8000 /* BIT 15 */

/* adslAturPerfDataExtTable */
#define ATUR_PERF_STAT_SESL_FLAG		0X1 /* BIT 0th position */
#define ATUR_PERF_STAT_SESL_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 34, 0, 1, data)	
#define ATUR_PERF_STAT_UASL_FLAG		0X2 /* BIT 1 */
#define ATUR_PERF_STAT_UASL_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 36, 0, 1, data)
#define ATUR_PERF_CURR_15MIN_SESL_FLAG		0X4 /* BIT 2 */
#define ATUR_PERF_CURR_15MIN_UASL_FLAG		0X8 /* BIT 3 */
#define ATUR_PERF_CURR_1DAY_SESL_FLAG		0X10 /* BIT 4 */
#define ATUR_PERF_CURR_1DAY_UASL_FLAG		0X20 /* BIT 5 */
#define ATUR_PERF_PREV_1DAY_SESL_FLAG		0X40 /* BIT 6 */
#define ATUR_PERF_PREV_1DAY_UASL_FLAG		0X80 /* BIT 7 */

/* adslAutcIntervalExtTable flags */
#define ATUC_INTERVAL_FASTR_FLAG		0x1 /* Bit 0 */ 	
#define ATUC_INTERVAL_FAILED_FASTR_FLAG		0x2 /* Bit 1 */ 	
#define ATUC_INTERVAL_SESL_FLAG			0x4 /* Bit 2 */ 	
#define ATUC_INTERVAL_UASL_FLAG			0x8 /* Bit 3 */ 	

/* adslAturIntervalExtTable */
#define ATUR_INTERVAL_SESL_FLAG		0X1 /* BIT 0th position */
#define ATUR_INTERVAL_UASL_FLAG		0X2 /* BIT 1 */

/* adslAlarmConfProfileExtTable */
#define ATUC_THRESH_15MIN_FAILED_FASTR_FLAG 0X1/* BIT 0th position */
#define ATUC_THRESH_15MIN_SESL_FLAG		 0X2 /* BIT 1 */
#define ATUC_THRESH_15MIN_UASL_FLAG		 0X4 /* BIT 2 */
#define ATUR_THRESH_15MIN_SESL_FLAG		 0X8 /* BIT 3 */
#define ATUR_THRESH_15MIN_UASL_FLAG		 0X10 /* BIT 4 */

/* adslAturExtTraps */
#define ATUC_15MIN_FAILED_FASTR_TRAP_FLAG 	0X1 /* BIT 0th position */
#define ATUC_15MIN_SESL_TRAP_FLAG		 0X2 /* BIT 1 */
#define ATUC_15MIN_UASL_TRAP_FLAG		 0X4 /* BIT 2 */
#define ATUR_15MIN_SESL_TRAP_FLAG		 0X8 /* BIT 3 */
#define ATUR_15MIN_UASL_TRAP_FLAG		 0X10 /* BIT 4 */

// 603221:tc.chen start 	
/* adslLineStatus Flags */
#define LINE_STAT_MODEM_STATUS_FLAG   	 0x1 /* BIT 0th position */
#define LINE_STAT_MODEM_STATUS_FLAG_MAKECMV makeCMV(H2D_CMV_READ, STAT, 0, 0, 1, data)
#define LINE_STAT_MODE_SEL_FLAG  	 0x2 /* BIT 1 */
#define LINE_STAT_MODE_SEL_FLAG_MAKECMV makeCMV(H2D_CMV_READ, STAT, 1, 0, 1, data)
#define LINE_STAT_TRELLCOD_ENABLE_FLAG 0x4 /* BIT 2 */
#define LINE_STAT_TRELLCOD_ENABLE_FLAG_MAKECMV makeCMV(H2D_CMV_READ, OPTN, 2, 0, 1, data)
#define LINE_STAT_LATENCY_FLAG	  	 0x8 /* BIT 3 */
#define LINE_STAT_LATENCY_FLAG_MAKECMV makeCMV(H2D_CMV_READ, STAT, 12, 0, 1, data)

/* adslLineRate Flags */
#define LINE_RATE_DATA_RATEDS_FLAG   	0x1 /* BIT 0th position */
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL1_LP0_MAKECMV makeCMV(H2D_CMV_READ, RATE, 1, 0, 2, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL1_LP1_MAKECMV makeCMV(H2D_CMV_READ, RATE, 1, 2, 2, data)


#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_RP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 12, 0, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_MP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 13, 0, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_LP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 14, 0, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_TP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 15, 0, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_KP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 17, 0, 2, data)

#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_RP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 12, 1, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_MP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 13, 1, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_LP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 14, 1, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_TP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 15, 1, 1, data)
#define LINE_RATE_DATA_RATEDS_FLAG_ADSL2_KP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 17, 2, 2, data)

#define LINE_RATE_DATA_RATEUS_FLAG  	0x2 /* BIT 1 */
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL1_LP0_MAKECMV makeCMV(H2D_CMV_READ, RATE, 0, 0, 2, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL1_LP1_MAKECMV makeCMV(H2D_CMV_READ, RATE, 0, 2, 2, data)


#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_RP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 23, 0, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_MP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 24, 0, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_LP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 25, 0, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_TP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 26, 0, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_KP_LP0_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 28, 0, 2, data)

#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_RP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 23, 1, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_MP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 24, 1, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_LP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 25, 1, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_TP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 26, 1, 1, data)
#define LINE_RATE_DATA_RATEUS_FLAG_ADSL2_KP_LP1_MAKECMV makeCMV(H2D_CMV_READ, CNFG, 28, 2, 2, data)

#define LINE_RATE_ATTNDRDS_FLAG  	0x4 /* BIT 2 */
#define LINE_RATE_ATTNDRDS_FLAG_MAKECMV makeCMV(H2D_CMV_READ, INFO, 68, 4, 2, data)

#define LINE_RATE_ATTNDRUS_FLAG	  	0x8 /* BIT 3 */
#define LINE_RATE_ATTNDRUS_FLAG_MAKECMV makeCMV(H2D_CMV_READ, INFO, 69, 4, 2, data)

/* adslLineInformation Flags */
#define LINE_INFO_INTLV_DEPTHDS_FLAG	0x1 /* BIT 0th position */
#define LINE_INFO_INTLV_DEPTHDS_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, CNFG, 27, 0, 1, data)
#define LINE_INFO_INTLV_DEPTHDS_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, CNFG, 27, 1, 1, data)
#define LINE_INFO_INTLV_DEPTHUS_FLAG	0x2 /* BIT 1 */
#define LINE_INFO_INTLV_DEPTHUS_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, CNFG, 16, 0, 1, data)
#define LINE_INFO_INTLV_DEPTHUS_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, CNFG, 16, 1, 1, data)
#define LINE_INFO_LATNDS_FLAG		0x4 /* BIT 2 */
#define LINE_INFO_LATNDS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 1, 1, data)
#define LINE_INFO_LATNUS_FLAG	  	0x8 /* BIT 3 */
#define LINE_INFO_LATNUS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 1, 1, data)
#define LINE_INFO_SATNDS_FLAG   	 	0x10 /* BIT 4 */
#define LINE_INFO_SATNDS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 2, 1, data)
#define LINE_INFO_SATNUS_FLAG  	 	0x20 /* BIT 5 */
#define LINE_INFO_SATNUS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 2, 1, data)
#define LINE_INFO_SNRMNDS_FLAG  	 	0x40 /* BIT 6 */
#define LINE_INFO_SNRMNDS_FLAG_ADSL1_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 3, 1, data)
#define LINE_INFO_SNRMNDS_FLAG_ADSL2_MAKECMV	makeCMV(H2D_CMV_READ, RATE, 3, 0, 1, data)
#define LINE_INFO_SNRMNDS_FLAG_ADSL2PLUS_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 46, 0, 1, data)
#define LINE_INFO_SNRMNUS_FLAG  	 	0x80 /* BIT 7 */
#define LINE_INFO_SNRMNUS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 3, 1, data)
#define LINE_INFO_ACATPDS_FLAG	  	0x100 /* BIT 8 */
#define LINE_INFO_ACATPDS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 68, 6, 1, data)
#define LINE_INFO_ACATPUS_FLAG	  	0x200 /* BIT 9 */
#define LINE_INFO_ACATPUS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 69, 6, 1, data)

/* adslNearEndPerformanceStats Flags */
#define NEAREND_PERF_SUPERFRAME_FLAG_LSW_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 20, 0, 1, data)
#define NEAREND_PERF_SUPERFRAME_FLAG_MSW_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 21, 0, 1, data)
#define NEAREND_PERF_SUPERFRAME_FLAG	0x1 /* BIT 0th position */
#define NEAREND_PERF_LOS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 0, 0, 1, data)
#define NEAREND_PERF_LOS_FLAG		0x2 /* BIT 1 */
#define NEAREND_PERF_LOF_FLAG		0x4 /* BIT 2 */
#define NEAREND_PERF_LPR_FLAG		0x8 /* BIT 3 */
#define NEAREND_PERF_NCD_FLAG		0x10 /* BIT 4 */
#define NEAREND_PERF_LCD_FLAG		0x20 /* BIT 5 */
#define NEAREND_PERF_CRC_FLAG		0x40 /* BIT 6 */
#define NEAREND_PERF_CRC_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 2, 0, 1, data)
#define NEAREND_PERF_CRC_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 2, 1, 1, data)
#define NEAREND_PERF_RSCORR_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 3, 0, 1, data)
#define NEAREND_PERF_RSCORR_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 3, 1, 1, data)
#define NEAREND_PERF_RSCORR_FLAG	0x80 /* BIT 7 */
#define NEAREND_PERF_FECS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 6, 0, 1, data)
#define NEAREND_PERF_FECS_FLAG		0x100 /* BIT 8 */
#define NEAREND_PERF_ES_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 7, 0, 1, data)
#define NEAREND_PERF_ES_FLAG		0x200 /* BIT 9 */
#define NEAREND_PERF_SES_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 8, 0, 1, data)
#define NEAREND_PERF_SES_FLAG		0x400 /* BIT 10 */
#define NEAREND_PERF_LOSS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 9, 0, 1, data)
#define NEAREND_PERF_LOSS_FLAG		0x800 /* BIT 11 */
#define NEAREND_PERF_UAS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 10, 0, 1, data)
#define NEAREND_PERF_UAS_FLAG		0x1000 /* BIT 12 */
#define NEAREND_PERF_HECERR_FLAG_BC0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 11, 0, 2, data)
#define NEAREND_PERF_HECERR_FLAG_BC1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 11, 2, 2, data)
#define NEAREND_PERF_HECERR_FLAG		0x2000 /* BIT 13 */

/* adslFarEndPerformanceStats Flags */
#define FAREND_PERF_LOS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 1, 0, 1, data)
#define FAREND_PERF_LOS_FLAG	0x1 /* BIT 0th position */
#define FAREND_PERF_LOF_FLAG	0x2 /* BIT 1 */
#define FAREND_PERF_LPR_FLAG	0x4 /* BIT 2 */
#define FAREND_PERF_NCD_FLAG	0x8 /* BIT 3 */
#define FAREND_PERF_LCD_FLAG	0x10 /* BIT 4 */
#define FAREND_PERF_CRC_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 24, 0, 1, data)
#define FAREND_PERF_CRC_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 24, 1, 1, data)
#define FAREND_PERF_CRC_FLAG	0x20 /* BIT 5 */
#define FAREND_PERF_RSCORR_FLAG_LP0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 28, 0, 1, data)
#define FAREND_PERF_RSCORR_FLAG_LP1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 28, 1, 1, data)
#define FAREND_PERF_RSCORR_FLAG	0x40 /* BIT 6 */
#define FAREND_PERF_FECS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 32, 0, 1, data)
#define FAREND_PERF_FECS_FLAG	0x80 /* BIT 7 */
#define FAREND_PERF_ES_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 33, 0, 1, data)
#define FAREND_PERF_ES_FLAG	0x100 /* BIT 8 */
#define FAREND_PERF_SES_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 34, 0, 1, data)
#define FAREND_PERF_SES_FLAG	0x200 /* BIT 9 */
#define FAREND_PERF_LOSS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 35, 0, 1, data)
#define FAREND_PERF_LOSS_FLAG	0x400 /* BIT 10 */
#define FAREND_PERF_UAS_FLAG_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 36, 0, 1, data)
#define FAREND_PERF_UAS_FLAG	0x800 /* BIT 11 */
#define FAREND_PERF_HECERR_FLAG_BC0_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 37, 0, 2, data)
#define FAREND_PERF_HECERR_FLAG_BC1_MAKECMV	makeCMV(H2D_CMV_READ, PLAM, 37, 2, 2, data)
#define FAREND_PERF_HECERR_FLAG	0x1000 /* BIT 12 */
// 603221:tc.chen end
/* TR-69 related additional parameters - defines */
/* Defines for  struct adslATURSubcarrierInfo */
#define	NEAREND_HLINSC	0x1
#define NEAREND_HLINSC_MAKECMV(mode)		makeCMV(mode, INFO, 71, 2, 1, data)
#define	NEAREND_HLINPS	0x2
#define NEAREND_HLINPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 73, idx, size, data)
#define	NEAREND_HLOGMT	0x4
#define NEAREND_HLOGMT_MAKECMV(mode)		makeCMV(mode, INFO, 80, 0, 1, data)
#define NEAREND_HLOGPS	0x8
#define NEAREND_HLOGPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 75, idx, size, data)
#define NEAREND_QLNMT	0x10
#define NEAREND_QLNMT_MAKECMV(mode)		makeCMV(mode, INFO, 80, 1, 1, data)
#define	NEAREND_QLNPS	0x20
#define NEAREND_QLNPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 77, idx, size, data)
#define	NEAREND_SNRMT	0x40
#define NEAREND_SNRMT_MAKECMV(mode)		makeCMV(mode, INFO, 80, 2, 1, data)
#define	NEAREND_SNRPS	0x80
#define NEAREND_SNRPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 78, idx, size, data)
#define	NEAREND_BITPS	0x100
#define NEAREND_BITPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 22, idx, size, data)
#define	NEAREND_GAINPS	0x200
#define NEAREND_GAINPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 24, idx, size, data)

/* Defines for  struct adslATUCSubcarrierInfo */
#define	 FAREND_HLINSC	0x1
#define  FAREND_HLINSC_MAKECMV(mode)		makeCMV(mode, INFO, 70, 0, 1, data)
#define	 FAREND_HLINPS	0x2
#define  FAREND_HLINPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 72, idx, size, data)
#define	 FAREND_HLOGMT	0x4
#define  FAREND_HLOGMT_MAKECMV(mode)		makeCMV(mode, INFO, 79, 0, 1, data)
#define  FAREND_HLOGPS	0x8
#define  FAREND_HLOGPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 74, idx, size, data)
#define  FAREND_QLNMT	0x10
#define  FAREND_QLNMT_MAKECMV(mode)		makeCMV(mode, INFO, 79, 1, 1, data)
#define	 FAREND_QLNPS	0x20
#define  FAREND_QLNPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 76, idx, size, data)
#define	 FAREND_SNRMT	0x40
#define  FAREND_SNRMT_MAKECMV(mode)		makeCMV(mode, INFO, 79, 2, 1, data)
#define	 FAREND_SNRPS	0x80
#define  FAREND_SNRPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 10, idx, size, data)
#define	 FAREND_BITPS	0x100
#define  FAREND_BITPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 23, idx, size, data)
#define	 FAREND_GAINPS	0x200
#define  FAREND_GAINPS_MAKECMV(mode,idx,size)	makeCMV(mode, INFO, 25, idx, size, data)


// GET_ADSL_POWER_SPECTRAL_DENSITY
#define NOMPSD_US_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 102, 0, 1, data)
#define NOMPSD_DS_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 102, 1, 1, data)
#define PCB_US_MAKECMV		makeCMV(H2D_CMV_READ, INFO, 102, 6, 1, data)
#define PCB_DS_MAKECMV		makeCMV(H2D_CMV_READ, INFO, 102, 7, 1, data)
#define	RMSGI_US_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 102, 10, 1, data)
#define	RMSGI_DS_MAKECMV	makeCMV(H2D_CMV_READ, INFO, 102, 11, 1, data)


#endif
/////////////////////////////////////////////////Macro Definitions ? FLAG Setting & Testing

#define SET_FLAG(flags, flag_val)   ((*flags) = ((*flags) | flag_val))
//	-- This macro sets the flags with the flag_val. Here flags is passed as a pointer

#define IS_FLAG_SET(flags, test_flag)	(((*flags) & (test_flag)) == (test_flag)? test_flag:0)
// 	-- This macro verifies whether test_flag has been set in flags. Here flags is passed as a pointer


#define CLR_FLAG(flags, flag_bit)	((*flags) = (*flags) & (~flag_bit))
//	-- This macro resets the specified flag_bit in the flags. Here flags is passed as a pointer


////////////////////////////////////////////////DATA STRUCTURES ORGANIZATION
	
//Here are the data structures used for accessing mib parameters. The ioctl call includes the third parameter as a void pointer. This parameter has to be type-casted in the driver code to the corresponding structure depending upon the command type. For Ex: consider the ioctl used to get the adslLineCode type, ioctl(fd,GET_ADSL_LINE_CODE,void *struct_adslLineTableEntry). In the driver code we check on the type of the command, i.e GET_ADSL_LINE_CODE and type-cast the void pointer to struct adslLineTableEntry type.
	//
#define u32 unsigned int
#define u16 unsigned short
#define s16 short
#define u8 unsigned char


typedef u32 AdslPerfTimeElapsed;
typedef u32 AdslPerfPrevDayCount;
typedef u32 PerfCurrentCount;
typedef u32 PerfIntervalCount;
typedef u32 AdslPerfCurrDayCount;


//ioctl(int fd, GET_ADSL_LINE_CODE, void *struct_adslLineTableEntry)

typedef struct adslLineTableEntry {
	int ifIndex;
	int adslLineCode;
	u8 flags;
} adslLineTableEntry;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct adslLineExtTableEntry {
	int ifIndex;
	u16 adslLineTransAtucCap;
	u16 adslLineTransAtucConfig;
	u16 adslLineTransAtucActual;
	int adslLineGlitePowerState;
	u32 flags;
}adslLineExtTableEntry;
#endif
//ioctl(int fd, GET_ADSL_ATUC_PHY, void  *struct_adslAtucPhysEntry)

typedef struct adslVendorId {
	u16	country_code;
	u_char	provider_id[4];  /* Ascii characters */
	u_char	revision_info[2];
}adslVendorId;


typedef struct adslAtucPhysEntry {
	int ifIndex;
	char serial_no[32];
	union {
		char vendor_id[16];
		adslVendorId vendor_info;
	} vendor_id;

	char version_no[16];
	u32 status;
	int outputPwr;
	u32 attainableRate;
	u8 flags;
} adslAtucPhysEntry;


//ioctl(int fd, GET_ADSL_ATUR_PHY, void  *struct_adslAturPhysEntry)

typedef struct adslAturPhysEntry {
	int ifIndex;
	char serial_no[32];
	union {
	char vendor_id[16];
		adslVendorId vendor_info;
	} vendor_id;
	char version_no[16];
	int SnrMgn;
	u32 Attn;
	u32 status;
	int outputPwr;
	u32 attainableRate;
	u8 flags;
} adslAturPhysEntry;


//ioctl(int fd, GET_ADSL_ATUC_CHAN_INFO, void *struct_adslAtucChanInfo)

typedef struct adslAtucChanInfo {
	int ifIndex;
 	u32 interleaveDelay;
	u32 currTxRate;
	u32 prevTxRate;
	u8 flags;
} adslAtucChanInfo;


//ioctl(int fd, GET_ADSL_ATUR_CHAN_INFO, void *struct_adslAturChanInfo)

typedef struct adslAturChanInfo {
	int ifIndex;
 	u32 interleaveDelay;
 	u32 currTxRate;
 	u32 prevTxRate;
 	u32 crcBlkLen;
 	u8 flags;
} adslAturChanInfo;


//ioctl(int fd, GET_ADSL_ATUC_PERF_DATA,  void *struct_atucPerfDataEntry)

typedef struct atucPerfDataEntry
{
   int			ifIndex;
   u32 			adslAtucPerfLofs;             
   u32 			adslAtucPerfLoss;             
   u32 			adslAtucPerfESs;                 
   u32 			adslAtucPerfInits;
   int         		adslAtucPerfValidIntervals;
   int         		adslAtucPerfInvalidIntervals;
   AdslPerfTimeElapsed 	adslAtucPerfCurr15MinTimeElapsed;
   PerfCurrentCount 	adslAtucPerfCurr15MinLofs;
   PerfCurrentCount 	adslAtucPerfCurr15MinLoss;
   PerfCurrentCount 	adslAtucPerfCurr15MinESs;
   PerfCurrentCount 	adslAtucPerfCurr15MinInits;
   AdslPerfTimeElapsed 	adslAtucPerfCurr1DayTimeElapsed;
   AdslPerfCurrDayCount adslAtucPerfCurr1DayLofs;
   AdslPerfCurrDayCount adslAtucPerfCurr1DayLoss;
   AdslPerfCurrDayCount adslAtucPerfCurr1DayESs;
   AdslPerfCurrDayCount adslAtucPerfCurr1DayInits;
   int         		adslAtucPerfPrev1DayMoniSecs;
   AdslPerfPrevDayCount adslAtucPerfPrev1DayLofs;
   AdslPerfPrevDayCount adslAtucPerfPrev1DayLoss;
   AdslPerfPrevDayCount adslAtucPerfPrev1DayESs;
   AdslPerfPrevDayCount adslAtucPerfPrev1DayInits;
   u32			flags;
} atucPerfDataEntry;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct atucPerfDataExtEntry
 {
  int ifIndex;
  u32 adslAtucPerfStatFastR;
  u32 adslAtucPerfStatFailedFastR;
  u32 adslAtucPerfStatSesL;
  u32 adslAtucPerfStatUasL;
  u32 adslAtucPerfCurr15MinFastR;
  u32 adslAtucPerfCurr15MinFailedFastR;
  u32 adslAtucPerfCurr15MinSesL;
  u32 adslAtucPerfCurr15MinUasL;
  u32 adslAtucPerfCurr1DayFastR;
  u32 adslAtucPerfCurr1DayFailedFastR;
  u32 adslAtucPerfCurr1DaySesL;
  u32 adslAtucPerfCurr1DayUasL;
  u32 adslAtucPerfPrev1DayFastR;
  u32 adslAtucPerfPrev1DayFailedFastR;
  u32 adslAtucPerfPrev1DaySesL;
  u32 adslAtucPerfPrev1DayUasL;
  u32	flags;
} atucPerfDataExtEntry; 

#endif
//ioctl(int fd, GET_ADSL_ATUR_PERF_DATA, void *struct_aturPerfDataEntry)

typedef struct aturPerfDataEntry
{
   int			ifIndex;
   u32 			adslAturPerfLofs;             
   u32 			adslAturPerfLoss;             
   u32 			adslAturPerfLprs;                 
   u32 			adslAturPerfESs;
   int         		adslAturPerfValidIntervals;
   int         		adslAturPerfInvalidIntervals;
   AdslPerfTimeElapsed 	adslAturPerfCurr15MinTimeElapsed;
   PerfCurrentCount 	adslAturPerfCurr15MinLofs;
   PerfCurrentCount 	adslAturPerfCurr15MinLoss;
   PerfCurrentCount 	adslAturPerfCurr15MinLprs;
   PerfCurrentCount 	adslAturPerfCurr15MinESs;
   AdslPerfTimeElapsed 	adslAturPerfCurr1DayTimeElapsed;
   AdslPerfCurrDayCount adslAturPerfCurr1DayLofs;
   AdslPerfCurrDayCount adslAturPerfCurr1DayLoss;
   AdslPerfCurrDayCount adslAturPerfCurr1DayLprs;
   AdslPerfCurrDayCount adslAturPerfCurr1DayESs;
   int         		adslAturPerfPrev1DayMoniSecs;
   AdslPerfPrevDayCount adslAturPerfPrev1DayLofs;
   AdslPerfPrevDayCount adslAturPerfPrev1DayLoss;
   AdslPerfPrevDayCount adslAturPerfPrev1DayLprs;
   AdslPerfPrevDayCount adslAturPerfPrev1DayESs;
   u32			flags;
} aturPerfDataEntry;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct aturPerfDataExtEntry
 {
  int ifIndex;
  u32 adslAturPerfStatSesL;
  u32 adslAturPerfStatUasL;
  u32 adslAturPerfCurr15MinSesL;
  u32 adslAturPerfCurr15MinUasL;
  u32 adslAturPerfCurr1DaySesL;
  u32 adslAturPerfCurr1DayUasL;
  u32 adslAturPerfPrev1DaySesL;
  u32 adslAturPerfPrev1DayUasL;
  u32	flags;
} aturPerfDataExtEntry;
#endif
//ioctl(int fd, GET_ADSL_ATUC_INTVL_INFO, void *struct_adslAtucInvtInfo)

typedef struct adslAtucIntvlInfo {
	int ifIndex;
        int IntervalNumber;
 	PerfIntervalCount intervalLOF;
 	PerfIntervalCount intervalLOS;
  	PerfIntervalCount intervalES;
 	PerfIntervalCount intervalInits; 
	int intervalValidData;
 	u8 flags;
} adslAtucIntvlInfo;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct adslAtucInvtlExtInfo
 {
  int ifIndex;
  int IntervalNumber;
  u32 adslAtucIntervalFastR;
  u32 adslAtucIntervalFailedFastR;
  u32 adslAtucIntervalSesL;
  u32 adslAtucIntervalUasL;
  u32	flags;
} adslAtucInvtlExtInfo;
#endif
//ioctl(int fd, GET_ADSL_ATUR_INTVL_INFO, void *struct_adslAturInvtlInfo)

typedef struct adslAturIntvlInfo {
	int ifIndex;
        int IntervalNumber;
 	PerfIntervalCount intervalLOF;
 	PerfIntervalCount intervalLOS;
 	PerfIntervalCount intervalLPR;
  	PerfIntervalCount intervalES;
 	int intervalValidData;
 	u8 flags;
} adslAturIntvlInfo;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct adslAturInvtlExtInfo
 {
  int ifIndex;
  int IntervalNumber;
  u32 adslAturIntervalSesL;
  u32 adslAturIntervalUasL;
  u32	flags;
} adslAturInvtlExtInfo;
#endif
//ioctl(int fd, GET_ADSL_ATUC_CHAN_PERF_DATA,  void *struct_atucChannelPerfDataEntry)

typedef struct atucChannelPerfDataEntry
{
   int			ifIndex;
   u32 			adslAtucChanReceivedBlks;             
   u32 			adslAtucChanTransmittedBlks;             
   u32 			adslAtucChanCorrectedBlks;                 
   u32 			adslAtucChanUncorrectBlks;
   int         		adslAtucChanPerfValidIntervals;
   int         		adslAtucChanPerfInvalidIntervals;
   AdslPerfTimeElapsed 	adslAtucChanPerfCurr15MinTimeElapsed;
   PerfCurrentCount 	adslAtucChanPerfCurr15MinReceivedBlks;
   PerfCurrentCount 	adslAtucChanPerfCurr15MinTransmittedBlks;
   PerfCurrentCount 	adslAtucChanPerfCurr15MinCorrectedBlks;
   PerfCurrentCount 	adslAtucChanPerfCurr15MinUncorrectBlks;
   AdslPerfTimeElapsed  adslAtucChanPerfCurr1DayTimeElapsed;
   AdslPerfCurrDayCount adslAtucChanPerfCurr1DayReceivedBlks;
   AdslPerfCurrDayCount adslAtucChanPerfCurr1DayTransmittedBlks;
   AdslPerfCurrDayCount adslAtucChanPerfCurr1DayCorrectedBlks;
   AdslPerfCurrDayCount adslAtucChanPerfCurr1DayUncorrectBlks;
   int                  adslAtucChanPerfPrev1DayMoniSecs;
   AdslPerfPrevDayCount adslAtucChanPerfPrev1DayReceivedBlks;
   AdslPerfPrevDayCount adslAtucChanPerfPrev1DayTransmittedBlks;
   AdslPerfPrevDayCount adslAtucChanPerfPrev1DayCorrectedBlks;
   AdslPerfPrevDayCount adslAtucChanPerfPrev1DayUncorrectBlks;
   u32			flags;
}atucChannelPerfDataEntry;


//ioctl(int fd, GET_ADSL_ATUR_CHAN_PERF_DATA,  void *struct_aturChannelPerfDataEntry)

typedef struct aturChannelPerfDataEntry
{
   int			ifIndex;
   u32 			adslAturChanReceivedBlks;             
   u32 			adslAturChanTransmittedBlks;             
   u32 			adslAturChanCorrectedBlks;                 
   u32 			adslAturChanUncorrectBlks;
   int         		adslAturChanPerfValidIntervals;
   int         		adslAturChanPerfInvalidIntervals;
   AdslPerfTimeElapsed 	adslAturChanPerfCurr15MinTimeElapsed;
   PerfCurrentCount 	adslAturChanPerfCurr15MinReceivedBlks;
   PerfCurrentCount 	adslAturChanPerfCurr15MinTransmittedBlks;
   PerfCurrentCount 	adslAturChanPerfCurr15MinCorrectedBlks;
   PerfCurrentCount 	adslAturChanPerfCurr15MinUncorrectBlks;
   AdslPerfTimeElapsed  adslAturChanPerfCurr1DayTimeElapsed;
   AdslPerfCurrDayCount adslAturChanPerfCurr1DayReceivedBlks;
   AdslPerfCurrDayCount adslAturChanPerfCurr1DayTransmittedBlks;
   AdslPerfCurrDayCount adslAturChanPerfCurr1DayCorrectedBlks;
   AdslPerfCurrDayCount adslAturChanPerfCurr1DayUncorrectBlks;
   int                  adslAturChanPerfPrev1DayMoniSecs;
   AdslPerfPrevDayCount adslAturChanPerfPrev1DayReceivedBlks;
   AdslPerfPrevDayCount adslAturChanPerfPrev1DayTransmittedBlks;
   AdslPerfPrevDayCount adslAturChanPerfPrev1DayCorrectedBlks;
   AdslPerfPrevDayCount adslAturChanPerfPrev1DayUncorrectBlks;
   u32			flags;
} aturChannelPerfDataEntry;


//ioctl(int fd, GET_ADSL_ATUC_CHAN_INTVL_INFO, void *struct_adslAtucChanIntvlInfo)

typedef struct adslAtucChanIntvlInfo {
	int ifIndex;
        int IntervalNumber;
 	PerfIntervalCount chanIntervalRecvdBlks;
 	PerfIntervalCount chanIntervalXmitBlks;
  	PerfIntervalCount chanIntervalCorrectedBlks;
 	PerfIntervalCount chanIntervalUncorrectBlks;
 	int intervalValidData;
 	u8 flags;
} adslAtucChanIntvlInfo;


//ioctl(int fd, GET_ADSL_ATUR_CHAN_INTVL_INFO, void *struct_adslAturChanIntvlInfo)

typedef struct adslAturChanIntvlInfo {
	int ifIndex;
        int IntervalNumber;
 	PerfIntervalCount chanIntervalRecvdBlks;
 	PerfIntervalCount chanIntervalXmitBlks;
  	PerfIntervalCount chanIntervalCorrectedBlks;
 	PerfIntervalCount chanIntervalUncorrectBlks;
 	int intervalValidData;
	u8 flags;
} adslAturChanIntvlInfo;


//ioctl(int fd, GET_ADSL_ALRM_CONF_PROF,  void *struct_adslLineAlarmConfProfileEntry)
//ioctl(int fd, SET_ADSL_ALRM_CONF_PROF,  void *struct_adslLineAlarmConfProfileEntry)

typedef struct  adslLineAlarmConfProfileEntry
 {
  unsigned char adslLineAlarmConfProfileName[32];
    int 	adslAtucThresh15MinLofs;
    int 	adslAtucThresh15MinLoss;
    int 	adslAtucThresh15MinESs;
    u32 	adslAtucThreshFastRateUp;
    u32 	adslAtucThreshInterleaveRateUp;
    u32 	adslAtucThreshFastRateDown;
    u32 	adslAtucThreshInterleaveRateDown;
    int 	adslAtucInitFailureTrapEnable;
    int 	adslAturThresh15MinLofs;
    int 	adslAturThresh15MinLoss;
    int 	adslAturThresh15MinLprs;
    int 	adslAturThresh15MinESs;
    u32 	adslAturThreshFastRateUp;
    u32 	adslAturThreshInterleaveRateUp;
    u32 	adslAturThreshFastRateDown;
    u32 	adslAturThreshInterleaveRateDown;
    int 	adslLineAlarmConfProfileRowStatus;
    u32	flags;
} adslLineAlarmConfProfileEntry;

#ifdef AMAZON_MEI_MIB_RFC3440
typedef struct adslLineAlarmConfProfileExtEntry
 {
  u8  adslLineAlarmConfProfileExtName[32];
  u32 adslAtucThreshold15MinFailedFastR;
  u32 adslAtucThreshold15MinSesL;
  u32 adslAtucThreshold15MinUasL;
  u32 adslAturThreshold15MinSesL;
  u32 adslAturThreshold15MinUasL;
  u32	flags;
} adslLineAlarmConfProfileExtEntry;
#endif
//TRAPS

// 603221:tc.chen start
/* The following Data Sturctures are added to support the WEB related parameters for ADSL Statistics */
typedef struct  adslLineStatus
 {
    int 	adslModemStatus;
    u32 	adslModeSelected;
    int 	adslAtucThresh15MinESs;
    int 	adslTrellisCodeEnable;
    int 	adslLatency;
    u8 flags;
 } adslLineStatusInfo;

typedef struct  adslLineRate
 {
    u32 	adslDataRateds;
    u32 	adslDataRateus;
    u32 	adslATTNDRds;	
    u32 	adslATTNDRus;	
    u8		flags;
 } adslLineRateInfo;

typedef struct  adslLineInfo
 {
    u32 	adslInterleaveDepthds;
    u32 	adslInterleaveDepthus;
    u32 	adslLATNds;
    u32 	adslLATNus;
    u32 	adslSATNds;
    u32 	adslSATNus;
    int	 	adslSNRMds;
    int	 	adslSNRMus;
    int	 	adslACATPds;
    int		adslACATPus;
    u32	flags;
 } adslLineInfo;

typedef struct  adslNearEndPerfStats
 {
    u32 	adslSuperFrames; 
    u32 	adslneLOS;
    u32 	adslneLOF;
    u32 	adslneLPR;
    u32 	adslneNCD;
    u32 	adslneLCD;
    u32 	adslneCRC;
    u32		adslneRSCorr;
    u32		adslneFECS;
    u32		adslneES;
    u32		adslneSES;
    u32		adslneLOSS;
    u32		adslneUAS;
    u32		adslneHECErrors;
    u32		flags;
 } adslNearEndPerfStats;

typedef struct  adslFarEndPerfStats
 {
    u32 	adslfeLOS;
    u32 	adslfeLOF;
    u32 	adslfeLPR;
    u32 	adslfeNCD;
    u32 	adslfeLCD;
    u32 	adslfeCRC;
    u32		adslfeRSCorr;
    u32		adslfeFECS;
    u32		adslfeES;
    u32		adslfeSES;
    u32		adslfeLOSS;
    u32		adslfeUAS;
    u32		adslfeHECErrors;
    u32		flags;
 } adslFarEndPerfStats;
// 603221:tc.chen end

/* The number of tones (and hence indexes) is dependent on the ADSL mode - G.992.1, G.992.2, G.992.3, * G.992.4 and G.992.5 */
typedef struct adslATURSubcarrierInfo {
	int 	ifindex;
	u16	HLINSCds;
	u16	HLINpsds[1024];/* Even index = real part; Odd Index
				    = imaginary part for each tone */
	u16	HLOGMTds;
	u16	HLOGpsds[512];
	u16	QLNMTds;
	u16	QLNpsds[512];
	u16	SNRMTds;
	u16	SNRpsds[512];  
	u16	BITpsds[512];
	u16	GAINpsds[512];
	u16	flags;
}adslATURSubcarrierInfo;

typedef struct adslATUCSubcarrierInfo {
	int 	ifindex;
	u16	HLINSCus;
	u16	HLINpsus[128];/* Even index = real part; Odd Index
				    = imaginary part for each tone */
	u16	HLOGMTus;
	u16	HLOGpsus[64];
	u16	QLNMTus;
	u16	QLNpsus[64]; 
	u16	SNRMTus;
	u16 	SNRpsus[64];  
	u16	BITpsus[64];
	u16	GAINpsus[64];
	u16	flags;
}adslATUCSubcarrierInfo;

#ifndef u_int16
#define u_int16 u16
#endif

typedef struct adslInitStats {
	u_int16	FullInitializationCount;
	u_int16 FailedFullInitializationCount;
	u_int16 LINIT_Errors;
	u_int16	Init_Timeouts;
}adslInitStats;

typedef struct adslPowerSpectralDensity {
	int	ACTPSDds;
	int 	ACTPSDus;
}adslPowerSpectralDensity;


//ioctl(int fd, ADSL_ATUR_TRAPS, void  *uint16_flags)
typedef union structpts {
	adslLineTableEntry * adslLineTableEntry_pt;
	adslAtucPhysEntry * adslAtucPhysEntry_pt;
	adslAturPhysEntry * adslAturPhysEntry_pt;
	adslAtucChanInfo * adslAtucChanInfo_pt;
	adslAturChanInfo * adslAturChanInfo_pt;
	atucPerfDataEntry * atucPerfDataEntry_pt;
	aturPerfDataEntry * aturPerfDataEntry_pt;
	adslAtucIntvlInfo * adslAtucIntvlInfo_pt;
	adslAturIntvlInfo * adslAturIntvlInfo_pt;
	atucChannelPerfDataEntry * atucChannelPerfDataEntry_pt;
	aturChannelPerfDataEntry * aturChannelPerfDataEntry_pt;
	adslAtucChanIntvlInfo * adslAtucChanIntvlInfo_pt;
	adslAturChanIntvlInfo * adslAturChanIntvlInfo_pt;
	adslLineAlarmConfProfileEntry * adslLineAlarmConfProfileEntry_pt;
	// RFC 3440
	
    #ifdef AMAZON_MEI_MIB_RFC3440
	adslLineExtTableEntry * adslLineExtTableEntry_pt;
	atucPerfDataExtEntry * atucPerfDataExtEntry_pt;
	adslAtucInvtlExtInfo * adslAtucInvtlExtInfo_pt;
	aturPerfDataExtEntry * aturPerfDataExtEntry_pt;
	adslAturInvtlExtInfo * adslAturInvtlExtInfo_pt;
	adslLineAlarmConfProfileExtEntry * adslLineAlarmConfProfileExtEntry_pt;
    #endif 
// 603221:tc.chen start
    	adslLineStatusInfo	* adslLineStatusInfo_pt;
    	adslLineRateInfo	* adslLineRateInfo_pt;
    	adslLineInfo		* adslLineInfo_pt;
    	adslNearEndPerfStats	* adslNearEndPerfStats_pt;
    	adslFarEndPerfStats	* adslFarEndPerfStats_pt;
// 603221:tc.chen end
	adslATUCSubcarrierInfo  * adslATUCSubcarrierInfo_pt;
	adslATURSubcarrierInfo  * adslATURSubcarrierInfo_pt;
	adslPowerSpectralDensity * adslPowerSpectralDensity_pt;
}structpts;

#endif /* ] __AMAZON_MEI_APP_IOCTL_H */