};
enum {
- SR_PROBE_TYPE_LOGIC,
+ SR_PROBE_LOGIC,
};
struct sr_probe {
/* Hardware driver options */
enum {
+ SR_HWOPT_DUMMY = 0, /* Used to terminate lists. Must be 0! */
+
/** Some drivers cannot detect the exact model they're talking to. */
SR_HWOPT_MODEL,
};
struct sr_dev_inst {
+ struct sr_dev_driver *driver;
int index;
int status;
int inst_type;
char *vendor;
char *model;
char *version;
+ GSList *probes;
void *priv;
};
/* Device info IDs */
enum {
/* struct sr_dev_inst for this specific device */
+ /* TODO: obsolete */
SR_DI_INST,
+ /* A list of options supported by the driver. */
+ SR_DI_HWOPTS,
+ /* A list of capabilities supported by the device. */
+ SR_DI_HWCAPS,
/* The number of probes connected to this device */
SR_DI_NUM_PROBES,
/* The probe names on this device */
int api_version;
int (*init) (void);
int (*cleanup) (void);
- int (*scan) (void);
+ GSList *(*scan) (GSList *options);
/* Device-specific */
int (*dev_open) (int dev_index);
int (*dev_close) (int dev_index);
+ /* TODO remove this */
const void *(*dev_info_get) (int dev_index, int dev_info_id);
+ int (*info_get) (int dev_info_id, const void **data,
+ const struct sr_dev_inst *sdi);
int (*dev_status_get) (int dev_index);
- const int *(*hwcap_get_all) (void);
int (*dev_config_set) (int dev_index, int hwcap, const void *value);
int (*dev_acquisition_start) (int dev_index, void *session_dev_id);
int (*dev_acquisition_stop) (int dev_index, void *session_dev_id);
+
+ /* Dynamic */
+ GSList *instances;
};
struct sr_session {