You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
1.7 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
  1. #pragma once
  2. #include <fstream>
  3. #include <functional>
  4. #include <iostream>
  5. #include <list>
  6. #include <map>
  7. #include <memory>
  8. #include <mutex>
  9. #include <set>
  10. #include <sstream>
  11. #include <string>
  12. #include <thread>
  13. #include <vector>
  14. #include "protocol/zfpga_commander/zfpga_commander.hpp"
  15. #include "zfpga_basic_protocol/zaf_protocol.h"
  16. #include "zfpga_basic_protocol/zaf_regs.hpp"
  17. //
  18. #include <QtCore/QVariant>
  19. #include <QtWidgets/QApplication>
  20. #include <QtWidgets/QComboBox>
  21. #include <QtWidgets/QGridLayout>
  22. #include <QtWidgets/QLabel>
  23. #include <QtWidgets/QLineEdit>
  24. #include <QtWidgets/QPushButton>
  25. #include <QtWidgets/QSpacerItem>
  26. #include <QtWidgets/QWidget>
  27. //
  28. #define REGADDOFF__FPGA_APP 0x1020
  29. namespace iflytop {
  30. namespace syncbox16chsdk {
  31. using namespace std;
  32. typedef enum {
  33. kWorkMode_extCpyMode,
  34. kWorkMode_extTriMode,
  35. kWorkMode_manualTriMode,
  36. } WorkMode_t;
  37. typedef enum {
  38. kreg_app = REGADDOFF__FPGA_APP,
  39. kreg_workmode = REGADDOFF__FPGA_APP + 1,
  40. kreg_pluse_gen_num = REGADDOFF__FPGA_APP + 2,
  41. kreg_pluse_pluse_width = REGADDOFF__FPGA_APP + 3,
  42. } reg_t;
  43. const char* WorkModeToStr(uint32_t mode);
  44. WorkMode_t WorkModeValueOf(const char* str);
  45. WorkMode_t WorkModeValueOf(QString str);
  46. list<string> WorkModeStrList();
  47. class SyncBox16ChSDK {
  48. unique_ptr<thread> m_thread;
  49. public:
  50. static SyncBox16ChSDK* ins() {
  51. static SyncBox16ChSDK cmder;
  52. return &cmder;
  53. }
  54. public:
  55. void initialize();
  56. void setPluseWidth(uint32_t widthus);
  57. void setPluseFreq(uint32_t freq);
  58. void setPluseGeneratorMode();
  59. ZFPGACommander* getCmder() { return ZFPGACommander::ins(); }
  60. public:
  61. };
  62. } // namespace syncbox16chsdk
  63. } // namespace iflytop