My Marlin configs for Fabrikator Mini and CTC i3 Pro B
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.

HAL_Due.h 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /**
  2. * Marlin 3D Printer Firmware
  3. *
  4. * Copyright (C) 2016 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  5. * Copyright (c) 2016 Bob Cousins bobcousins42@googlemail.com
  6. * Copyright (c) 2015-2016 Nico Tonnhofer wurstnase.reprap@gmail.com
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. /**
  23. * Description: HAL for Arduino Due and compatible (SAM3X8E)
  24. *
  25. * For ARDUINO_ARCH_SAM
  26. */
  27. #ifndef _HAL_DUE_H
  28. #define _HAL_DUE_H
  29. #include <stdint.h>
  30. #include "Arduino.h"
  31. #include "fastio_Due.h"
  32. #include "watchdog_Due.h"
  33. #include "HAL_timers_Due.h"
  34. //
  35. // Defines
  36. //
  37. #if SERIAL_PORT == -1
  38. #define MYSERIAL SerialUSB
  39. #elif SERIAL_PORT == 0
  40. #define MYSERIAL customizedSerial
  41. #elif SERIAL_PORT == 1
  42. #define MYSERIAL customizedSerial
  43. #elif SERIAL_PORT == 2
  44. #define MYSERIAL customizedSerial
  45. #elif SERIAL_PORT == 3
  46. #define MYSERIAL customizedSerial
  47. #endif
  48. #define _BV(bit) (1 << (bit))
  49. // We need the previous define before the include, or compilation bombs...
  50. #include "MarlinSerial_Due.h"
  51. #ifndef analogInputToDigitalPin
  52. #define analogInputToDigitalPin(p) ((p < 12u) ? (p) + 54u : -1)
  53. #endif
  54. #define CRITICAL_SECTION_START uint32_t primask = __get_PRIMASK(); __disable_irq();
  55. #define CRITICAL_SECTION_END if (!primask) __enable_irq();
  56. // On AVR this is in math.h?
  57. #define square(x) ((x)*(x))
  58. #ifndef strncpy_P
  59. #define strncpy_P(dest, src, num) strncpy((dest), (src), (num))
  60. #endif
  61. #ifndef vsnprintf_P
  62. #define vsnprintf_P vsnprintf
  63. #endif
  64. // Fix bug in pgm_read_ptr
  65. #undef pgm_read_ptr
  66. #define pgm_read_ptr(addr) (*((void**)(addr)))
  67. #undef pgm_read_word
  68. #define pgm_read_word(addr) (*((uint16_t*)(addr)))
  69. #define RST_POWER_ON 1
  70. #define RST_EXTERNAL 2
  71. #define RST_BROWN_OUT 4
  72. #define RST_WATCHDOG 8
  73. #define RST_JTAG 16
  74. #define RST_SOFTWARE 32
  75. #define RST_BACKUP 64
  76. // --------------------------------------------------------------------------
  77. // Types
  78. // --------------------------------------------------------------------------
  79. typedef int8_t pin_t;
  80. // --------------------------------------------------------------------------
  81. // Public Variables
  82. // --------------------------------------------------------------------------
  83. extern uint16_t HAL_adc_result; // result of last ADC conversion
  84. void cli(void); // Disable interrupts
  85. void sei(void); // Enable interrupts
  86. void HAL_clear_reset_source(void); // clear reset reason
  87. uint8_t HAL_get_reset_source(void); // get reset reason
  88. void _delay_ms(const int delay);
  89. int freeMemory(void);
  90. /**
  91. * SPI: Extended functions taking a channel number (hardware SPI only)
  92. */
  93. // Write single byte to specified SPI channel
  94. void spiSend(uint32_t chan, byte b);
  95. // Write buffer to specified SPI channel
  96. void spiSend(uint32_t chan, const uint8_t* buf, size_t n);
  97. // Read single byte from specified SPI channel
  98. uint8_t spiRec(uint32_t chan);
  99. /**
  100. * EEPROM
  101. */
  102. void eeprom_write_byte(unsigned char *pos, unsigned char value);
  103. unsigned char eeprom_read_byte(unsigned char *pos);
  104. void eeprom_read_block (void *__dst, const void *__src, size_t __n);
  105. void eeprom_update_block (const void *__src, void *__dst, size_t __n);
  106. /**
  107. * ADC
  108. */
  109. #define HAL_ANALOG_SELECT(pin)
  110. inline void HAL_adc_init(void) {}//todo
  111. #define HAL_START_ADC(pin) HAL_adc_start_conversion(pin)
  112. #define HAL_READ_ADC HAL_adc_result
  113. void HAL_adc_start_conversion(const uint8_t adc_pin);
  114. uint16_t HAL_adc_get_result(void);
  115. uint16_t HAL_getAdcReading(uint8_t chan);
  116. void HAL_startAdcConversion(uint8_t chan);
  117. uint8_t HAL_pinToAdcChannel(int pin);
  118. uint16_t HAL_getAdcFreerun(uint8_t chan, bool wait_for_conversion = false);
  119. //uint16_t HAL_getAdcSuperSample(uint8_t chan);
  120. void HAL_enable_AdcFreerun(void);
  121. //void HAL_disable_AdcFreerun(uint8_t chan);
  122. #define GET_PIN_MAP_PIN(index) index
  123. #define GET_PIN_MAP_INDEX(pin) pin
  124. #define PARSED_PIN_INDEX(code, dval) parser.intval(code, dval)
  125. #endif // _HAL_DUE_H