no-OS
Macros | Enumerations | Functions
iio_lt7182s.c File Reference

Source file for the LT7182S IIO Driver. More...

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "no_os_alloc.h"
#include "no_os_error.h"
#include "no_os_units.h"
#include "no_os_util.h"
#include "lt7182s.h"
#include "iio_lt7182s.h"
Include dependency graph for iio_lt7182s.c:

Macros

#define LT7182S_IIO_REG_CHAN(reg, chan)   (reg | (chan << 8))
 
#define LT7182S_IIO_REG(x)   (x & 0xFF)
 
#define LT7182S_IIO_CHAN(x)   ((x >> 8) & 0xFF)
 

Enumerations

enum  lt7182s_iio_enable_type {
  LT7182S_IIO_OUTPUT_ENABLE,
  LT7182S_IIO_PULSE_ENABLE,
  LT7182S_IIO_SYNC_ENABLE,
  LT7182S_IIO_OUTPUT_ENABLE,
  LT7182S_IIO_PULSE_ENABLE,
  LT7182S_IIO_SYNC_ENABLE
}
 
enum  lt7182s_iio_pwm_params {
  LT7182S_IIO_PWM_FREQUENCY,
  LT7182S_IIO_PWM_PHASE
}
 
enum  lt7182s_iio_chan_type {
  LT7182S_IIO_VOUT_0_CHAN,
  LT7182S_IIO_VOUT_1_CHAN,
  LT7182S_IIO_VIN_0_CHAN,
  LT7182S_IIO_VIN_1_CHAN,
  LT7182S_IIO_IIN_0_CHAN,
  LT7182S_IIO_IIN_1_CHAN,
  LT7182S_IIO_IOUT_0_CHAN,
  LT7182S_IIO_IOUT_1_CHAN,
  LT7182S_IIO_TEMP_CHAN,
  LT7182S_IIO_VCC_CHAN
}
 

Functions

int lt7182s_iio_init (struct lt7182s_iio_desc **iio_desc, struct lt7182s_iio_desc_init_param *init_param)
 Initializes the LT7182S IIO descriptor. More...
 
int lt7182s_iio_remove (struct lt7182s_iio_desc *iio_desc)
 Free resources allocated by the init function. More...
 

Detailed Description

Source file for the LT7182S IIO Driver.

Author
Cedric Justine Encarnacion (cedri.nosp@m.cjus.nosp@m.tine..nosp@m.enca.nosp@m.rnaci.nosp@m.on@a.nosp@m.nalog.nosp@m..com)

Copyright 2024(c) Analog Devices, Inc.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
  3. Neither the name of Analog Devices, Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES, INC. “AS IS” AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ANALOG DEVICES, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Macro Definition Documentation

◆ LT7182S_IIO_CHAN

#define LT7182S_IIO_CHAN (   x)    ((x >> 8) & 0xFF)

◆ LT7182S_IIO_REG

#define LT7182S_IIO_REG (   x)    (x & 0xFF)

◆ LT7182S_IIO_REG_CHAN

#define LT7182S_IIO_REG_CHAN (   reg,
  chan 
)    (reg | (chan << 8))

Enumeration Type Documentation

◆ lt7182s_iio_chan_type

Enumerator
LT7182S_IIO_VOUT_0_CHAN 
LT7182S_IIO_VOUT_1_CHAN 
LT7182S_IIO_VIN_0_CHAN 
LT7182S_IIO_VIN_1_CHAN 
LT7182S_IIO_IIN_0_CHAN 
LT7182S_IIO_IIN_1_CHAN 
LT7182S_IIO_IOUT_0_CHAN 
LT7182S_IIO_IOUT_1_CHAN 
LT7182S_IIO_TEMP_CHAN 
LT7182S_IIO_VCC_CHAN 

◆ lt7182s_iio_enable_type

Enumerator
LT7182S_IIO_OUTPUT_ENABLE 
LT7182S_IIO_PULSE_ENABLE 
LT7182S_IIO_SYNC_ENABLE 
LT7182S_IIO_OUTPUT_ENABLE 
LT7182S_IIO_PULSE_ENABLE 
LT7182S_IIO_SYNC_ENABLE 

◆ lt7182s_iio_pwm_params

Enumerator
LT7182S_IIO_PWM_FREQUENCY 
LT7182S_IIO_PWM_PHASE 

Function Documentation

◆ lt7182s_iio_init()

int lt7182s_iio_init ( struct lt7182s_iio_desc **  iio_desc,
struct lt7182s_iio_desc_init_param init_param 
)

Initializes the LT7182S IIO descriptor.

Parameters
iio_desc- The iio device descriptor.
init_param- The structure that contains the device initial parameters.
Returns
0 in case of success, an error code otherwise.
Here is the caller graph for this function:

◆ lt7182s_iio_remove()

int lt7182s_iio_remove ( struct lt7182s_iio_desc iio_desc)

Free resources allocated by the init function.

Parameters
iio_desc- The iio device descriptor.
Returns
0 in case of success, an error code otherwise.
Here is the caller graph for this function: