/*
* Video On Demand Samples
*
* Copyright (C) 2015 Microchip Technology Germany II GmbH & Co. KG
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
* You may also obtain this software under a propriety license from Microchip.
* Please contact Microchip for further information.
*
*/
/*----------------------------------------------------------*/
/*! \file
* \brief This file contains the EPDataType_t, EPDirection_t, MlbPortSpeed_t, V1I2SPortClkDriveMode_t, V1I2SStreamingDataFormat_t,
* V1I2SPin_t, V3I2SPortOption_t, V3I2SClockMode_t, V3I2SDelayMode_t, V3I2SPortSpeed_t, V3I2SAlignment_t, V3I2SPin_t type definition.
*/
/*----------------------------------------------------------*/
#ifndef _TYPES_H_
#define _TYPES_H_
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include "Console.h"
#define LOG(x) ConsolePrintf(PRIO_ERROR, RED"! %s, %u, %s"RESETCOLOR"\n",x,__LINE__,__FILE__)
#define SCM_IN 0x00
#define SCM_OUT 0x01
typedef uint32_t TChannelId;
typedef uint16_t TDeviceId;
typedef uint8_t TNodePos;
typedef uint16_t TNodeAddr;
typedef uint32_t TBlockwidth;
typedef uint8_t TMostInstace;
typedef uint16_t TPos; ///Value is in per mile. (0..1000)
typedef enum AimType_tag
{
AIM_UNKNOWN,
AIM_CDEV,
AIM_AUDIO,
AIM_V4L
} AimType_t;
///Data type enum values are matched to INIC API V1 & V2
typedef enum
{
EP_Synchron = 0x00,
EP_Asynchron = 0x01,
EP_Control = 0x02,
EP_Isochron = 0x03,
EP_Unused = 0xFE,
EP_Unknown = 0xFF
} EPDataType_t;
///Direction type enum values are matched to INIC API V1 & V2
typedef enum
{
EPDIR_IN = 0x00,
EPDIR_OUT = 0x01,
EPDIR_Unknown = 0xFF
} EPDirection_t;
///INIC API V1 and V2: MLB Port speed in mulitple of MOST base clock (FS)
typedef enum
{
MlbSpeed256FS = 0,
MlbSpeed512FS = 1,
MlbSpeed1024FS = 2,
MlbSpeed2048FS = 3,
MlbSpeed3072FS = 4,
MlbSpeed4096FS = 5,
MlbSpeed6144FS = 6,
MlbSpeed8192FS = 7,
MlbSpeedNotSet = 0xFF
} MlbPortSpeed_t;
///TSI Port ID
typedef enum
{
V1TsiPortInstance0 = 0x5,
V1TsiPortInstance1 = 0x25,
V1TsiPortInstanceNotSet = 0xFF
} V1TsiPortInstance_t;
///TSI Port Mode
typedef enum
{
V1TsiPortModeSlave = 0x0,
V1TsiPortModeMaster = 0x1,
V1TsiPortModeNotSet = 0xFF
} V1TsiPortMode;
///I2S Port drive mode
typedef enum
{
V1I2sClockModeOutput = 0,
V1I2sClockModeInput = 1,
V1I2sClockModeIsocOutput = 2,
V1I2sClockModeIsocInput = 3,
V1I2sClockModeUnknown = 0xFE,
} V1I2SPortClkDriveMode_t;
///I2S Streaming Port mode
typedef enum
{
V1I2sStreamingPortInOut = 0,
V1I2sStreamingPortDualIn = 1,
V1I2sStreamingPortDualOut = 2,
V1I2sStreamingPortFullStream = 3,
V1I2sStreamingPortUnknown = 0xFE,
V1I2sStreamingPortWildcard = 0xFF ///Only valid for OS81110
} V1I2SStreamingPortMode_t;
///I2S Port streaming data format
typedef enum
{
V1I2sDelay64Fs16Bit = 0x00,
V1I2sDelay64Fs24Bit = 0x01,
V1I2sDelay64FsSeq = 0x04,
V1I2sDelay128FsSeq = 0x05,
V1I2sDelay256FsSeq = 0x06,
V1I2sRight64Fs16Bit = 0x07,
V1I2sRight64Fs24Bit = 0x08,
V1I2sSeq64Fs = 0x0B,
V1I2sSeq128Fs = 0x0C,
V1I2sSeq256Fs = 0x0D,
V1I2sLeft64Fs16Bit = 0x0E,
V1I2sLeft64Fs24Bit = 0x0F,
V1I2sDelay512FsSeq = 0x17,
V1I2sSeq512Fs = 0x18,
V1I2sDataFormatUnknown = 0xFE,
} V1I2SStreamingDataFormat_t;
///I2S Stream Pin ID
typedef enum
{
V1I2sSR0Pin = 0x00,
V1I2sSX0Pin = 0x01,
V1I2sSR1Pin = 0x02,
V1I2sSX1Pin = 0x03,
V1I2sSR2Pin = 0x04,
V1I2sSX2Pin = 0x05,
V1I2sSR3Pin = 0x06,
V1I2sSX3Pin = 0x07,
V1I2sFSYSCKPins = 0x10,
V1I2sInvalidPin = 0xFE,
} V1I2SPin_t;
///I2S Port option
typedef enum
{
V3I2SOptionInOut = 0,
V3I2SOptionDualIn = 1,
V3I2SOptionDualOut = 2,
V3I2SOptionUnknown = 0xFE
} V3I2SPortOption_t;
///I2S Clock mode
typedef enum
{
V3I2SClockModeOutput = 0,
V3I2SClockModeInput = 1,
V3I2SClockModeWildcard = 0xFF,
V3I2SClockModeUnknown = 0xFE
} V3I2SClockMode_t;
///I2S Delay option
typedef enum
{
V3I2SDelayOff = 0,
V3I2SDelayEnabled = 1,
V3I2SDelayWildcard = 0xFF,
V3I2SDelayUnknown = 0xFE
} V3I2SDelayMode_t;
///I2S Port speed in mulitple of MOST base clock (FS)
typedef enum
{
V3I2SSpeed64FS = 3,
V3I2SSpeed128FS = 4,
V3I2SSpeed256FS = 5,
V3I2SSpeed512FS = 6,
V3I2SSpeedWildcard = 0xFF,
V3I2SSpeedUnknown = 0xFE
} V3I2SPortSpeed_t;
///I2S Data Alignment
typedef enum
{
V3I2SAlignLeft16 = 0,
V3I2SAlignLeft24 = 1,
V3I2SAlignRight16 = 2,
V3I2SAlignRight24 = 3,
V3I2SAlignSeq = 4,
V3I2SAlignUnknown = 0xFE
} V3I2SAlignment_t;
///I2S Stream Pin ID
typedef enum
{
V3I2SSRXA0 = 0x0,
V3I2SSRXA1 = 0x1,
V3I2SSRXB0 = 0x10,
V3I2SSRXB1 = 0x11,
V3I2SInvalidPin = 0xFE
} V3I2SPin_t;
#endif