i2c.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #ifndef I2C_H
  2. #define I2C_H
  3. #include <stdint.h>
  4. #ifndef F_CPU
  5. #define F_CPU 16000000UL
  6. #endif
  7. #define I2C_READ 1
  8. #define I2C_WRITE 0
  9. #define I2C_ACK 1
  10. #define I2C_NACK 0
  11. // Address location defines (Keymap should be last, as it's size is dynamic)
  12. #define I2C_BACKLIT_START 0x00
  13. // Need 4 bytes for RGB (32 bit)
  14. #define I2C_RGB_START 0x01
  15. #define I2C_KEYMAP_START 0x06
  16. // Slave buffer (8bit per)
  17. // Rows per hand + backlit space + rgb space
  18. // TODO : Make this dynamically sized
  19. #define SLAVE_BUFFER_SIZE 0x20
  20. // i2c SCL clock frequency
  21. #define SCL_CLOCK 400000L
  22. // Support 8bits right now (8 cols) will need to edit to take higher (code exists in delta split?)
  23. extern volatile uint8_t i2c_slave_buffer[SLAVE_BUFFER_SIZE];
  24. void i2c_master_init(void);
  25. uint8_t i2c_master_start(uint8_t address);
  26. void i2c_master_stop(void);
  27. uint8_t i2c_master_write(uint8_t data);
  28. uint8_t i2c_master_write_data(void *const TXdata, uint8_t dataLen);
  29. uint8_t i2c_master_read(int);
  30. void i2c_reset_state(void);
  31. void i2c_slave_init(uint8_t address);
  32. static inline unsigned char i2c_start_read(unsigned char addr) {
  33. return i2c_master_start((addr << 1) | I2C_READ);
  34. }
  35. static inline unsigned char i2c_start_write(unsigned char addr) {
  36. return i2c_master_start((addr << 1) | I2C_WRITE);
  37. }
  38. // from SSD1306 scrips
  39. extern unsigned char i2c_rep_start(unsigned char addr);
  40. extern void i2c_start_wait(unsigned char addr);
  41. extern unsigned char i2c_readAck(void);
  42. extern unsigned char i2c_readNak(void);
  43. extern unsigned char i2c_read(unsigned char ack);
  44. #define i2c_read(ack) (ack) ? i2c_readAck() : i2c_readNak();
  45. #endif