summaryrefslogtreecommitdiffstats
path: root/cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h
diff options
context:
space:
mode:
Diffstat (limited to 'cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h')
-rw-r--r--cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h86
1 files changed, 0 insertions, 86 deletions
diff --git a/cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h b/cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h
deleted file mode 100644
index fafac346ec..0000000000
--- a/cpukit/dev/include/dev/i2c/xilinx-axi-i2c.h
+++ /dev/null
@@ -1,86 +0,0 @@
-/*
- * Copyright (c) 2016-2017 Chris Johns <chrisj@rtems.org> All rights reserved.
- *
- * The license and distribution terms for this file may be
- * found in the file LICENSE in this distribution or at
- * http://www.rtems.org/license/LICENSE.
- */
-
-/*
- * Xilinx AXI IIC Interface v2.0. See PG090.pdf.
- *
- * Note, only master support is provided and no dynamic mode by design.
- *
- * The clock set up is to be handled by the IP integrator. There are too many
- * factors handling this in software.
- */
-
-
-#ifndef XILINX_AXI_I2C_H
-#define XILINX_AXI_I2C_H
-
-#include <dev/i2c/i2c.h>
-
-/*
- * The PL integrator controls the timing. This interface allows software to
- * override those settings. It pays to check the timing with ChipScope.
- *
- * If you set the AXI bus frequency you can use the clock speed ioctl call to
- * change the speed dymanically. The ioctl call overrides the defaults passed
- * in.
- *
- * Set the valid mask to the values that are to be set.
- */
-#define XILINX_AIX_I2C_AXI_CLOCK (1 << 0)
-#define XILINX_AIX_I2C_TSUSTA (1 << 1)
-#define XILINX_AIX_I2C_TSUSTO (1 << 2)
-#define XILINX_AIX_I2C_THDSTA (1 << 3)
-#define XILINX_AIX_I2C_TSUDAT (1 << 4)
-#define XILINX_AIX_I2C_TBUF (1 << 5)
-#define XILINX_AIX_I2C_THIGH (1 << 6)
-#define XILINX_AIX_I2C_TLOW (1 << 7)
-#define XILINX_AIX_I2C_THDDAT (1 << 8)
-#define XILINX_AIX_I2C_ALL_REGS (XILINX_AIX_I2C_TSUSTA | \
- XILINX_AIX_I2C_TSUSTO | \
- XILINX_AIX_I2C_THDSTA | \
- XILINX_AIX_I2C_TSUDAT | \
- XILINX_AIX_I2C_TBUF | \
- XILINX_AIX_I2C_THIGH | \
- XILINX_AIX_I2C_TLOW | \
- XILINX_AIX_I2C_THDDAT)
-typedef struct
-{
- uint32_t valid_mask;
- uint32_t AXI_CLOCK;
- uint32_t SCL_INERTIAL_DELAY;
- uint32_t TSUSTA;
- uint32_t TSUSTO;
- uint32_t THDSTA;
- uint32_t TSUDAT;
- uint32_t TBUF;
- uint32_t THIGH;
- uint32_t TLOW;
- uint32_t THDDAT;
-} xilinx_aix_i2c_timing;
-
-/*
- * Register the driver.
- *
- * The driver can multipex a number of I2C buses (in master mode only) using
- * the GPO port. The PL designer can use the output pins to select a bus. This
- * is useful if connecting a number of slave devices that have limit selectable
- * addresses.
- *
- * @param bus_path The driver's device path.
- * @param register_base AXI base address.
- * @param irq AXI FPGA interrupt.
- * @param gpio_address Bits 12:15 of a slave address it written to the GPO.
- * @param timing Override the default timing. NULL means no changes.
- */
-int i2c_bus_register_xilinx_aix_i2c(const char* bus_path,
- uintptr_t register_base,
- rtems_vector_number irq,
- bool ten_gpio,
- const xilinx_aix_i2c_timing* timing);
-
-#endif