Cleanup user functions
This commit is contained in:
@@ -8,6 +8,5 @@
|
|||||||
#ifndef USER_BSP_PD_H_
|
#ifndef USER_BSP_PD_H_
|
||||||
#define USER_BSP_PD_H_
|
#define USER_BSP_PD_H_
|
||||||
#include "BSP.h"
|
#include "BSP.h"
|
||||||
bool getFUS302IRQLow(); // Return true if the IRQ line is still held low
|
|
||||||
|
|
||||||
#endif /* USER_BSP_PD_H_ */
|
#endif /* USER_BSP_PD_H_ */
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
#include "Pins.h"
|
#include "Pins.h"
|
||||||
#include "QC3.h"
|
#include "QC3.h"
|
||||||
#include "Settings.h"
|
#include "Settings.h"
|
||||||
|
#include "fusb_user.h"
|
||||||
#include "fusbpd.h"
|
#include "fusbpd.h"
|
||||||
#include "int_n.h"
|
#include "int_n.h"
|
||||||
#include "policy_engine.h"
|
#include "policy_engine.h"
|
||||||
|
|||||||
@@ -6,52 +6,12 @@
|
|||||||
#include "Setup.h"
|
#include "Setup.h"
|
||||||
#include "fusb302b.h"
|
#include "fusb302b.h"
|
||||||
#include "fusb_user.h"
|
#include "fusb_user.h"
|
||||||
/*
|
|
||||||
* Read a single byte from the FUSB302B
|
|
||||||
*
|
|
||||||
* cfg: The FUSB302B to communicate with
|
|
||||||
* addr: The memory address from which to read
|
|
||||||
*
|
|
||||||
* Returns the value read from addr.
|
|
||||||
*/
|
|
||||||
uint8_t fusb_read_byte(uint8_t addr) {
|
|
||||||
uint8_t data[1];
|
|
||||||
if (!FRToSI2C::Mem_Read(FUSB302B_ADDR, addr, (uint8_t *)data, 1)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return data[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Read multiple bytes from the FUSB302B
|
|
||||||
*
|
|
||||||
* cfg: The FUSB302B to communicate with
|
|
||||||
* addr: The memory address from which to read
|
|
||||||
* size: The number of bytes to read
|
|
||||||
* buf: The buffer into which data will be read
|
|
||||||
*/
|
|
||||||
bool fusb_read_buf(uint8_t addr, uint8_t size, uint8_t *buf) { return FRToSI2C::Mem_Read(FUSB302B_ADDR, addr, buf, size); }
|
bool fusb_read_buf(uint8_t addr, uint8_t size, uint8_t *buf) { return FRToSI2C::Mem_Read(FUSB302B_ADDR, addr, buf, size); }
|
||||||
|
|
||||||
/*
|
|
||||||
* Write a single byte to the FUSB302B
|
|
||||||
*
|
|
||||||
* cfg: The FUSB302B to communicate with
|
|
||||||
* addr: The memory address to which we will write
|
|
||||||
* byte: The value to write
|
|
||||||
*/
|
|
||||||
bool fusb_write_byte(uint8_t addr, uint8_t byte) { return FRToSI2C::Mem_Write(FUSB302B_ADDR, addr, (uint8_t *)&byte, 1); }
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write multiple bytes to the FUSB302B
|
|
||||||
*
|
|
||||||
* cfg: The FUSB302B to communicate with
|
|
||||||
* addr: The memory address to which we will write
|
|
||||||
* size: The number of bytes to write
|
|
||||||
* buf: The buffer to write
|
|
||||||
*/
|
|
||||||
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return FRToSI2C::Mem_Write(FUSB302B_ADDR, addr, (uint8_t *)buf, size); }
|
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return FRToSI2C::Mem_Write(FUSB302B_ADDR, addr, (uint8_t *)buf, size); }
|
||||||
|
|
||||||
uint8_t fusb302_detect() {
|
bool fusb302_detect() {
|
||||||
// Probe the I2C bus for its address
|
// Probe the I2C bus for its address
|
||||||
return FRToSI2C::probe(FUSB302B_ADDR);
|
return FRToSI2C::probe(FUSB302B_ADDR);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ bool fusb_write_byte(uint8_t addr, uint8_t byte) { return I2CBB::Mem_Write(FUSB3
|
|||||||
*/
|
*/
|
||||||
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return I2CBB::Mem_Write(FUSB302B_ADDR, addr, buf, size); }
|
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return I2CBB::Mem_Write(FUSB302B_ADDR, addr, buf, size); }
|
||||||
|
|
||||||
uint8_t fusb302_detect() {
|
bool fusb302_detect() {
|
||||||
// Probe the I2C bus for its address
|
// Probe the I2C bus for its address
|
||||||
return I2CBB::probe(FUSB302B_ADDR);
|
return I2CBB::probe(FUSB302B_ADDR);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ bool fusb_write_byte(uint8_t addr, uint8_t byte) { return FRToSI2C::Mem_Write(FU
|
|||||||
*/
|
*/
|
||||||
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return FRToSI2C::Mem_Write(FUSB302B_ADDR, addr, (uint8_t *)buf, size); }
|
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf) { return FRToSI2C::Mem_Write(FUSB302B_ADDR, addr, (uint8_t *)buf, size); }
|
||||||
|
|
||||||
uint8_t fusb302_detect() {
|
bool fusb302_detect() {
|
||||||
// Probe the I2C bus for its address
|
// Probe the I2C bus for its address
|
||||||
return FRToSI2C::probe(FUSB302B_ADDR);
|
return FRToSI2C::probe(FUSB302B_ADDR);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,9 @@
|
|||||||
#include "fusb_user.h"
|
#include "fusb_user.h"
|
||||||
#include "int_n.h"
|
#include "int_n.h"
|
||||||
#include <pd.h>
|
#include <pd.h>
|
||||||
void fusb_send_message(const union pd_msg *msg) {
|
uint8_t fusb_read_byte(uint8_t addr);
|
||||||
|
bool fusb_write_byte(uint8_t addr, uint8_t byte);
|
||||||
|
void fusb_send_message(const union pd_msg *msg) {
|
||||||
|
|
||||||
/* Token sequences for the FUSB302B */
|
/* Token sequences for the FUSB302B */
|
||||||
static uint8_t sop_seq[5] = {FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP2, FUSB_FIFO_TX_PACKSYM};
|
static uint8_t sop_seq[5] = {FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP1, FUSB_FIFO_TX_SOP2, FUSB_FIFO_TX_PACKSYM};
|
||||||
@@ -161,3 +163,27 @@ bool fusb_read_id() {
|
|||||||
return false;
|
return false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
* Read a single byte from the FUSB302B
|
||||||
|
*
|
||||||
|
* cfg: The FUSB302B to communicate with
|
||||||
|
* addr: The memory address from which to read
|
||||||
|
*
|
||||||
|
* Returns the value read from addr.
|
||||||
|
*/
|
||||||
|
uint8_t fusb_read_byte(uint8_t addr) {
|
||||||
|
uint8_t data[1];
|
||||||
|
if (!fusb_read_buf(addr, 1, (uint8_t *)data)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return data[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Write a single byte to the FUSB302B
|
||||||
|
*
|
||||||
|
* cfg: The FUSB302B to communicate with
|
||||||
|
* addr: The memory address to which we will write
|
||||||
|
* byte: The value to write
|
||||||
|
*/
|
||||||
|
bool fusb_write_byte(uint8_t addr, uint8_t byte) { return fusb_write_buf(addr, 1, (uint8_t *)&byte); }
|
||||||
|
|||||||
@@ -19,11 +19,29 @@
|
|||||||
#define PDB_FUSB_USER_H
|
#define PDB_FUSB_USER_H
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
uint8_t fusb_read_byte(uint8_t addr);
|
/*
|
||||||
bool fusb_read_buf(uint8_t addr, uint8_t size, uint8_t *buf);
|
* Read multiple bytes from the FUSB302B
|
||||||
bool fusb_write_byte(uint8_t addr, uint8_t byte);
|
*
|
||||||
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf);
|
* cfg: The FUSB302B to communicate with
|
||||||
uint8_t fusb302_detect();
|
* addr: The memory address from which to read
|
||||||
void setupFUSBIRQ();
|
* size: The number of bytes to read
|
||||||
|
* buf: The buffer into which data will be read
|
||||||
|
*/
|
||||||
|
bool fusb_read_buf(uint8_t addr, uint8_t size, uint8_t *buf);
|
||||||
|
/*
|
||||||
|
* Write multiple bytes to the FUSB302B
|
||||||
|
*
|
||||||
|
* cfg: The FUSB302B to communicate with
|
||||||
|
* addr: The memory address to which we will write
|
||||||
|
* size: The number of bytes to write
|
||||||
|
* buf: The buffer to write
|
||||||
|
*/
|
||||||
|
bool fusb_write_buf(uint8_t addr, uint8_t size, const uint8_t *buf);
|
||||||
|
// Used to poll for the device existing on the I2C bus. This should return non-zero if the device is responding on the bus
|
||||||
|
bool fusb302_detect();
|
||||||
|
// Once this is called IRQ's should be enabled and routed to the IRQ handler thread
|
||||||
|
void setupFUSBIRQ();
|
||||||
|
// This should return true if the IRQ line for the FUSB302 is still held low
|
||||||
|
bool getFUS302IRQLow();
|
||||||
|
|
||||||
#endif /* PDB_FUSB302B_H */
|
#endif /* PDB_FUSB302B_H */
|
||||||
|
|||||||
@@ -11,8 +11,5 @@
|
|||||||
extern struct pdb_config pdb_config_data;
|
extern struct pdb_config pdb_config_data;
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
// returns 1 if the FUSB302 is on the I2C bus
|
|
||||||
uint8_t fusb302_detect();
|
|
||||||
|
|
||||||
void fusb302_start_processing();
|
void fusb302_start_processing();
|
||||||
#endif /* DRIVERS_FUSB302_FUSBPD_H_ */
|
#endif /* DRIVERS_FUSB302_FUSBPD_H_ */
|
||||||
|
|||||||
@@ -16,12 +16,11 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "int_n.h"
|
#include "int_n.h"
|
||||||
#include "BSP.h"
|
#include "Defines.h"
|
||||||
#include "BSP_PD.h"
|
|
||||||
#include "fusb302b.h"
|
#include "fusb302b.h"
|
||||||
|
#include "fusb_user.h"
|
||||||
#include "fusbpd.h"
|
#include "fusbpd.h"
|
||||||
#include "policy_engine.h"
|
#include "policy_engine.h"
|
||||||
|
|
||||||
#include "task.h"
|
#include "task.h"
|
||||||
#include <pd.h>
|
#include <pd.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|||||||
Reference in New Issue
Block a user