The command parser has been implemented for all options other than the config option. See #1
72 lines
2.0 KiB
C
72 lines
2.0 KiB
C
/*
|
|
* File: command-handler.h
|
|
* Author: Sebastian H. Gabrielli
|
|
*
|
|
* Created on March 6, 2024, 12:43 PM
|
|
*/
|
|
|
|
#ifndef COMMAND_HANDLER_H
|
|
#define COMMAND_HANDLER_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
#include <string.h>
|
|
|
|
// Enum of all valid command types
|
|
typedef enum {
|
|
WRITE_CONFIG, // Change the configuration
|
|
READ_CONFIG, // Read, and print the current configuration
|
|
READ_VOLTAGE, // Read, and print a voltage
|
|
READ_TERMPERATURE, // Read, and print the temperature
|
|
READ_FAN_SPEED, // Read, and print the current fan speed
|
|
READ_BULK_FAN_SPEED, // Read, and print the stored back fan speed data
|
|
CLEAR_BULK_FAN_SPEED, // Clear the buffer of stored fan speed data
|
|
UNKNOWN_COMMAND // An unrecognized command has been sent
|
|
} command_t;
|
|
|
|
// Enum of all valid voltage sources
|
|
typedef enum {
|
|
SRC_INTERNAL, // Internal volage
|
|
SRC_EXTRNAL, // External voltage
|
|
SRC_THERMISTOR, // Thermistor voltage
|
|
SRC_NONE // No voltage source selected
|
|
} src_voltage_t;
|
|
|
|
// Enum of all valid config options
|
|
// TODO: Move into config header file
|
|
typedef enum {
|
|
CNF_NONE, // No config option
|
|
} config_option_t;
|
|
|
|
// Enum of all valid fans
|
|
// TODO: Consider moving into it's own fan page
|
|
typedef enum {
|
|
FAN1, // The first fan
|
|
FAN2, // The second fan
|
|
FAN_NONE // No fan
|
|
} fans_t;
|
|
|
|
// Struct with command context
|
|
typedef struct {
|
|
command_t command; // The command to execute
|
|
src_voltage_t src_voltage; // The selected voltage source
|
|
fans_t fan; // The selected fan
|
|
config_option_t conf; // The configuration option to cange
|
|
// TODO: Add config value field for writing
|
|
} command_context_t;
|
|
|
|
// Parses the input string and outputs one of the valid commands
|
|
command_context_t parse_command(uint8_t *command, uint8_t command_len);
|
|
|
|
// Routes the provided command to the appropriate function to handle it
|
|
void route_command(command_context_t command);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* COMMAND_HANDLER_H */
|