blob: 685c2902216c38928748ebb8fb7828363ae7d941 [file] [log] [blame]
/*
* libiio - Library for interfacing industrial I/O (IIO) devices
*
* Copyright (C) 2014 Analog Devices, Inc.
* Author: Paul Cercueil <paul.cercueil@analog.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* */
#ifndef __IIO_PRIVATE_H__
#define __IIO_PRIVATE_H__
/* Include public interface */
#include "iio.h"
#include "iio-config.h"
#include <stdbool.h>
#ifdef _MSC_BUILD
#define inline __inline
#define iio_snprintf sprintf_s
#else
#define iio_snprintf snprintf
#endif
#ifdef _WIN32
# ifdef LIBIIO_EXPORTS
# define __api __declspec(dllexport)
# else
# define __api __declspec(dllimport)
# endif
#elif __GNUC__ >= 4
# define __api __attribute__((visibility ("default")))
#else
# define __api
#endif
#ifdef WITH_MATLAB_BINDINGS_API
#include "bindings/matlab/iio-wrapper.h"
#endif
#define ARRAY_SIZE(x) (sizeof(x) ? sizeof(x) / sizeof((x)[0]) : 0)
#define BIT(x) (1 << (x))
#define BIT_MASK(bit) BIT((bit) % 32)
#define BIT_WORD(bit) ((bit) / 32)
#define TEST_BIT(addr, bit) (!!(*(((uint32_t *) addr) + BIT_WORD(bit)) \
& BIT_MASK(bit)))
#define SET_BIT(addr, bit) \
*(((uint32_t *) addr) + BIT_WORD(bit)) |= BIT_MASK(bit)
#define CLEAR_BIT(addr, bit) \
*(((uint32_t *) addr) + BIT_WORD(bit)) &= ~BIT_MASK(bit)
/* ntohl/htonl are a nightmare to use in cross-platform applications,
* since they are defined in different headers on different platforms.
* iio_be32toh/iio_htobe32 are just clones of ntohl/htonl. */
static inline uint32_t iio_be32toh(uint32_t word)
{
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
#ifdef __GNUC__
return __builtin_bswap32(word);
#else
return ((word & 0xff) << 24) | ((word & 0xff00) << 8) |
((word >> 8) & 0xff00) | ((word >> 24) & 0xff);
#endif
#else
return word;
#endif
}
static inline uint32_t iio_htobe32(uint32_t word)
{
return iio_be32toh(word);
}
/* Allocate zeroed out memory */
static inline void *zalloc(size_t size)
{
return calloc(1, size);
}
enum iio_attr_type {
IIO_ATTR_TYPE_DEVICE = 0,
IIO_ATTR_TYPE_DEBUG,
IIO_ATTR_TYPE_BUFFER,
};
struct iio_backend_ops {
struct iio_context * (*clone)(const struct iio_context *ctx);
ssize_t (*read)(const struct iio_device *dev, void *dst, size_t len,
uint32_t *mask, size_t words);
ssize_t (*write)(const struct iio_device *dev,
const void *src, size_t len);
int (*open)(const struct iio_device *dev,
size_t samples_count, bool cyclic);
int (*close)(const struct iio_device *dev);
int (*get_fd)(const struct iio_device *dev);
int (*set_blocking_mode)(const struct iio_device *dev, bool blocking);
void (*cancel)(const struct iio_device *dev);
int (*set_kernel_buffers_count)(const struct iio_device *dev,
unsigned int nb_blocks);
ssize_t (*get_buffer)(const struct iio_device *dev,
void **addr_ptr, size_t bytes_used,
uint32_t *mask, size_t words);
ssize_t (*read_device_attr)(const struct iio_device *dev,
const char *attr, char *dst, size_t len, enum iio_attr_type);
ssize_t (*write_device_attr)(const struct iio_device *dev,
const char *attr, const char *src,
size_t len, enum iio_attr_type);
ssize_t (*read_channel_attr)(const struct iio_channel *chn,
const char *attr, char *dst, size_t len);
ssize_t (*write_channel_attr)(const struct iio_channel *chn,
const char *attr, const char *src, size_t len);
int (*get_trigger)(const struct iio_device *dev,
const struct iio_device **trigger);
int (*set_trigger)(const struct iio_device *dev,
const struct iio_device *trigger);
void (*shutdown)(struct iio_context *ctx);
int (*get_version)(const struct iio_context *ctx, unsigned int *major,
unsigned int *minor, char git_tag[8]);
int (*set_timeout)(struct iio_context *ctx, unsigned int timeout);
};
/*
* If these structures are updated, the qsort functions defined in sort.c
* may need to be updated.
*/
struct iio_context_pdata;
struct iio_device_pdata;
struct iio_channel_pdata;
struct iio_scan_backend_context;
struct iio_channel_attr {
char *name;
char *filename;
};
struct iio_context {
struct iio_context_pdata *pdata;
const struct iio_backend_ops *ops;
const char *name;
char *description;
struct iio_device **devices;
unsigned int nb_devices;
char *xml;
char **attrs;
char **values;
unsigned int nb_attrs;
};
struct iio_channel {
struct iio_device *dev;
struct iio_channel_pdata *pdata;
void *userdata;
bool is_output;
bool is_scan_element;
struct iio_data_format format;
char *name, *id;
long index;
enum iio_modifier modifier;
enum iio_chan_type type;
struct iio_channel_attr *attrs;
unsigned int nb_attrs;
unsigned int number;
};
struct iio_device {
const struct iio_context *ctx;
struct iio_device_pdata *pdata;
void *userdata;
char *name, *id;
char **attrs;
unsigned int nb_attrs;
char **buffer_attrs;
unsigned int nb_buffer_attrs;
char **debug_attrs;
unsigned int nb_debug_attrs;
struct iio_channel **channels;
unsigned int nb_channels;
uint32_t *mask;
size_t words;
};
struct iio_buffer {
const struct iio_device *dev;
void *buffer, *userdata;
size_t length, data_length;
uint32_t *mask;
unsigned int dev_sample_size;
unsigned int sample_size;
bool is_output, dev_is_high_speed;
};
struct iio_context_info {
char *description;
char *uri;
};
struct iio_scan_result {
size_t size;
struct iio_context_info **info;
};
struct iio_context_info ** iio_scan_result_add(
struct iio_scan_result *scan_result, size_t num);
void free_channel(struct iio_channel *chn);
void free_device(struct iio_device *dev);
char *iio_channel_get_xml(const struct iio_channel *chn, size_t *len);
char *iio_device_get_xml(const struct iio_device *dev, size_t *len);
char *iio_context_create_xml(const struct iio_context *ctx);
int iio_context_init(struct iio_context *ctx);
bool iio_device_is_tx(const struct iio_device *dev);
int iio_device_open(const struct iio_device *dev,
size_t samples_count, bool cyclic);
int iio_device_close(const struct iio_device *dev);
int iio_device_set_blocking_mode(const struct iio_device *dev, bool blocking);
ssize_t iio_device_read_raw(const struct iio_device *dev,
void *dst, size_t len, uint32_t *mask, size_t words);
ssize_t iio_device_write_raw(const struct iio_device *dev,
const void *src, size_t len);
int iio_device_get_poll_fd(const struct iio_device *dev);
int read_double(const char *str, double *val);
int write_double(char *buf, size_t len, double val);
struct iio_context * local_create_context(void);
struct iio_context * network_create_context(const char *hostname);
struct iio_context * xml_create_context_mem(const char *xml, size_t len);
struct iio_context * xml_create_context(const char *xml_file);
struct iio_context * usb_create_context(unsigned int bus, unsigned int address,
unsigned int interface);
struct iio_context * usb_create_context_from_uri(const char *uri);
struct iio_context * serial_create_context_from_uri(const char *uri);
int local_context_scan(struct iio_scan_result *scan_result);
struct iio_scan_backend_context * usb_context_scan_init(void);
void usb_context_scan_free(struct iio_scan_backend_context *ctx);
int usb_context_scan(struct iio_scan_backend_context *ctx,
struct iio_scan_result *scan_result);
/* This function is not part of the API, but is used by the IIO daemon */
__api ssize_t iio_device_get_sample_size_mask(const struct iio_device *dev,
const uint32_t *mask, size_t words);
void iio_channel_init_finalize(struct iio_channel *chn);
unsigned int find_channel_modifier(const char *s, size_t *len_p);
char *iio_strdup(const char *str);
int iio_context_add_attr(struct iio_context *ctx,
const char *key, const char *value);
#undef __api
#endif /* __IIO_PRIVATE_H__ */