1 /*
2  * Copyright (C) 2014 Satoshi Noguchi
3  * Copyright (C) 2014 Synaptics Inc
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 #ifndef _F54TEST_H_
19 #define _F54TEST_H_
20 
21 #include "rmidevice.h"
22 
23 #define COMMAND_TIMEOUT_100MS 20
24 
25 #define COMMAND_GET_REPORT 1
26 #define COMMAND_FORCE_CAL 2
27 #define COMMAND_FORCE_UPDATE 4
28 
29 #define REPORT_INDEX_OFFSET 1
30 #define REPORT_DATA_OFFSET 3
31 
32 #define SENSOR_RX_MAPPING_OFFSET 1
33 #define SENSOR_TX_MAPPING_OFFSET 2
34 
35 #define CONTROL_0_SIZE 1
36 #define CONTROL_1_SIZE 1
37 #define CONTROL_2_SIZE 2
38 #define CONTROL_3_SIZE 1
39 #define CONTROL_4_6_SIZE 3
40 #define CONTROL_7_SIZE 1
41 #define CONTROL_8_9_SIZE 3
42 #define CONTROL_10_SIZE 1
43 #define CONTROL_11_SIZE 2
44 #define CONTROL_12_13_SIZE 2
45 #define CONTROL_14_SIZE 1
46 #define CONTROL_15_SIZE 1
47 #define CONTROL_16_SIZE 1
48 #define CONTROL_17_SIZE 1
49 #define CONTROL_18_SIZE 1
50 #define CONTROL_19_SIZE 1
51 #define CONTROL_20_SIZE 1
52 #define CONTROL_21_SIZE 2
53 #define CONTROL_22_26_SIZE 7
54 #define CONTROL_27_SIZE 1
55 #define CONTROL_28_SIZE 2
56 #define CONTROL_29_SIZE 1
57 #define CONTROL_30_SIZE 1
58 #define CONTROL_31_SIZE 1
59 #define CONTROL_32_35_SIZE 8
60 #define CONTROL_36_SIZE 1
61 #define CONTROL_37_SIZE 1
62 #define CONTROL_38_SIZE 1
63 #define CONTROL_39_SIZE 1
64 #define CONTROL_40_SIZE 1
65 #define CONTROL_41_SIZE 1
66 #define CONTROL_42_SIZE 2
67 #define CONTROL_43_54_SIZE 13
68 #define CONTROL_55_56_SIZE 2
69 #define CONTROL_57_SIZE 1
70 #define CONTROL_58_SIZE 1
71 #define CONTROL_59_SIZE 2
72 #define CONTROL_60_62_SIZE 3
73 #define CONTROL_63_SIZE 1
74 #define CONTROL_64_67_SIZE 4
75 #define CONTROL_68_73_SIZE 8
76 #define CONTROL_74_SIZE 2
77 #define CONTROL_75_SIZE 1
78 #define CONTROL_76_SIZE 1
79 #define CONTROL_77_78_SIZE 2
80 #define CONTROL_79_83_SIZE 5
81 #define CONTROL_84_85_SIZE 2
82 #define CONTROL_86_SIZE 1
83 #define CONTROL_87_SIZE 1
84 #define CONTROL_88_SIZE 1
85 #define CONTROL_89_SIZE 1
86 #define CONTROL_90_SIZE 1
87 #define CONTROL_91_SIZE 1
88 #define CONTROL_92_SIZE 1
89 #define CONTROL_93_SIZE 1
90 #define CONTROL_94_SIZE 1
91 #define CONTROL_95_SIZE 1
92 #define CONTROL_96_SIZE 1
93 #define CONTROL_97_SIZE 1
94 #define CONTROL_98_SIZE 1
95 #define CONTROL_99_SIZE 1
96 #define CONTROL_100_SIZE 1
97 #define CONTROL_101_SIZE 1
98 #define CONTROL_102_SIZE 1
99 #define CONTROL_103_SIZE 1
100 #define CONTROL_104_SIZE 1
101 #define CONTROL_105_SIZE 1
102 #define CONTROL_106_SIZE 1
103 #define CONTROL_107_SIZE 1
104 #define CONTROL_108_SIZE 1
105 #define CONTROL_109_SIZE 1
106 #define CONTROL_110_SIZE 1
107 #define CONTROL_111_SIZE 1
108 #define CONTROL_112_SIZE 1
109 #define CONTROL_113_SIZE 1
110 #define CONTROL_114_SIZE 1
111 #define CONTROL_115_SIZE 1
112 #define CONTROL_116_SIZE 1
113 #define CONTROL_117_SIZE 1
114 #define CONTROL_118_SIZE 1
115 #define CONTROL_119_SIZE 1
116 #define CONTROL_120_SIZE 1
117 #define CONTROL_121_SIZE 1
118 #define CONTROL_122_SIZE 1
119 #define CONTROL_123_SIZE 1
120 #define CONTROL_124_SIZE 1
121 #define CONTROL_125_SIZE 1
122 #define CONTROL_126_SIZE 1
123 #define CONTROL_127_SIZE 1
124 #define CONTROL_128_SIZE 1
125 #define CONTROL_129_SIZE 1
126 #define CONTROL_130_SIZE 1
127 #define CONTROL_131_SIZE 1
128 #define CONTROL_132_SIZE 1
129 #define CONTROL_133_SIZE 1
130 #define CONTROL_134_SIZE 1
131 #define CONTROL_135_SIZE 1
132 #define CONTROL_136_SIZE 1
133 #define CONTROL_137_SIZE 1
134 #define CONTROL_138_SIZE 1
135 #define CONTROL_139_SIZE 1
136 #define CONTROL_140_SIZE 1
137 #define CONTROL_141_SIZE 1
138 #define CONTROL_142_SIZE 1
139 #define CONTROL_143_SIZE 1
140 #define CONTROL_144_SIZE 1
141 #define CONTROL_145_SIZE 1
142 #define CONTROL_146_SIZE 1
143 #define CONTROL_147_SIZE 1
144 #define CONTROL_148_SIZE 1
145 #define CONTROL_149_SIZE 1
146 
147 #define HIGH_RESISTANCE_DATA_SIZE 6
148 #define FULL_RAW_CAP_MIN_MAX_DATA_SIZE 4
149 #define TRX_OPEN_SHORT_DATA_SIZE 7
150 
151 enum f54_report_types {
152 	F54_8BIT_IMAGE = 1,
153 	F54_16BIT_IMAGE = 2,
154 	F54_RAW_16BIT_IMAGE = 3,
155 	F54_HIGH_RESISTANCE = 4,
156 	F54_TX_TO_TX_SHORTS = 5,
157 	F54_RX_TO_RX_SHORTS_1 = 7,
158 	F54_TRUE_BASELINE = 9,
159 	F54_FULL_RAW_CAP_MIN_MAX = 13,
160 	F54_RX_OPENS_1 = 14,
161 	F54_TX_OPENS = 15,
162 	F54_TX_TO_GND_SHORTS = 16,
163 	F54_RX_TO_RX_SHORTS_2 = 17,
164 	F54_RX_OPENS_2 = 18,
165 	F54_FULL_RAW_CAP = 19,
166 	F54_FULL_RAW_CAP_NO_RX_COUPLING = 20,
167 	F54_SENSOR_SPEED = 22,
168 	F54_ADC_RANGE = 23,
169 	F54_TRX_OPENS = 24,
170 	F54_TRX_TO_GND_SHORTS = 25,
171 	F54_TRX_SHORTS = 26,
172 	F54_ABS_RAW_CAP = 38,
173 	F54_ABS_DELTA_CAP = 40,
174 	INVALID_REPORT_TYPE = -1,
175 };
176 
177 struct f54_query {
178 	union {
179 		struct {
180 			/* query 0 */
181 			unsigned char num_of_rx_electrodes;
182 
183 			/* query 1 */
184 			unsigned char num_of_tx_electrodes;
185 
186 			/* query 2 */
187 			unsigned char f54_query2_b0__1:2;
188 			unsigned char has_baseline:1;
189 			unsigned char has_image8:1;
190 			unsigned char f54_query2_b4__5:2;
191 			unsigned char has_image16:1;
192 			unsigned char f54_query2_b7:1;
193 
194 			/* queries 3.0 and 3.1 */
195 			unsigned short clock_rate;
196 
197 			/* query 4 */
198 			unsigned char touch_controller_family;
199 
200 			/* query 5 */
201 			unsigned char has_pixel_touch_threshold_adjustment:1;
202 			unsigned char f54_query5_b1__7:7;
203 
204 			/* query 6 */
205 			unsigned char has_sensor_assignment:1;
206 			unsigned char has_interference_metric:1;
207 			unsigned char has_sense_frequency_control:1;
208 			unsigned char has_firmware_noise_mitigation:1;
209 			unsigned char has_ctrl11:1;
210 			unsigned char has_two_byte_report_rate:1;
211 			unsigned char has_one_byte_report_rate:1;
212 			unsigned char has_relaxation_control:1;
213 
214 			/* query 7 */
215 			unsigned char curve_compensation_mode:2;
216 			unsigned char f54_query7_b2__7:6;
217 
218 			/* query 8 */
219 			unsigned char f54_query8_b0:1;
220 			unsigned char has_iir_filter:1;
221 			unsigned char has_cmn_removal:1;
222 			unsigned char has_cmn_maximum:1;
223 			unsigned char has_touch_hysteresis:1;
224 			unsigned char has_edge_compensation:1;
225 			unsigned char has_per_frequency_noise_control:1;
226 			unsigned char has_enhanced_stretch:1;
227 
228 			/* query 9 */
229 			unsigned char has_force_fast_relaxation:1;
230 			unsigned char has_multi_metric_state_machine:1;
231 			unsigned char has_signal_clarity:1;
232 			unsigned char has_variance_metric:1;
233 			unsigned char has_0d_relaxation_control:1;
234 			unsigned char has_0d_acquisition_control:1;
235 			unsigned char has_status:1;
236 			unsigned char has_slew_metric:1;
237 
238 			/* query 10 */
239 			unsigned char has_h_blank:1;
240 			unsigned char has_v_blank:1;
241 			unsigned char has_long_h_blank:1;
242 			unsigned char has_startup_fast_relaxation:1;
243 			unsigned char has_esd_control:1;
244 			unsigned char has_noise_mitigation2:1;
245 			unsigned char has_noise_state:1;
246 			unsigned char has_energy_ratio_relaxation:1;
247 
248 			/* query 11 */
249 			unsigned char has_excessive_noise_reporting:1;
250 			unsigned char has_slew_option:1;
251 			unsigned char has_two_overhead_bursts:1;
252 			unsigned char has_query13:1;
253 			unsigned char has_one_overhead_burst:1;
254 			unsigned char f54_query11_b5:1;
255 			unsigned char has_ctrl88:1;
256 			unsigned char has_query15:1;
257 
258 			/* query 12 */
259 			unsigned char number_of_sensing_frequencies:4;
260 			unsigned char f54_query12_b4__7:4;
261 		} __attribute__((packed));
262 		unsigned char data[14];
263 	};
264 };
265 
266 struct f54_query_13 {
267 	union {
268 		struct {
269 			unsigned char has_ctrl86:1;
270 			unsigned char has_ctrl87:1;
271 			unsigned char has_ctrl87_sub0:1;
272 			unsigned char has_ctrl87_sub1:1;
273 			unsigned char has_ctrl87_sub2:1;
274 			unsigned char has_cidim:1;
275 			unsigned char has_noise_mitigation_enhancement:1;
276 			unsigned char has_rail_im:1;
277 		} __attribute__((packed));
278 		unsigned char data[1];
279 	};
280 };
281 
282 struct f54_query_15 {
283 	union {
284 		struct {
285 			unsigned char has_ctrl90:1;
286 			unsigned char has_transmit_strength:1;
287 			unsigned char has_ctrl87_sub3:1;
288 			unsigned char has_query16:1;
289 			unsigned char has_query20:1;
290 			unsigned char has_query21:1;
291 			unsigned char has_query22:1;
292 			unsigned char has_query25:1;
293 		} __attribute__((packed));
294 		unsigned char data[1];
295 	};
296 };
297 
298 struct f54_query_16 {
299 	union {
300 		struct {
301 			unsigned char has_query17:1;
302 			unsigned char has_data17:1;
303 			unsigned char has_ctrl92:1;
304 			unsigned char has_ctrl93:1;
305 			unsigned char has_ctrl94_query18:1;
306 			unsigned char has_ctrl95_query19:1;
307 			unsigned char has_ctrl99:1;
308 			unsigned char has_ctrl100:1;
309 		} __attribute__((packed));
310 		unsigned char data[1];
311 	};
312 };
313 
314 struct f54_query_21 {
315 	union {
316 		struct {
317 			unsigned char has_abs_rx:1;
318 			unsigned char has_abs_tx:1;
319 			unsigned char has_ctrl91:1;
320 			unsigned char has_ctrl96:1;
321 			unsigned char has_ctrl97:1;
322 			unsigned char has_ctrl98:1;
323 			unsigned char has_data19:1;
324 			unsigned char has_query24_data18:1;
325 		} __attribute__((packed));
326 		unsigned char data[1];
327 	};
328 };
329 
330 struct f54_query_22 {
331 	union {
332 		struct {
333 			unsigned char has_packed_image:1;
334 			unsigned char has_ctrl101:1;
335 			unsigned char has_dynamic_sense_display_ratio:1;
336 			unsigned char has_query23:1;
337 			unsigned char has_ctrl103_query26:1;
338 			unsigned char has_ctrl104:1;
339 			unsigned char has_ctrl105:1;
340 			unsigned char has_query28:1;
341 		} __attribute__((packed));
342 		unsigned char data[1];
343 	};
344 };
345 
346 struct f54_query_23 {
347 	union {
348 		struct {
349 			unsigned char has_ctrl102:1;
350 			unsigned char has_ctrl102_sub1:1;
351 			unsigned char has_ctrl102_sub2:1;
352 			unsigned char has_ctrl102_sub4:1;
353 			unsigned char has_ctrl102_sub5:1;
354 			unsigned char has_ctrl102_sub9:1;
355 			unsigned char has_ctrl102_sub10:1;
356 			unsigned char has_ctrl102_sub11:1;
357 		} __attribute__((packed));
358 		unsigned char data[1];
359 	};
360 };
361 
362 struct f54_query_25 {
363 	union {
364 		struct {
365 			unsigned char has_ctrl106:1;
366 			unsigned char has_ctrl102_sub12:1;
367 			unsigned char has_ctrl107:1;
368 			unsigned char has_ctrl108:1;
369 			unsigned char has_ctrl109:1;
370 			unsigned char has_data20:1;
371 			unsigned char f54_query25_b6:1;
372 			unsigned char has_query27:1;
373 		} __attribute__((packed));
374 		unsigned char data[1];
375 	};
376 };
377 
378 struct f54_query_27 {
379 	union {
380 		struct {
381 			unsigned char has_ctrl110:1;
382 			unsigned char has_data21:1;
383 			unsigned char has_ctrl111:1;
384 			unsigned char has_ctrl112:1;
385 			unsigned char has_ctrl113:1;
386 			unsigned char has_data22:1;
387 			unsigned char has_ctrl114:1;
388 			unsigned char has_query29:1;
389 		} __attribute__((packed));
390 		unsigned char data[1];
391 	};
392 };
393 
394 struct f54_query_29 {
395 	union {
396 		struct {
397 			unsigned char has_ctrl115:1;
398 			unsigned char has_ground_ring_options:1;
399 			unsigned char has_lost_bursts_tuning:1;
400 			unsigned char has_aux_exvcom2_select:1;
401 			unsigned char has_ctrl116:1;
402 			unsigned char has_data23:1;
403 			unsigned char has_ctrl117:1;
404 			unsigned char has_query30:1;
405 		} __attribute__((packed));
406 		unsigned char data[1];
407 	};
408 };
409 
410 struct f54_query_30 {
411 	union {
412 		struct {
413 			unsigned char has_ctrl118:1;
414 			unsigned char has_ctrl119:1;
415 			unsigned char has_ctrl120:1;
416 			unsigned char has_ctrl121:1;
417 			unsigned char has_ctrl122_query31:1;
418 			unsigned char has_ctrl123:1;
419 			unsigned char f54_query30_b6:1;
420 			unsigned char has_query32:1;
421 		} __attribute__((packed));
422 		unsigned char data[1];
423 	};
424 };
425 
426 struct f54_query_32 {
427 	union {
428 		struct {
429 			unsigned char has_ctrl125:1;
430 			unsigned char has_ctrl126:1;
431 			unsigned char has_ctrl127:1;
432 			unsigned char has_abs_charge_pump_disable:1;
433 			unsigned char has_query33:1;
434 			unsigned char has_data24:1;
435 			unsigned char has_query34:1;
436 			unsigned char has_query35:1;
437 		} __attribute__((packed));
438 		unsigned char data[1];
439 	};
440 };
441 
442 struct f54_query_33 {
443 	union {
444 		struct {
445 			unsigned char f54_query33_b0:1;
446 			unsigned char f54_query33_b1:1;
447 			unsigned char f54_query33_b2:1;
448 			unsigned char f54_query33_b3:1;
449 			unsigned char has_ctrl132:1;
450 			unsigned char has_ctrl133:1;
451 			unsigned char has_ctrl134:1;
452 			unsigned char has_query36:1;
453 		} __attribute__((packed));
454 		unsigned char data[1];
455 	};
456 };
457 
458 struct f54_query_35 {
459 	union {
460 		struct {
461 			unsigned char has_data25:1;
462 			unsigned char f54_query35_b1:1;
463 			unsigned char f54_query35_b2:1;
464 			unsigned char has_ctrl137:1;
465 			unsigned char has_ctrl138:1;
466 			unsigned char has_ctrl139:1;
467 			unsigned char has_data26:1;
468 			unsigned char has_ctrl140:1;
469 		} __attribute__((packed));
470 		unsigned char data[1];
471 	};
472 };
473 
474 struct f54_query_36 {
475 	union {
476 		struct {
477 			unsigned char f54_query36_b0:1;
478 			unsigned char has_ctrl142:1;
479 			unsigned char has_query37:1;
480 			unsigned char has_ctrl143:1;
481 			unsigned char has_ctrl144:1;
482 			unsigned char has_ctrl145:1;
483 			unsigned char has_ctrl146:1;
484 			unsigned char has_query38:1;
485 		} __attribute__((packed));
486 		unsigned char data[1];
487 	};
488 };
489 
490 struct f54_query_38 {
491 	union {
492 		struct {
493 			unsigned char has_ctrl147:1;
494 			unsigned char has_ctrl148:1;
495 			unsigned char has_ctrl149:1;
496 			unsigned char f54_query38_b3:1;
497 			unsigned char f54_query38_b4:1;
498 			unsigned char f54_query38_b5:1;
499 			unsigned char f54_query38_b6:1;
500 			unsigned char f54_query38_b7:1;
501 		} __attribute__((packed));
502 		unsigned char data[1];
503 	};
504 };
505 
506 struct f54_control_7 {
507 	union {
508 		struct {
509 			unsigned char cbc_cap:3;
510 			unsigned char cbc_polarity:1;
511 			unsigned char cbc_tx_carrier_selection:1;
512 			unsigned char f54_ctrl7_b5__7:3;
513 		} __attribute__((packed));
514 		struct {
515 			unsigned char data[1];
516 			unsigned short address;
517 		} __attribute__((packed));
518 	};
519 };
520 
521 struct f54_control_41 {
522 	union {
523 		struct {
524 			unsigned char no_signal_clarity:1;
525 			unsigned char f54_ctrl41_b1__7:7;
526 		} __attribute__((packed));
527 		struct {
528 			unsigned char data[1];
529 			unsigned short address;
530 		} __attribute__((packed));
531 	};
532 };
533 
534 struct f54_control_57 {
535 	union {
536 		struct {
537 			unsigned char cbc_cap:3;
538 			unsigned char cbc_polarity:1;
539 			unsigned char cbc_tx_carrier_selection:1;
540 			unsigned char f54_ctrl57_b5__7:3;
541 		} __attribute__((packed));
542 		struct {
543 			unsigned char data[1];
544 			unsigned short address;
545 		} __attribute__((packed));
546 	};
547 };
548 
549 struct f54_control_88 {
550 	union {
551 		struct {
552 			unsigned char tx_low_reference_polarity:1;
553 			unsigned char tx_high_reference_polarity:1;
554 			unsigned char abs_low_reference_polarity:1;
555 			unsigned char abs_polarity:1;
556 			unsigned char cbc_polarity:1;
557 			unsigned char cbc_tx_carrier_selection:1;
558 			unsigned char charge_pump_enable:1;
559 			unsigned char cbc_abs_auto_servo:1;
560 		} __attribute__((packed));
561 		struct {
562 			unsigned char data[1];
563 			unsigned short address;
564 		} __attribute__((packed));
565 	};
566 };
567 
568 struct f54_control_110 {
569 	union {
570 		struct {
571 			unsigned char active_stylus_rx_feedback_cap;
572 			unsigned char active_stylus_rx_feedback_cap_reference;
573 			unsigned char active_stylus_low_reference;
574 			unsigned char active_stylus_high_reference;
575 			unsigned char active_stylus_gain_control;
576 			unsigned char active_stylus_gain_control_reference;
577 			unsigned char active_stylus_timing_mode;
578 			unsigned char active_stylus_discovery_bursts;
579 			unsigned char active_stylus_detection_bursts;
580 			unsigned char active_stylus_discovery_noise_multiplier;
581 			unsigned char active_stylus_detection_envelope_min;
582 			unsigned char active_stylus_detection_envelope_max;
583 			unsigned char active_stylus_lose_count;
584 		} __attribute__((packed));
585 		struct {
586 			unsigned char data[13];
587 			unsigned short address;
588 		} __attribute__((packed));
589 	};
590 };
591 
592 struct f54_control_149 {
593 	union {
594 		struct {
595 			unsigned char trans_cbc_global_cap_enable:1;
596 			unsigned char f54_ctrl49_b1__7:7;
597 		} __attribute__((packed));
598 		struct {
599 			unsigned char data[1];
600 			unsigned short address;
601 		} __attribute__((packed));
602 	};
603 };
604 
605 struct f54_control {
606 	struct f54_control_7 reg_7;
607 	struct f54_control_41 reg_41;
608 	struct f54_control_57 reg_57;
609 	struct f54_control_88 reg_88;
610 	struct f54_control_110 reg_110;
611 	struct f54_control_149 reg_149;
612 };
613 
614 struct f55_query {
615 	union {
616 		struct {
617 			/* query 0 */
618 			unsigned char num_of_rx_electrodes;
619 
620 			/* query 1 */
621 			unsigned char num_of_tx_electrodes;
622 
623 			/* query 2 */
624 			unsigned char has_sensor_assignment:1;
625 			unsigned char has_edge_compensation:1;
626 			unsigned char curve_compensation_mode:2;
627 			unsigned char has_ctrl6:1;
628 			unsigned char has_alternate_transmitter_assignment:1;
629 			unsigned char has_single_layer_multi_touch:1;
630 			unsigned char has_query5:1;
631 		}  __attribute__((packed));
632 		unsigned char data[3];
633 	};
634 };
635 
636 class Display;
637 
638 class F54Test
639 {
640 public:
641 		F54Test(RMIDevice & device, Display & display)
642 		: m_device(device),
643 		m_reportType(INVALID_REPORT_TYPE),
644 		m_txAssignment(NULL),
645 		m_rxAssignment(NULL),
646 		m_reportBufferSize(0),
647 		m_reportData(NULL),
648 		m_display(display)
649 	{}
650 	~F54Test();
651 	int Prepare(f54_report_types reportType);
652 	int Run();
653 
654 private:
655 	int FindTestFunctions();
656 	int ReadF54Queries();
657 	int ReadF55Queries();
658 	int SetupF54Controls();
659 	int SetF54ReportType(f54_report_types report_type);
660 	int SetF54ReportSize(f54_report_types report_type);
661 	int SetF54Interrupt();
662 	int DoF54Command(unsigned char command);
663 	int WaitForF54CommandCompletion();
664 	int ReadF54Report();
665 	int ShowF54Report();
666 
667 private:
668 	RMIDevice & m_device;
669 
670 	RMIFunction m_f01;
671 	RMIFunction m_f54;
672 	RMIFunction m_f55;
673 
674 	f54_query m_f54Query;
675 	f54_query_13 m_f54Query_13;
676 	f54_query_15 m_f54Query_15;
677 	f54_query_16 m_f54Query_16;
678 	f54_query_21 m_f54Query_21;
679 	f54_query_22 m_f54Query_22;
680 	f54_query_23 m_f54Query_23;
681 	f54_query_25 m_f54Query_25;
682 	f54_query_27 m_f54Query_27;
683 	f54_query_29 m_f54Query_29;
684 	f54_query_30 m_f54Query_30;
685 	f54_query_32 m_f54Query_32;
686 	f54_query_33 m_f54Query_33;
687 	f54_query_35 m_f54Query_35;
688 	f54_query_36 m_f54Query_36;
689 	f54_query_38 m_f54Query_38;
690 
691 	f54_control m_f54Control;
692 
693 	f55_query m_f55Query;
694 
695 	f54_report_types m_reportType;
696 	unsigned int m_reportSize;
697 
698 	unsigned char *m_txAssignment;
699 	unsigned char *m_rxAssignment;
700 	unsigned char m_txAssigned;
701 	unsigned char m_rxAssigned;
702 
703 	unsigned int m_reportBufferSize;
704 	unsigned char *m_reportData;
705 
706 	Display & m_display;
707 };
708 
709 #endif // _F54TEST_H_
710