* Fix the SLC_CLOCK setting for the Split Common code Make the SCL_CLOCK setting configurable per board, since some use different settings And change the Iris to use 100000L instead of 400000L * Add SCL_CLOCK variable to documentation * Change SCL_CLOCK default to 100000L
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef I2C_H
 | 
						|
#define I2C_H
 | 
						|
 | 
						|
#include <stdint.h>
 | 
						|
 | 
						|
#ifndef F_CPU
 | 
						|
#define F_CPU 16000000UL
 | 
						|
#endif
 | 
						|
 | 
						|
#define I2C_READ 1
 | 
						|
#define I2C_WRITE 0
 | 
						|
 | 
						|
#define I2C_ACK 1
 | 
						|
#define I2C_NACK 0
 | 
						|
 | 
						|
// Address location defines (Keymap should be last, as it's size is dynamic)
 | 
						|
#define I2C_BACKLIT_START   0x00
 | 
						|
// Need 4 bytes for RGB (32 bit)
 | 
						|
#define I2C_RGB_START       0x01
 | 
						|
#define I2C_KEYMAP_START    0x06
 | 
						|
 | 
						|
// Slave buffer (8bit per)
 | 
						|
// Rows per hand + backlit space + rgb space
 | 
						|
// TODO : Make this dynamically sized
 | 
						|
#define SLAVE_BUFFER_SIZE 0x20
 | 
						|
 | 
						|
// i2c SCL clock frequency
 | 
						|
#ifndef SCL_CLOCK
 | 
						|
#define SCL_CLOCK  100000L
 | 
						|
#endif
 | 
						|
 | 
						|
// Support 8bits right now (8 cols) will need to edit to take higher (code exists in delta split?)
 | 
						|
extern volatile uint8_t i2c_slave_buffer[SLAVE_BUFFER_SIZE];
 | 
						|
 | 
						|
void i2c_master_init(void);
 | 
						|
uint8_t i2c_master_start(uint8_t address);
 | 
						|
void i2c_master_stop(void);
 | 
						|
uint8_t i2c_master_write(uint8_t data);
 | 
						|
uint8_t i2c_master_write_data(void *const TXdata, uint8_t dataLen);
 | 
						|
uint8_t i2c_master_read(int);
 | 
						|
void i2c_reset_state(void);
 | 
						|
void i2c_slave_init(uint8_t address);
 | 
						|
 | 
						|
 | 
						|
static inline unsigned char i2c_start_read(unsigned char addr) {
 | 
						|
  return i2c_master_start((addr << 1) | I2C_READ);
 | 
						|
}
 | 
						|
 | 
						|
static inline unsigned char i2c_start_write(unsigned char addr) {
 | 
						|
  return i2c_master_start((addr << 1) | I2C_WRITE);
 | 
						|
}
 | 
						|
 | 
						|
// from SSD1306 scrips
 | 
						|
extern unsigned char i2c_rep_start(unsigned char addr);
 | 
						|
extern void i2c_start_wait(unsigned char addr);
 | 
						|
extern unsigned char i2c_readAck(void);
 | 
						|
extern unsigned char i2c_readNak(void);
 | 
						|
extern unsigned char i2c_read(unsigned char ack);
 | 
						|
 | 
						|
#define i2c_read(ack)  (ack) ? i2c_readAck() : i2c_readNak();
 | 
						|
 | 
						|
#endif
 |