1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-25 14:04:25 +00:00

Minor style changes.

This commit is contained in:
Con Kolivas 2013-10-13 17:11:16 +11:00
parent 4664350c23
commit f1941db061

View File

@ -14,7 +14,7 @@
#define _HF_PROTOCOL_H_ #define _HF_PROTOCOL_H_
#if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ #if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
#error "This header uses bit fields and has byte ordering assumptions suitable only for Little Endian platforms" #error "This header uses bit fields and has byte ordering assumptions suitable only for Little Endian platforms"
#endif #endif
#define HF_PREAMBLE (uint8_t) 0xaa #define HF_PREAMBLE (uint8_t) 0xaa
@ -43,122 +43,122 @@
// Generic header // Generic header
struct hf_header { struct hf_header {
uint8_t preamble; // Always 0xaa uint8_t preamble; // Always 0xaa
uint8_t operation_code; uint8_t operation_code;
uint8_t chip_address; uint8_t chip_address;
uint8_t core_address; uint8_t core_address;
uint16_t hdata; // Header specific data uint16_t hdata; // Header specific data
uint8_t data_length; // .. of data frame to follow, in 4 byte blocks, 0=no data uint8_t data_length; // .. of data frame to follow, in 4 byte blocks, 0=no data
uint8_t crc8; // Computed across bytes 1-6 inclusive uint8_t crc8; // Computed across bytes 1-6 inclusive
} __attribute__((packed,aligned(4))); // 8 bytes total } __attribute__((packed,aligned(4))); // 8 bytes total
// Header specific to OP_PLL_CONFIG // Header specific to OP_PLL_CONFIG
struct hf_pll_config { struct hf_pll_config {
uint8_t preamble; uint8_t preamble;
uint8_t operation_code; uint8_t operation_code;
uint8_t chip_address; uint8_t chip_address;
uint8_t pll_divr:6; uint8_t pll_divr:6;
uint8_t pll_bypass:1; uint8_t pll_bypass:1;
uint8_t pll_reset:1; uint8_t pll_reset:1;
uint16_t pll_divf:8; uint16_t pll_divf:8;
uint16_t spare1:1; // Must always be 0 uint16_t spare1:1; // Must always be 0
uint16_t pll_divq:3; uint16_t pll_divq:3;
uint16_t pll_range:3; uint16_t pll_range:3;
uint16_t pll_fse:1; // Must always be 1 uint16_t pll_fse:1; // Must always be 1
uint8_t data_length; // Always 0 uint8_t data_length; // Always 0
uint8_t crc8; // Computed across bytes 1-6 inclusive uint8_t crc8; // Computed across bytes 1-6 inclusive
} __attribute__((packed,aligned(4))); // 8 bytes total } __attribute__((packed,aligned(4))); // 8 bytes total
// OP_HASH serial data // OP_HASH serial data
struct hf_hash_serial { struct hf_hash_serial {
uint8_t midstate[32]; // Computed from first half of block header uint8_t midstate[32]; // Computed from first half of block header
uint8_t merkle_residual[4]; // From block header uint8_t merkle_residual[4]; // From block header
uint32_t timestamp; // From block header uint32_t timestamp; // From block header
uint32_t bits; // Actual difficulty target for block header uint32_t bits; // Actual difficulty target for block header
uint32_t starting_nonce; // Usually set to 0 uint32_t starting_nonce; // Usually set to 0
uint32_t nonce_loops; // How many nonces to search, or 0 for 2^32 uint32_t nonce_loops; // How many nonces to search, or 0 for 2^32
uint16_t ntime_loops:12; // How many times to roll timestamp, or 0 uint16_t ntime_loops:12; // How many times to roll timestamp, or 0
uint16_t spare1:4; uint16_t spare1:4;
uint8_t search_difficulty; // Search difficulty to use, number of leading '0' bits required uint8_t search_difficulty; // Search difficulty to use, number of leading '0' bits required
uint8_t option; uint8_t option;
uint32_t group:8; uint32_t group:8;
uint32_t spare3:24; uint32_t spare3:24;
uint32_t crc32; // Computed across all preceding data fields uint32_t crc32; // Computed across all preceding data fields
} __attribute__((packed,aligned(4))); // 64 bytes total, including CRC } __attribute__((packed,aligned(4))); // 64 bytes total, including CRC
// OP_HASH usb data - squashed so header+data = 64 bytes // OP_HASH usb data - squashed so header+data = 64 bytes
struct hf_hash_usb { struct hf_hash_usb {
uint8_t midstate[32]; // Computed from first half of block header uint8_t midstate[32]; // Computed from first half of block header
uint8_t merkle_residual[4]; // From block header uint8_t merkle_residual[4]; // From block header
uint32_t timestamp; // From block header uint32_t timestamp; // From block header
uint32_t bits; // Actual difficulty target for block header uint32_t bits; // Actual difficulty target for block header
uint32_t starting_nonce; // Usually set to 0 uint32_t starting_nonce; // Usually set to 0
uint32_t nonce_loops; // How many nonces to search, or 0 for 2^32 uint32_t nonce_loops; // How many nonces to search, or 0 for 2^32
uint16_t ntime_loops:12; // How many times to roll timestamp, or 0 uint16_t ntime_loops:12; // How many times to roll timestamp, or 0
uint16_t spare1:4; uint16_t spare1:4;
uint8_t search_difficulty; // Search difficulty to use, number of leading '0' bits required uint8_t search_difficulty; // Search difficulty to use, number of leading '0' bits required
uint8_t group; // Non-zero for valid group uint8_t group; // Non-zero for valid group
} __attribute__((packed,aligned(4))); // 64 bytes total, including CRC } __attribute__((packed,aligned(4))); // 64 bytes total, including CRC
// OP_NONCE data // OP_NONCE data
struct hf_candidate_nonce { struct hf_candidate_nonce {
uint32_t nonce; // Candidate nonce uint32_t nonce; // Candidate nonce
uint16_t sequence; // Sequence number from corresponding OP_HASH uint16_t sequence; // Sequence number from corresponding OP_HASH
uint16_t ntime:12; // ntime offset, if ntime roll occurred uint16_t ntime:12; // ntime offset, if ntime roll occurred
uint16_t search:1; // Search forward next 128 nonces to find solution uint16_t search:1; // Search forward next 128 nonces to find solution
uint16_t spare:3; uint16_t spare:3;
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// OP_CONFIG data // OP_CONFIG data
struct hf_config_data { struct hf_config_data {
uint16_t status_period:11; // Periodic status time, msec uint16_t status_period:11; // Periodic status time, msec
uint16_t enable_periodic_status:1; // Send periodic status uint16_t enable_periodic_status:1; // Send periodic status
uint16_t send_status_on_core_idle:1; // Schedule status whenever core goes idle uint16_t send_status_on_core_idle:1; // Schedule status whenever core goes idle
uint16_t send_status_on_pending_empty:1; // Schedule status whenever core pending goes idle uint16_t send_status_on_pending_empty:1; // Schedule status whenever core pending goes idle
uint16_t pwm_active_level:1; // Active level of PWM outputs, if used uint16_t pwm_active_level:1; // Active level of PWM outputs, if used
uint16_t forward_all_privileged_packets:1; // Forward priv pkts -- diagnostic uint16_t forward_all_privileged_packets:1; // Forward priv pkts -- diagnostic
uint8_t status_batch_delay; // Batching delay, time to wait before sending status uint8_t status_batch_delay; // Batching delay, time to wait before sending status
uint8_t watchdog:7; // Watchdog timeout, seconds uint8_t watchdog:7; // Watchdog timeout, seconds
uint8_t disable_sensors:1; // Diagnostic uint8_t disable_sensors:1; // Diagnostic
uint8_t rx_header_timeout:7; // Header timeout in char times uint8_t rx_header_timeout:7; // Header timeout in char times
uint8_t rx_ignore_header_crc:1; // Ignore rx header crc's (diagnostic) uint8_t rx_ignore_header_crc:1; // Ignore rx header crc's (diagnostic)
uint8_t rx_data_timeout:7; // Data timeout in char times / 16 uint8_t rx_data_timeout:7; // Data timeout in char times / 16
uint8_t rx_ignore_data_crc:1; // Ignore rx data crc's (diagnostic) uint8_t rx_ignore_data_crc:1; // Ignore rx data crc's (diagnostic)
uint8_t stats_interval:7; // Minimum interval to report statistics (seconds) uint8_t stats_interval:7; // Minimum interval to report statistics (seconds)
uint8_t stat_diagnostic:1; // Never set this uint8_t stat_diagnostic:1; // Never set this
uint8_t measure_interval; // Die temperature measurment interval (msec) uint8_t measure_interval; // Die temperature measurment interval (msec)
uint32_t one_usec:12; // How many LF clocks per usec. uint32_t one_usec:12; // How many LF clocks per usec.
uint32_t max_nonces_per_frame:4; // Maximum # of nonces to combine in a single frame uint32_t max_nonces_per_frame:4; // Maximum # of nonces to combine in a single frame
uint32_t voltage_sample_points:8; // Bit mask for sample points (up to 5 bits set) uint32_t voltage_sample_points:8; // Bit mask for sample points (up to 5 bits set)
uint32_t pwm_phases:2; // phases - 1 uint32_t pwm_phases:2; // phases - 1
uint32_t trim:4; // Trim value for temperature measurements uint32_t trim:4; // Trim value for temperature measurements
uint32_t clock_diagnostic:1; // Never set this uint32_t clock_diagnostic:1; // Never set this
uint32_t forward_all_packets:1; // Forward everything - diagnostic. uint32_t forward_all_packets:1; // Forward everything - diagnostic.
uint16_t pwm_period; // Period of PWM outputs, in reference clock cycles uint16_t pwm_period; // Period of PWM outputs, in reference clock cycles
uint16_t pwm_pulse_period; // Initial count, phase 0 uint16_t pwm_pulse_period; // Initial count, phase 0
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// OP_GROUP data // OP_GROUP data
struct hf_group_data { struct hf_group_data {
uint16_t nonce_msoffset; // This value << 16 added to starting nonce uint16_t nonce_msoffset; // This value << 16 added to starting nonce
uint16_t ntime_offset:12; // This value added to timestamp uint16_t ntime_offset:12; // This value added to timestamp
uint16_t spare:4; uint16_t spare:4;
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// Structure of the monitor fields for G-1, returned in OP_STATUS, core bitmap follows this // Structure of the monitor fields for G-1, returned in OP_STATUS, core bitmap follows this
struct hf_g1_monitor { struct hf_g1_monitor {
uint16_t die_temperature:12; // Die temperature ADC count uint16_t die_temperature:12; // Die temperature ADC count
uint16_t spare:4; // Spare uint16_t spare:4; // Spare
uint8_t core_voltage[6]; // Core voltage uint8_t core_voltage[6]; // Core voltage
// [0] = main sensor // [0] = main sensor
// [1]-[5] = other positions // [1]-[5] = other positions
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// Conversions for the ADC readings from GN on-chip sensors in the above structure // Conversions for the ADC readings from GN on-chip sensors in the above structure
#define GN_CORE_VOLTAGE(a) ((float)(a)/256*1.2) #define GN_CORE_VOLTAGE(a) ((float)(a)/256*1.2)
@ -166,15 +166,15 @@ struct hf_g1_monitor {
// What comes back in the body of an OP_STATISTICS frame (On die statistics) // What comes back in the body of an OP_STATISTICS frame (On die statistics)
struct hf_statistics { struct hf_statistics {
uint8_t rx_header_crc; // Header CRC error's uint8_t rx_header_crc; // Header CRC error's
uint8_t rx_body_crc; // Data CRC error's uint8_t rx_body_crc; // Data CRC error's
uint8_t rx_header_timeouts; // Header timeouts uint8_t rx_header_timeouts; // Header timeouts
uint8_t rx_body_timeouts; // Data timeouts uint8_t rx_body_timeouts; // Data timeouts
uint8_t core_nonce_fifo_full; // Core nonce Q overrun events uint8_t core_nonce_fifo_full; // Core nonce Q overrun events
uint8_t array_nonce_fifo_full; // System nonce Q overrun events uint8_t array_nonce_fifo_full; // System nonce Q overrun events
uint8_t stats_overrun; // Overrun in statistics reporting uint8_t stats_overrun; // Overrun in statistics reporting
uint8_t spare; uint8_t spare;
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// The sequence distance between a sent and received sequence number. // The sequence distance between a sent and received sequence number.
@ -186,23 +186,23 @@ struct hf_statistics {
// Convenience header specific to OP_USB_INIT // Convenience header specific to OP_USB_INIT
struct hf_usb_init_header { struct hf_usb_init_header {
uint8_t preamble; // Always 0xaa uint8_t preamble; // Always 0xaa
uint8_t operation_code; uint8_t operation_code;
uint8_t spare1; uint8_t spare1;
uint8_t protocol:3; // Which protocol to use uint8_t protocol:3; // Which protocol to use
uint8_t user_configuration:1; // Use the following configuration data uint8_t user_configuration:1; // Use the following configuration data
uint8_t spare2:4; uint8_t spare2:4;
uint16_t hash_clock:12; // Requested hash clock frequency uint16_t hash_clock:12; // Requested hash clock frequency
uint16_t pll_bypass:1; // Force PLL bypass, hash clock = ref clock uint16_t pll_bypass:1; // Force PLL bypass, hash clock = ref clock
uint16_t no_asic_initialization:1; // Do not perform automatic ASIC initialization uint16_t no_asic_initialization:1; // Do not perform automatic ASIC initialization
uint16_t do_atspeed_core_tests:1; // Do core tests at speed, return second bitmap uint16_t do_atspeed_core_tests:1; // Do core tests at speed, return second bitmap
uint16_t leave_powered_down:1; // Init USB only, leave device powered down uint16_t leave_powered_down:1; // Init USB only, leave device powered down
uint8_t data_length; // .. of data frame to follow, in 4 byte blocks uint8_t data_length; // .. of data frame to follow, in 4 byte blocks
uint8_t crc8; // Computed across bytes 1-6 inclusive uint8_t crc8; // Computed across bytes 1-6 inclusive
} __attribute__((packed,aligned(4))); // 8 bytes total } __attribute__((packed,aligned(4))); // 8 bytes total
// Values the protocol field in the above structure may take // Values the protocol field in the above structure may take
#define PROTOCOL_USB_MAPPED_SERIAL 0 #define PROTOCOL_USB_MAPPED_SERIAL 0
@ -214,22 +214,22 @@ struct hf_usb_init_header {
// select only those options desired for modification. Do not use this facility // select only those options desired for modification. Do not use this facility
// unless you are an expert - loading inconsistent settings will not work. // unless you are an expert - loading inconsistent settings will not work.
struct hf_usb_init_options { struct hf_usb_init_options {
uint16_t group_ntime_roll; // Total ntime roll amount per group uint16_t group_ntime_roll; // Total ntime roll amount per group
uint16_t core_ntime_roll; // Total core ntime roll amount uint16_t core_ntime_roll; // Total core ntime roll amount
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// Base item returned from device for OP_USB_INIT // Base item returned from device for OP_USB_INIT
struct hf_usb_init_base { struct hf_usb_init_base {
uint16_t firmware_rev; // Firmware revision # uint16_t firmware_rev; // Firmware revision #
uint16_t hardware_rev; // Hardware revision # uint16_t hardware_rev; // Hardware revision #
uint32_t serial_number; // Board serial number uint32_t serial_number; // Board serial number
uint8_t operation_status; // Reply status for OP_USB_INIT (0 = success) uint8_t operation_status; // Reply status for OP_USB_INIT (0 = success)
uint8_t extra_status_1; // Extra reply status information, code specific uint8_t extra_status_1; // Extra reply status information, code specific
uint8_t extra_status_2; // uint8_t extra_status_2; //
uint8_t extra_status_3; // uint8_t extra_status_3; //
uint16_t hash_clockrate; // Actual hash clock rate used (nearest Mhz) uint16_t hash_clockrate; // Actual hash clock rate used (nearest Mhz)
uint16_t inflight_target; // Target inflight amount for GWQ protocol uint16_t inflight_target; // Target inflight amount for GWQ protocol
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// The above base item (16 bytes) is followed by the struct hf_config_data (16 bytes) actually // The above base item (16 bytes) is followed by the struct hf_config_data (16 bytes) actually
// used internally (so users may modify non-critical fields by doing subsequent // used internally (so users may modify non-critical fields by doing subsequent
@ -240,13 +240,13 @@ struct hf_usb_init_base {
// Information in an OP_DIE_STATUS frame. This is for one die - there are four per ASIC. // Information in an OP_DIE_STATUS frame. This is for one die - there are four per ASIC.
// Board level phase current and voltage sensors are likely to disappear in later production models. // Board level phase current and voltage sensors are likely to disappear in later production models.
struct hf_g1_die_data { struct hf_g1_die_data {
struct hf_g1_monitor die; // Die sensors - 8 bytes struct hf_g1_monitor die; // Die sensors - 8 bytes
uint16_t phase_currents[4]; // Phase currents (0 if unavailable) uint16_t phase_currents[4]; // Phase currents (0 if unavailable)
uint16_t voltage; // Voltage at device boundary (0 if unavailable) uint16_t voltage; // Voltage at device boundary (0 if unavailable)
uint16_t temperature; // Regulator temp sensor uint16_t temperature; // Regulator temp sensor
uint16_t tacho; // See documentation uint16_t tacho; // See documentation
uint16_t spare; uint16_t spare;
} __attribute__((packed,aligned(4))); // 24 bytes total } __attribute__((packed,aligned(4))); // 24 bytes total
// Conversions for the board/module level sensors // Conversions for the board/module level sensors
#define M_VOLTAGE(a) ((float)(a)*19.0734e-6) #define M_VOLTAGE(a) ((float)(a)*19.0734e-6)
@ -255,45 +255,45 @@ struct hf_g1_die_data {
// Information for an OP_GWQ_STATUS frame // Information for an OP_GWQ_STATUS frame
// If sequence_head == sequence_tail, then there is no active work and sequence_head is invalid // If sequence_head == sequence_tail, then there is no active work and sequence_head is invalid
struct hf_gwq_data { struct hf_gwq_data {
uint64_t hash_count; // Add this to host's cumulative hash count uint64_t hash_count; // Add this to host's cumulative hash count
uint16_t sequence_head; // The latest, internal, active sequence # uint16_t sequence_head; // The latest, internal, active sequence #
uint16_t sequence_tail; // The latest, internal, inactive sequence # uint16_t sequence_tail; // The latest, internal, inactive sequence #
} __attribute__((packed,aligned(4))); } __attribute__((packed,aligned(4)));
// Information for an OP_USB_STATS1 frame - Communication statistics // Information for an OP_USB_STATS1 frame - Communication statistics
struct hf_usb_stats1 { struct hf_usb_stats1 {
// USB incoming // USB incoming
uint16_t usb_rx_preambles; uint16_t usb_rx_preambles;
uint16_t usb_rx_receive_byte_errors; uint16_t usb_rx_receive_byte_errors;
uint16_t usb_rx_bad_hcrc; uint16_t usb_rx_bad_hcrc;
// USB outgoing // USB outgoing
uint16_t usb_tx_attempts; uint16_t usb_tx_attempts;
uint16_t usb_tx_packets; uint16_t usb_tx_packets;
uint16_t usb_tx_timeouts; uint16_t usb_tx_timeouts;
uint16_t usb_tx_incompletes; uint16_t usb_tx_incompletes;
uint16_t usb_tx_endpointstalled; uint16_t usb_tx_endpointstalled;
uint16_t usb_tx_disconnected; uint16_t usb_tx_disconnected;
uint16_t usb_tx_suspended; uint16_t usb_tx_suspended;
// Internal UART transmit
uint16_t uart_tx_queue_dma;
uint16_t uart_tx_interrupts;
// Internal UART receive // Internal UART transmit
uint16_t uart_rx_preamble_ints; uint16_t uart_tx_queue_dma;
uint16_t uart_rx_missed_preamble_ints; uint16_t uart_tx_interrupts;
uint16_t uart_rx_header_done;
uint16_t uart_rx_data_done;
uint16_t uart_rx_bad_hcrc;
uint16_t uart_rx_bad_dma;
uint16_t uart_rx_short_dma;
uint16_t uart_rx_buffers_full;
uint8_t max_tx_buffers; // Maximum # of send buffers ever used // Internal UART receive
uint8_t max_rx_buffers; // Maximum # of receive buffers ever used uint16_t uart_rx_preamble_ints;
} __attribute__((packed,aligned(4))); uint16_t uart_rx_missed_preamble_ints;
uint16_t uart_rx_header_done;
uint16_t uart_rx_data_done;
uint16_t uart_rx_bad_hcrc;
uint16_t uart_rx_bad_dma;
uint16_t uart_rx_short_dma;
uint16_t uart_rx_buffers_full;
uint8_t max_tx_buffers; // Maximum # of send buffers ever used
uint8_t max_rx_buffers; // Maximum # of receive buffers ever used
} __attribute__((packed,aligned(4)));
// Values info->device_type can take // Values info->device_type can take
#define HFD_G1 1 // HashFast G-1 GN ASIC #define HFD_G1 1 // HashFast G-1 GN ASIC