fsensor.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. //! @file
  2. #ifndef FSENSOR_H
  3. #define FSENSOR_H
  4. #include <inttypes.h>
  5. #include "config.h"
  6. // enable/disable flag
  7. extern bool fsensor_enabled;
  8. // not responding flag
  9. extern bool fsensor_not_responding;
  10. #ifdef PAT9125
  11. // optical checking "chunk lenght" (already in steps)
  12. extern int16_t fsensor_chunk_len;
  13. // count of soft failures
  14. extern uint8_t fsensor_softfail;
  15. #endif
  16. //! @name save restore printing
  17. //! @{
  18. extern void fsensor_stop_and_save_print(void);
  19. //! restore print - restore position and heatup to original temperature
  20. extern void fsensor_restore_print_and_continue(void);
  21. //! split the current gcode stream to insert new instructions
  22. extern void fsensor_checkpoint_print(void);
  23. //! @}
  24. //! initialize
  25. extern void fsensor_init(void);
  26. #ifdef PAT9125
  27. //! update axis resolution
  28. extern void fsensor_set_axis_steps_per_unit(float u);
  29. #endif
  30. //! @name enable/disable
  31. //! @{
  32. extern bool fsensor_enable(bool bUpdateEEPROM=true);
  33. extern void fsensor_disable(bool bUpdateEEPROM=true);
  34. //! @}
  35. //autoload feature enabled
  36. extern bool fsensor_autoload_enabled;
  37. extern void fsensor_autoload_set(bool State);
  38. #ifdef PAT9125
  39. //! setup pin-change interrupt
  40. extern void fsensor_setup_interrupt(void);
  41. //! @name autoload support
  42. //! @{
  43. extern void fsensor_autoload_check_start(void);
  44. extern void fsensor_autoload_check_stop(void);
  45. #endif //PAT9125
  46. //! @}
  47. #ifdef PAT9125
  48. //! @name callbacks from stepper
  49. //! @{
  50. extern void fsensor_st_block_chunk(int cnt);
  51. // debugging
  52. extern uint8_t fsensor_log;
  53. // There's really nothing to do in block_begin: the stepper ISR likely has
  54. // called us already at the end of the last block, making this integration
  55. // redundant. LA1.5 might not always do that during a coasting move, so attempt
  56. // to drain fsensor_st_cnt anyway at the beginning of the new block.
  57. #define fsensor_st_block_begin(rev) fsensor_st_block_chunk(0)
  58. //! @}
  59. #endif //PAT9125
  60. #define VOLT_DIV_REF 5
  61. #ifdef IR_SENSOR_ANALOG
  62. #define IR_SENSOR_STEADY 10 // [ms]
  63. enum class ClFsensorPCB:uint_least8_t
  64. {
  65. _Old=0,
  66. _Rev04=1,
  67. _Undef=EEPROM_EMPTY_VALUE
  68. };
  69. enum class ClFsensorActionNA:uint_least8_t
  70. {
  71. _Continue=0,
  72. _Pause=1,
  73. _Undef=EEPROM_EMPTY_VALUE
  74. };
  75. extern ClFsensorPCB oFsensorPCB;
  76. extern ClFsensorActionNA oFsensorActionNA;
  77. extern const char* FsensorIRVersionText();
  78. extern bool fsensor_IR_check();
  79. constexpr uint16_t Voltage2Raw(float V){
  80. return ( V * 1023 * OVERSAMPLENR / VOLT_DIV_REF ) + 0.5F;
  81. }
  82. constexpr float Raw2Voltage(uint16_t raw){
  83. return VOLT_DIV_REF*(raw / (1023.F * OVERSAMPLENR) );
  84. }
  85. constexpr uint16_t IRsensor_Ldiode_TRESHOLD = Voltage2Raw(0.3F); // ~0.3V, raw value=982
  86. constexpr uint16_t IRsensor_Lmax_TRESHOLD = Voltage2Raw(1.5F); // ~1.5V (0.3*Vcc), raw value=4910
  87. constexpr uint16_t IRsensor_Hmin_TRESHOLD = Voltage2Raw(3.0F); // ~3.0V (0.6*Vcc), raw value=9821
  88. constexpr uint16_t IRsensor_Hopen_TRESHOLD = Voltage2Raw(4.6F); // ~4.6V (N.C. @ Ru~20-50k, Rd'=56k, Ru'=10k), raw value=15059
  89. constexpr uint16_t IRsensor_VMax_TRESHOLD = Voltage2Raw(5.F); // ~5V, raw value=16368
  90. #endif //IR_SENSOR_ANALOG
  91. #endif //FSENSOR_H