From 323ec66d62f19673e66762fe25585746d3b2a5e0 Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: 周三, 18 3月 2015 17:09:30 +0800 Subject: [PATCH] Add new AUTO special value, resolve #20 --- libscpi/inc/scpi/types.h | 105 ++++++++++++++++++++++++++++++---------------------- 1 files changed, 61 insertions(+), 44 deletions(-) diff --git a/libscpi/inc/scpi/types.h b/libscpi/inc/scpi/types.h index 2b24cb5..ee0d0b9 100644 --- a/libscpi/inc/scpi/types.h +++ b/libscpi/inc/scpi/types.h @@ -1,5 +1,7 @@ /*- - * Copyright (c) 2012-2013 Jan Breuer, + * Copyright (c) 2013 Jan Breuer + * Richard.hmm + * Copyright (c) 2012 Jan Breuer * * All Rights Reserved * @@ -45,46 +47,50 @@ extern "C" { #endif -#define FALSE false -#define TRUE true +#ifndef FALSE + #define FALSE 0 +#endif +#ifndef TRUE + #define TRUE (!FALSE) +#endif /* basic data types */ - typedef bool bool_t; - //typedef enum { FALSE = 0, TRUE } bool_t; + typedef bool scpi_bool_t; + /* typedef enum { FALSE = 0, TRUE } scpi_bool_t; */ /* IEEE 488.2 registers */ enum _scpi_reg_name_t { - SCPI_REG_STB = 0, // Status Byte - SCPI_REG_SRE, // Service Request Enable Register - SCPI_REG_ESR, // Standard Event Status Register (ESR, SESR) - SCPI_REG_ESE, // Event Status Enable Register - SCPI_REG_OPER, // OPERation Status Register - SCPI_REG_OPERE, // OPERation Status Enable Register - SCPI_REG_QUES, // QUEStionable status register - SCPI_REG_QUESE, // QUEStionable status Enable Register + SCPI_REG_STB = 0, /* Status Byte */ + SCPI_REG_SRE, /* Service Request Enable Register */ + SCPI_REG_ESR, /* Standard Event Status Register (ESR, SESR) */ + SCPI_REG_ESE, /* Event Status Enable Register */ + SCPI_REG_OPER, /* OPERation Status Register */ + SCPI_REG_OPERE, /* OPERation Status Enable Register */ + SCPI_REG_QUES, /* QUEStionable status register */ + SCPI_REG_QUESE, /* QUEStionable status Enable Register */ /* last definition - number of registers */ - SCPI_REG_COUNT, + SCPI_REG_COUNT }; typedef enum _scpi_reg_name_t scpi_reg_name_t; enum _scpi_ctrl_name_t { - SCPI_CTRL_SRQ = 1, // service request - SCPI_CTRL_GTL, // Go to local - SCPI_CTRL_SDC, // Selected device clear - SCPI_CTRL_PPC, // Parallel poll configure - SCPI_CTRL_GET, // Group execute trigger - SCPI_CTRL_TCT, // Take control - SCPI_CTRL_LLO, // Device clear - SCPI_CTRL_DCL, // Local lockout - SCPI_CTRL_PPU, // Parallel poll unconfigure - SCPI_CTRL_SPE, // Serial poll enable - SCPI_CTRL_SPD, // Serial poll disable - SCPI_CTRL_MLA, // My local address - SCPI_CTRL_UNL, // Unlisten - SCPI_CTRL_MTA, // My talk address - SCPI_CTRL_UNT, // Untalk - SCPI_CTRL_MSA, // My secondary address + SCPI_CTRL_SRQ = 1, /* service request */ + SCPI_CTRL_GTL, /* Go to local */ + SCPI_CTRL_SDC, /* Selected device clear */ + SCPI_CTRL_PPC, /* Parallel poll configure */ + SCPI_CTRL_GET, /* Group execute trigger */ + SCPI_CTRL_TCT, /* Take control */ + SCPI_CTRL_LLO, /* Device clear */ + SCPI_CTRL_DCL, /* Local lockout */ + SCPI_CTRL_PPU, /* Parallel poll unconfigure */ + SCPI_CTRL_SPE, /* Serial poll enable */ + SCPI_CTRL_SPD, /* Serial poll disable */ + SCPI_CTRL_MLA, /* My local address */ + SCPI_CTRL_UNL, /* Unlisten */ + SCPI_CTRL_MTA, /* My talk address */ + SCPI_CTRL_UNT, /* Untalk */ + SCPI_CTRL_MSA /* My secondary address */ }; typedef enum _scpi_ctrl_name_t scpi_ctrl_name_t; @@ -93,23 +99,11 @@ /* scpi commands */ enum _scpi_result_t { SCPI_RES_OK = 1, - SCPI_RES_ERR = -1, + SCPI_RES_ERR = -1 }; typedef enum _scpi_result_t scpi_result_t; typedef struct _scpi_command_t scpi_command_t; - - struct _scpi_param_list_t { - const scpi_command_t * cmd; - const char * parameters; - size_t length; - }; - #define SCPI_CMD_LIST_END {NULL, NULL, } - typedef struct _scpi_param_list_t scpi_param_list_t; - - /* scpi interface */ - typedef struct _scpi_t scpi_t; - typedef struct _scpi_interface_t scpi_interface_t; struct _scpi_buffer_t { size_t length; @@ -117,6 +111,26 @@ char * data; }; typedef struct _scpi_buffer_t scpi_buffer_t; + + struct _scpi_const_buffer_t { + size_t length; + size_t position; + const char * data; + }; + typedef struct _scpi_const_buffer_t scpi_const_buffer_t; + + struct _scpi_param_list_t { + const scpi_command_t * cmd; + const char * parameters; + size_t length; + scpi_const_buffer_t cmd_raw; + }; + #define SCPI_CMD_LIST_END {NULL, NULL, } + typedef struct _scpi_param_list_t scpi_param_list_t; + + /* scpi interface */ + typedef struct _scpi_t scpi_t; + typedef struct _scpi_interface_t scpi_interface_t; typedef size_t(*scpi_write_t)(scpi_t * context, const char * data, size_t len); typedef scpi_result_t(*scpi_write_control_t)(scpi_t * context, scpi_ctrl_name_t ctrl, scpi_reg_val_t val); @@ -136,6 +150,7 @@ SCPI_UNIT_HERTZ, SCPI_UNIT_CELSIUS, SCPI_UNIT_SECONDS, + SCPI_UNIT_DISTANCE }; typedef enum _scpi_unit_t scpi_unit_t; @@ -157,6 +172,7 @@ SCPI_NUM_NAN, SCPI_NUM_INF, SCPI_NUM_NINF, + SCPI_NUM_AUTO }; typedef enum _scpi_special_number_t scpi_special_number_t; @@ -195,12 +211,13 @@ scpi_interface_t * interface; int_fast16_t output_count; int_fast16_t input_count; - bool_t cmd_error; + scpi_bool_t cmd_error; scpi_error_queue_t error_queue; scpi_reg_val_t * registers; const scpi_unit_def_t * units; const scpi_special_number_def_t * special_numbers; void * user_context; + const char * idn[4]; }; #ifdef __cplusplus -- Gitblit v1.9.1