Commit abfc768d authored by Lior Dotan's avatar Lior Dotan Committed by Greg Kroah-Hartman

Staging: crystalhd: Remove typedefs from driver

Remove typedefs from driver
Signed-of-by: default avatarLior Dotan <liodot@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 973267a2
...@@ -26,12 +26,10 @@ ...@@ -26,12 +26,10 @@
#ifndef _BC_DTS_DEFS_H_ #ifndef _BC_DTS_DEFS_H_
#define _BC_DTS_DEFS_H_ #define _BC_DTS_DEFS_H_
#include "bc_dts_types.h"
/* BIT Mask */ /* BIT Mask */
#define BC_BIT(_x) (1 << (_x)) #define BC_BIT(_x) (1 << (_x))
typedef enum _BC_STATUS { enum BC_STATUS {
BC_STS_SUCCESS = 0, BC_STS_SUCCESS = 0,
BC_STS_INV_ARG = 1, BC_STS_INV_ARG = 1,
BC_STS_BUSY = 2, BC_STS_BUSY = 2,
...@@ -62,7 +60,7 @@ typedef enum _BC_STATUS { ...@@ -62,7 +60,7 @@ typedef enum _BC_STATUS {
/* Must be the last one.*/ /* Must be the last one.*/
BC_STS_ERROR = -1 BC_STS_ERROR = -1
} BC_STATUS; };
/*------------------------------------------------------* /*------------------------------------------------------*
* Registry Key Definitions * * Registry Key Definitions *
...@@ -81,14 +79,14 @@ typedef enum _BC_STATUS { ...@@ -81,14 +79,14 @@ typedef enum _BC_STATUS {
* *
*/ */
typedef enum _BC_SW_OPTIONS { enum BC_SW_OPTIONS {
BC_OPT_DOSER_OUT_ENCRYPT = BC_BIT(3), BC_OPT_DOSER_OUT_ENCRYPT = BC_BIT(3),
BC_OPT_LINK_OUT_ENCRYPT = BC_BIT(29), BC_OPT_LINK_OUT_ENCRYPT = BC_BIT(29),
} BC_SW_OPTIONS; };
typedef struct _BC_REG_CONFIG{ struct BC_REG_CONFIG{
uint32_t DbgOptions; uint32_t DbgOptions;
} BC_REG_CONFIG; };
#if defined(__KERNEL__) || defined(__LINUX_USER__) #if defined(__KERNEL__) || defined(__LINUX_USER__)
#else #else
...@@ -108,7 +106,7 @@ typedef struct _BC_REG_CONFIG{ ...@@ -108,7 +106,7 @@ typedef struct _BC_REG_CONFIG{
*/ */
/* To allow multiple apps to open the device. */ /* To allow multiple apps to open the device. */
enum _DtsDeviceOpenMode { enum DtsDeviceOpenMode {
DTS_PLAYBACK_MODE = 0, DTS_PLAYBACK_MODE = 0,
DTS_DIAG_MODE, DTS_DIAG_MODE,
DTS_MONITOR_MODE, DTS_MONITOR_MODE,
...@@ -116,7 +114,7 @@ enum _DtsDeviceOpenMode { ...@@ -116,7 +114,7 @@ enum _DtsDeviceOpenMode {
}; };
/* To enable the filter to selectively enable/disable fixes or erratas */ /* To enable the filter to selectively enable/disable fixes or erratas */
enum _DtsDeviceFixMode { enum DtsDeviceFixMode {
DTS_LOAD_NEW_FW = BC_BIT(8), DTS_LOAD_NEW_FW = BC_BIT(8),
DTS_LOAD_FILE_PLAY_FW = BC_BIT(9), DTS_LOAD_FILE_PLAY_FW = BC_BIT(9),
DTS_DISK_FMT_BD = BC_BIT(10), DTS_DISK_FMT_BD = BC_BIT(10),
...@@ -133,7 +131,7 @@ enum _DtsDeviceFixMode { ...@@ -133,7 +131,7 @@ enum _DtsDeviceFixMode {
#define DTS_DFLT_CLOCK(x) (x<<19) #define DTS_DFLT_CLOCK(x) (x<<19)
/* F/W File Version corresponding to S/W Releases */ /* F/W File Version corresponding to S/W Releases */
enum _FW_FILE_VER { enum FW_FILE_VER {
/* S/W release: 02.04.02 F/W release 2.12.2.0 */ /* S/W release: 02.04.02 F/W release 2.12.2.0 */
BC_FW_VER_020402 = ((12<<16) | (2<<8) | (0)) BC_FW_VER_020402 = ((12<<16) | (2<<8) | (0))
}; };
...@@ -141,7 +139,7 @@ enum _FW_FILE_VER { ...@@ -141,7 +139,7 @@ enum _FW_FILE_VER {
/*------------------------------------------------------* /*------------------------------------------------------*
* Stream Types for DtsOpenDecoder() * * Stream Types for DtsOpenDecoder() *
*------------------------------------------------------*/ *------------------------------------------------------*/
enum _DtsOpenDecStreamTypes { enum DtsOpenDecStreamTypes {
BC_STREAM_TYPE_ES = 0, BC_STREAM_TYPE_ES = 0,
BC_STREAM_TYPE_PES = 1, BC_STREAM_TYPE_PES = 1,
BC_STREAM_TYPE_TS = 2, BC_STREAM_TYPE_TS = 2,
...@@ -151,7 +149,7 @@ enum _DtsOpenDecStreamTypes { ...@@ -151,7 +149,7 @@ enum _DtsOpenDecStreamTypes {
/*------------------------------------------------------* /*------------------------------------------------------*
* Video Algorithms for DtsSetVideoParams() * * Video Algorithms for DtsSetVideoParams() *
*------------------------------------------------------*/ *------------------------------------------------------*/
enum _DtsSetVideoParamsAlgo { enum DtsSetVideoParamsAlgo {
BC_VID_ALGO_H264 = 0, BC_VID_ALGO_H264 = 0,
BC_VID_ALGO_MPEG2 = 1, BC_VID_ALGO_MPEG2 = 1,
BC_VID_ALGO_VC1 = 4, BC_VID_ALGO_VC1 = 4,
...@@ -163,7 +161,7 @@ enum _DtsSetVideoParamsAlgo { ...@@ -163,7 +161,7 @@ enum _DtsSetVideoParamsAlgo {
*------------------------------------------------------*/ *------------------------------------------------------*/
#define BC_MPEG_VALID_PANSCAN (1) #define BC_MPEG_VALID_PANSCAN (1)
typedef struct _BC_PIB_EXT_MPEG { struct BC_PIB_EXT_MPEG {
uint32_t valid; uint32_t valid;
/* Always valid, defaults to picture size if no /* Always valid, defaults to picture size if no
* sequence display extension in the stream. */ * sequence display extension in the stream. */
...@@ -175,8 +173,7 @@ typedef struct _BC_PIB_EXT_MPEG { ...@@ -175,8 +173,7 @@ typedef struct _BC_PIB_EXT_MPEG {
uint32_t offset_count; uint32_t offset_count;
int32_t horizontal_offset[3]; int32_t horizontal_offset[3];
int32_t vertical_offset[3]; int32_t vertical_offset[3];
};
} BC_PIB_EXT_MPEG;
/*------------------------------------------------------* /*------------------------------------------------------*
* H.264 Extension to the PPB * * H.264 Extension to the PPB *
...@@ -186,7 +183,7 @@ typedef struct _BC_PIB_EXT_MPEG { ...@@ -186,7 +183,7 @@ typedef struct _BC_PIB_EXT_MPEG {
#define H264_VALID_SPS_CROP (2) #define H264_VALID_SPS_CROP (2)
#define H264_VALID_VUI (4) #define H264_VALID_VUI (4)
typedef struct _BC_PIB_EXT_H264 { struct BC_PIB_EXT_H264 {
/* 'valid' specifies which fields (or sets of /* 'valid' specifies which fields (or sets of
* fields) below are valid. If the corresponding * fields) below are valid. If the corresponding
* bit in 'valid' is NOT set then that field(s) * bit in 'valid' is NOT set then that field(s)
...@@ -209,15 +206,14 @@ typedef struct _BC_PIB_EXT_H264 { ...@@ -209,15 +206,14 @@ typedef struct _BC_PIB_EXT_H264 {
/* H264_VALID_VUI */ /* H264_VALID_VUI */
uint32_t chroma_top; uint32_t chroma_top;
uint32_t chroma_bottom; uint32_t chroma_bottom;
};
} BC_PIB_EXT_H264;
/*------------------------------------------------------* /*------------------------------------------------------*
* VC1 Extension to the PPB * * VC1 Extension to the PPB *
*------------------------------------------------------*/ *------------------------------------------------------*/
#define VC1_VALID_PANSCAN (1) #define VC1_VALID_PANSCAN (1)
typedef struct _BC_PIB_EXT_VC1 { struct BC_PIB_EXT_VC1 {
uint32_t valid; uint32_t valid;
/* Always valid, defaults to picture size if no /* Always valid, defaults to picture size if no
...@@ -231,9 +227,7 @@ typedef struct _BC_PIB_EXT_VC1 { ...@@ -231,9 +227,7 @@ typedef struct _BC_PIB_EXT_VC1 {
int32_t ps_vert_offset[4]; int32_t ps_vert_offset[4];
int32_t ps_width[4]; int32_t ps_width[4];
int32_t ps_height[4]; int32_t ps_height[4];
};
} BC_PIB_EXT_VC1;
/*------------------------------------------------------* /*------------------------------------------------------*
* Picture Information Block * * Picture Information Block *
...@@ -366,7 +360,7 @@ enum _BC_OUTPUT_FORMAT { ...@@ -366,7 +360,7 @@ enum _BC_OUTPUT_FORMAT {
MODE422_UYVY = 0x2, MODE422_UYVY = 0x2,
}; };
typedef struct _BC_PIC_INFO_BLOCK { struct BC_PIC_INFO_BLOCK {
/* Common fields. */ /* Common fields. */
uint64_t timeStamp; /* Timestamp */ uint64_t timeStamp; /* Timestamp */
uint32_t picture_number; /* Ordinal display number */ uint32_t picture_number; /* Ordinal display number */
...@@ -386,18 +380,18 @@ typedef struct _BC_PIC_INFO_BLOCK { ...@@ -386,18 +380,18 @@ typedef struct _BC_PIC_INFO_BLOCK {
/* Protocol-specific extensions. */ /* Protocol-specific extensions. */
union { union {
BC_PIB_EXT_H264 h264; struct BC_PIB_EXT_H264 h264;
BC_PIB_EXT_MPEG mpeg; struct BC_PIB_EXT_MPEG mpeg;
BC_PIB_EXT_VC1 vc1; struct BC_PIB_EXT_VC1 vc1;
} other; } other;
} BC_PIC_INFO_BLOCK, *PBC_PIC_INFO_BLOCK; };
/*------------------------------------------------------* /*------------------------------------------------------*
* ProcOut Info * * ProcOut Info *
*------------------------------------------------------*/ *------------------------------------------------------*/
/* Optional flags for ProcOut Interface.*/ /* Optional flags for ProcOut Interface.*/
enum _POUT_OPTIONAL_IN_FLAGS_{ enum POUT_OPTIONAL_IN_FLAGS_{
/* Flags from App to Device */ /* Flags from App to Device */
BC_POUT_FLAGS_YV12 = 0x01, /* Copy Data in YV12 format */ BC_POUT_FLAGS_YV12 = 0x01, /* Copy Data in YV12 format */
BC_POUT_FLAGS_STRIDE = 0x02, /* Stride size is valid. */ BC_POUT_FLAGS_STRIDE = 0x02, /* Stride size is valid. */
...@@ -412,17 +406,13 @@ enum _POUT_OPTIONAL_IN_FLAGS_{ ...@@ -412,17 +406,13 @@ enum _POUT_OPTIONAL_IN_FLAGS_{
BC_POUT_FLAGS_FLD_BOT = 0x80000, /* Bottom Field data */ BC_POUT_FLAGS_FLD_BOT = 0x80000, /* Bottom Field data */
}; };
#if defined(__KERNEL__) || defined(__LINUX_USER__) typedef enum BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, void *pOut);
typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, void *pOut);
#else
typedef BC_STATUS(*dts_pout_callback)(void *shnd, uint32_t width, uint32_t height, uint32_t stride, struct _BC_DTS_PROC_OUT *pOut);
#endif
/* Line 21 Closed Caption */ /* Line 21 Closed Caption */
/* User Data */ /* User Data */
#define MAX_UD_SIZE 1792 /* 1920 - 128 */ #define MAX_UD_SIZE 1792 /* 1920 - 128 */
typedef struct _BC_DTS_PROC_OUT { struct BC_DTS_PROC_OUT {
uint8_t *Ybuff; /* Caller Supplied buffer for Y data */ uint8_t *Ybuff; /* Caller Supplied buffer for Y data */
uint32_t YbuffSz; /* Caller Supplied Y buffer size */ uint32_t YbuffSz; /* Caller Supplied Y buffer size */
uint32_t YBuffDoneSz; /* Transferred Y datasize */ uint32_t YBuffDoneSz; /* Transferred Y datasize */
...@@ -436,7 +426,7 @@ typedef struct _BC_DTS_PROC_OUT { ...@@ -436,7 +426,7 @@ typedef struct _BC_DTS_PROC_OUT {
uint32_t discCnt; /* Picture discontinuity count */ uint32_t discCnt; /* Picture discontinuity count */
BC_PIC_INFO_BLOCK PicInfo; /* Picture Information Block Data */ struct BC_PIC_INFO_BLOCK PicInfo; /* Picture Information Block Data */
/* Line 21 Closed Caption */ /* Line 21 Closed Caption */
/* User Data */ /* User Data */
...@@ -450,9 +440,9 @@ typedef struct _BC_DTS_PROC_OUT { ...@@ -450,9 +440,9 @@ typedef struct _BC_DTS_PROC_OUT {
uint8_t bPibEnc; /* PIB encrypted */ uint8_t bPibEnc; /* PIB encrypted */
uint8_t bRevertScramble; uint8_t bRevertScramble;
} BC_DTS_PROC_OUT; };
typedef struct _BC_DTS_STATUS { struct BC_DTS_STATUS {
uint8_t ReadyListCount; /* Number of frames in ready list (reported by driver) */ uint8_t ReadyListCount; /* Number of frames in ready list (reported by driver) */
uint8_t FreeListCount; /* Number of frame buffers free. (reported by driver) */ uint8_t FreeListCount; /* Number of frame buffers free. (reported by driver) */
uint8_t PowerStateChange; /* Number of active state power transitions (reported by driver) */ uint8_t PowerStateChange; /* Number of active state power transitions (reported by driver) */
...@@ -479,7 +469,7 @@ typedef struct _BC_DTS_STATUS { ...@@ -479,7 +469,7 @@ typedef struct _BC_DTS_STATUS {
* back from the driver */ * back from the driver */
uint8_t reserved__[16]; uint8_t reserved__[16];
} BC_DTS_STATUS; };
#define BC_SWAP32(_v) \ #define BC_SWAP32(_v) \
((((_v) & 0xFF000000)>>24)| \ ((((_v) & 0xFF000000)>>24)| \
......
...@@ -58,7 +58,7 @@ ...@@ -58,7 +58,7 @@
* These are SW stack tunable parameters shared * These are SW stack tunable parameters shared
* between the driver and the application. * between the driver and the application.
*/ */
enum _BC_DTS_GLOBALS { enum BC_DTS_GLOBALS {
BC_MAX_FW_CMD_BUFF_SZ = 0x40, /* FW passthrough cmd/rsp buffer size */ BC_MAX_FW_CMD_BUFF_SZ = 0x40, /* FW passthrough cmd/rsp buffer size */
PCI_CFG_SIZE = 256, /* PCI config size buffer */ PCI_CFG_SIZE = 256, /* PCI config size buffer */
BC_IOCTL_DATA_POOL_SIZE = 8, /* BC_IOCTL_DATA Pool size */ BC_IOCTL_DATA_POOL_SIZE = 8, /* BC_IOCTL_DATA Pool size */
...@@ -70,62 +70,62 @@ enum _BC_DTS_GLOBALS { ...@@ -70,62 +70,62 @@ enum _BC_DTS_GLOBALS {
BC_INFIFO_THRESHOLD = 0x10000, BC_INFIFO_THRESHOLD = 0x10000,
}; };
typedef struct _BC_CMD_REG_ACC { struct BC_CMD_REG_ACC {
uint32_t Offset; uint32_t Offset;
uint32_t Value; uint32_t Value;
} BC_CMD_REG_ACC; };
typedef struct _BC_CMD_DEV_MEM { struct BC_CMD_DEV_MEM {
uint32_t StartOff; uint32_t StartOff;
uint32_t NumDwords; uint32_t NumDwords;
uint32_t Rsrd; uint32_t Rsrd;
} BC_CMD_DEV_MEM; };
/* FW Passthrough command structure */ /* FW Passthrough command structure */
enum _bc_fw_cmd_flags { enum bc_fw_cmd_flags {
BC_FW_CMD_FLAGS_NONE = 0, BC_FW_CMD_FLAGS_NONE = 0,
BC_FW_CMD_PIB_QS = 0x01, BC_FW_CMD_PIB_QS = 0x01,
}; };
typedef struct _BC_FW_CMD { struct BC_FW_CMD {
uint32_t cmd[BC_MAX_FW_CMD_BUFF_SZ]; uint32_t cmd[BC_MAX_FW_CMD_BUFF_SZ];
uint32_t rsp[BC_MAX_FW_CMD_BUFF_SZ]; uint32_t rsp[BC_MAX_FW_CMD_BUFF_SZ];
uint32_t flags; uint32_t flags;
uint32_t add_data; uint32_t add_data;
} BC_FW_CMD, *PBC_FW_CMD; };
typedef struct _BC_HW_TYPE { struct BC_HW_TYPE {
uint16_t PciDevId; uint16_t PciDevId;
uint16_t PciVenId; uint16_t PciVenId;
uint8_t HwRev; uint8_t HwRev;
uint8_t Align[3]; uint8_t Align[3];
} BC_HW_TYPE; };
typedef struct _BC_PCI_CFG { struct BC_PCI_CFG {
uint32_t Size; uint32_t Size;
uint32_t Offset; uint32_t Offset;
uint8_t pci_cfg_space[PCI_CFG_SIZE]; uint8_t pci_cfg_space[PCI_CFG_SIZE];
} BC_PCI_CFG; };
typedef struct _BC_VERSION_INFO_ { struct BC_VERSION_INFO {
uint8_t DriverMajor; uint8_t DriverMajor;
uint8_t DriverMinor; uint8_t DriverMinor;
uint16_t DriverRevision; uint16_t DriverRevision;
} BC_VERSION_INFO; };
typedef struct _BC_START_RX_CAP_ { struct BC_START_RX_CAP {
uint32_t Rsrd; uint32_t Rsrd;
uint32_t StartDeliveryThsh; uint32_t StartDeliveryThsh;
uint32_t PauseThsh; uint32_t PauseThsh;
uint32_t ResumeThsh; uint32_t ResumeThsh;
} BC_START_RX_CAP; };
typedef struct _BC_FLUSH_RX_CAP_ { struct BC_FLUSH_RX_CAP {
uint32_t Rsrd; uint32_t Rsrd;
uint32_t bDiscardOnly; uint32_t bDiscardOnly;
} BC_FLUSH_RX_CAP; };
typedef struct _BC_DTS_STATS { struct BC_DTS_STATS {
uint8_t drvRLL; uint8_t drvRLL;
uint8_t drvFLL; uint8_t drvFLL;
uint8_t eosDetected; uint8_t eosDetected;
...@@ -154,18 +154,18 @@ typedef struct _BC_DTS_STATS { ...@@ -154,18 +154,18 @@ typedef struct _BC_DTS_STATS {
uint32_t DrvRepeatedFrms; uint32_t DrvRepeatedFrms;
uint32_t res1[13]; uint32_t res1[13];
} BC_DTS_STATS; };
typedef struct _BC_PROC_INPUT_ { struct BC_PROC_INPUT {
uint8_t *pDmaBuff; uint8_t *pDmaBuff;
uint32_t BuffSz; uint32_t BuffSz;
uint8_t Mapped; uint8_t Mapped;
uint8_t Encrypted; uint8_t Encrypted;
uint8_t Rsrd[2]; uint8_t Rsrd[2];
uint32_t DramOffset; /* For debug use only */ uint32_t DramOffset; /* For debug use only */
} BC_PROC_INPUT, *PBC_PROC_INPUT; };
typedef struct _BC_DEC_YUV_BUFFS { struct BC_DEC_YUV_BUFFS {
uint32_t b422Mode; uint32_t b422Mode;
uint8_t *YuvBuff; uint8_t *YuvBuff;
uint32_t YuvBuffSz; uint32_t YuvBuffSz;
...@@ -173,9 +173,9 @@ typedef struct _BC_DEC_YUV_BUFFS { ...@@ -173,9 +173,9 @@ typedef struct _BC_DEC_YUV_BUFFS {
uint32_t YBuffDoneSz; uint32_t YBuffDoneSz;
uint32_t UVBuffDoneSz; uint32_t UVBuffDoneSz;
uint32_t RefCnt; uint32_t RefCnt;
} BC_DEC_YUV_BUFFS; };
enum _DECOUT_COMPLETION_FLAGS{ enum DECOUT_COMPLETION_FLAGS{
COMP_FLAG_NO_INFO = 0x00, COMP_FLAG_NO_INFO = 0x00,
COMP_FLAG_FMT_CHANGE = 0x01, COMP_FLAG_FMT_CHANGE = 0x01,
COMP_FLAG_PIB_VALID = 0x02, COMP_FLAG_PIB_VALID = 0x02,
...@@ -184,47 +184,47 @@ enum _DECOUT_COMPLETION_FLAGS{ ...@@ -184,47 +184,47 @@ enum _DECOUT_COMPLETION_FLAGS{
COMP_FLAG_DATA_BOT = 0x10, COMP_FLAG_DATA_BOT = 0x10,
}; };
typedef struct _BC_DEC_OUT_BUFF{ struct BC_DEC_OUT_BUFF{
BC_DEC_YUV_BUFFS OutPutBuffs; struct BC_DEC_YUV_BUFFS OutPutBuffs;
BC_PIC_INFO_BLOCK PibInfo; struct BC_PIC_INFO_BLOCK PibInfo;
uint32_t Flags; uint32_t Flags;
uint32_t BadFrCnt; uint32_t BadFrCnt;
} BC_DEC_OUT_BUFF; };
typedef struct _BC_NOTIFY_MODE { struct BC_NOTIFY_MODE {
uint32_t Mode; uint32_t Mode;
uint32_t Rsvr[3]; uint32_t Rsvr[3];
} BC_NOTIFY_MODE; };
typedef struct _BC_CLOCK { struct BC_CLOCK {
uint32_t clk; uint32_t clk;
uint32_t Rsvr[3]; uint32_t Rsvr[3];
} BC_CLOCK; };
typedef struct _BC_IOCTL_DATA { struct BC_IOCTL_DATA {
BC_STATUS RetSts; enum BC_STATUS RetSts;
uint32_t IoctlDataSz; uint32_t IoctlDataSz;
uint32_t Timeout; uint32_t Timeout;
union { union {
BC_CMD_REG_ACC regAcc; struct BC_CMD_REG_ACC regAcc;
BC_CMD_DEV_MEM devMem; struct BC_CMD_DEV_MEM devMem;
BC_FW_CMD fwCmd; struct BC_FW_CMD fwCmd;
BC_HW_TYPE hwType; struct BC_HW_TYPE hwType;
BC_PCI_CFG pciCfg; struct BC_PCI_CFG pciCfg;
BC_VERSION_INFO VerInfo; struct BC_VERSION_INFO VerInfo;
BC_PROC_INPUT ProcInput; struct BC_PROC_INPUT ProcInput;
BC_DEC_YUV_BUFFS RxBuffs; struct BC_DEC_YUV_BUFFS RxBuffs;
BC_DEC_OUT_BUFF DecOutData; struct BC_DEC_OUT_BUFF DecOutData;
BC_START_RX_CAP RxCap; struct BC_START_RX_CAP RxCap;
BC_FLUSH_RX_CAP FlushRxCap; struct BC_FLUSH_RX_CAP FlushRxCap;
BC_DTS_STATS drvStat; struct BC_DTS_STATS drvStat;
BC_NOTIFY_MODE NotifyMode; struct BC_NOTIFY_MODE NotifyMode;
BC_CLOCK clockValue; struct BC_CLOCK clockValue;
} u; } u;
struct _BC_IOCTL_DATA *next; struct _BC_IOCTL_DATA *next;
} BC_IOCTL_DATA; };
typedef enum _BC_DRV_CMD{ enum BC_DRV_CMD {
DRV_CMD_VERSION = 0, /* Get SW version */ DRV_CMD_VERSION = 0, /* Get SW version */
DRV_CMD_GET_HWTYPE, /* Get HW version and type Dozer/Tank */ DRV_CMD_GET_HWTYPE, /* Get HW version and type Dozer/Tank */
DRV_CMD_REG_RD, /* Read Device Register */ DRV_CMD_REG_RD, /* Read Device Register */
...@@ -249,12 +249,12 @@ typedef enum _BC_DRV_CMD{ ...@@ -249,12 +249,12 @@ typedef enum _BC_DRV_CMD{
/* MUST be the last one.. */ /* MUST be the last one.. */
DRV_CMD_END, /* End of the List.. */ DRV_CMD_END, /* End of the List.. */
} BC_DRV_CMD; };
#define BC_IOC_BASE 'b' #define BC_IOC_BASE 'b'
#define BC_IOC_VOID _IOC_NONE #define BC_IOC_VOID _IOC_NONE
#define BC_IOC_IOWR(nr, type) _IOWR(BC_IOC_BASE, nr, type) #define BC_IOC_IOWR(nr, type) _IOWR(BC_IOC_BASE, nr, type)
#define BC_IOCTL_MB BC_IOCTL_DATA #define BC_IOCTL_MB struct BC_IOCTL_DATA
#define BCM_IOC_GET_VERSION BC_IOC_IOWR(DRV_CMD_VERSION, BC_IOCTL_MB) #define BCM_IOC_GET_VERSION BC_IOC_IOWR(DRV_CMD_VERSION, BC_IOCTL_MB)
#define BCM_IOC_GET_HWTYPE BC_IOC_IOWR(DRV_CMD_GET_HWTYPE, BC_IOCTL_MB) #define BCM_IOC_GET_HWTYPE BC_IOC_IOWR(DRV_CMD_GET_HWTYPE, BC_IOCTL_MB)
...@@ -280,17 +280,16 @@ typedef enum _BC_DRV_CMD{ ...@@ -280,17 +280,16 @@ typedef enum _BC_DRV_CMD{
#define BCM_IOC_END BC_IOC_VOID #define BCM_IOC_END BC_IOC_VOID
/* Wrapper for main IOCTL data */ /* Wrapper for main IOCTL data */
typedef struct _crystalhd_ioctl_data { struct crystalhd_ioctl_data {
BC_IOCTL_DATA udata; /* IOCTL from App..*/ struct BC_IOCTL_DATA udata; /* IOCTL from App..*/
uint32_t u_id; /* Driver specific user ID */ uint32_t u_id; /* Driver specific user ID */
uint32_t cmd; /* Cmd ID for driver's use. */ uint32_t cmd; /* Cmd ID for driver's use. */
void *add_cdata; /* Additional command specific data..*/ void *add_cdata; /* Additional command specific data..*/
uint32_t add_cdata_sz; /* Additional command specific data size */ uint32_t add_cdata_sz; /* Additional command specific data size */
struct _crystalhd_ioctl_data *next; /* List/Fifo management */ struct crystalhd_ioctl_data *next; /* List/Fifo management */
} crystalhd_ioctl_data; };
enum _crystalhd_kmod_ver{ enum crystalhd_kmod_ver{
crystalhd_kmod_major = 0, crystalhd_kmod_major = 0,
crystalhd_kmod_minor = 9, crystalhd_kmod_minor = 9,
crystalhd_kmod_rev = 27, crystalhd_kmod_rev = 27,
......
...@@ -69,8 +69,8 @@ static void bc_cproc_mark_pwr_state(struct crystalhd_cmd *ctx) ...@@ -69,8 +69,8 @@ static void bc_cproc_mark_pwr_state(struct crystalhd_cmd *ctx)
} }
} }
static BC_STATUS bc_cproc_notify_mode(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_notify_mode(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
int rc = 0, i = 0; int rc = 0, i = 0;
...@@ -111,8 +111,8 @@ static BC_STATUS bc_cproc_notify_mode(struct crystalhd_cmd *ctx, ...@@ -111,8 +111,8 @@ static BC_STATUS bc_cproc_notify_mode(struct crystalhd_cmd *ctx,
return crystalhd_hw_setup_dma_rings(&ctx->hw_ctx); return crystalhd_hw_setup_dma_rings(&ctx->hw_ctx);
} }
static BC_STATUS bc_cproc_get_version(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_get_version(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) { if (!ctx || !idata) {
...@@ -126,7 +126,8 @@ static BC_STATUS bc_cproc_get_version(struct crystalhd_cmd *ctx, ...@@ -126,7 +126,8 @@ static BC_STATUS bc_cproc_get_version(struct crystalhd_cmd *ctx,
} }
static BC_STATUS bc_cproc_get_hwtype(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *idata) static enum BC_STATUS bc_cproc_get_hwtype(struct crystalhd_cmd *ctx,
struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -143,8 +144,8 @@ static BC_STATUS bc_cproc_get_hwtype(struct crystalhd_cmd *ctx, crystalhd_ioctl_ ...@@ -143,8 +144,8 @@ static BC_STATUS bc_cproc_get_hwtype(struct crystalhd_cmd *ctx, crystalhd_ioctl_
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_reg_rd(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_reg_rd(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) if (!ctx || !idata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -153,8 +154,8 @@ static BC_STATUS bc_cproc_reg_rd(struct crystalhd_cmd *ctx, ...@@ -153,8 +154,8 @@ static BC_STATUS bc_cproc_reg_rd(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_reg_wr(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_reg_wr(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) if (!ctx || !idata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -165,8 +166,8 @@ static BC_STATUS bc_cproc_reg_wr(struct crystalhd_cmd *ctx, ...@@ -165,8 +166,8 @@ static BC_STATUS bc_cproc_reg_wr(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_link_reg_rd(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_link_reg_rd(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) if (!ctx || !idata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -176,8 +177,8 @@ static BC_STATUS bc_cproc_link_reg_rd(struct crystalhd_cmd *ctx, ...@@ -176,8 +177,8 @@ static BC_STATUS bc_cproc_link_reg_rd(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_link_reg_wr(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_link_reg_wr(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
if (!ctx || !idata) if (!ctx || !idata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -188,10 +189,10 @@ static BC_STATUS bc_cproc_link_reg_wr(struct crystalhd_cmd *ctx, ...@@ -188,10 +189,10 @@ static BC_STATUS bc_cproc_link_reg_wr(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_mem_rd(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_mem_rd(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata || !idata->add_cdata) if (!ctx || !idata || !idata->add_cdata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -207,10 +208,10 @@ static BC_STATUS bc_cproc_mem_rd(struct crystalhd_cmd *ctx, ...@@ -207,10 +208,10 @@ static BC_STATUS bc_cproc_mem_rd(struct crystalhd_cmd *ctx,
} }
static BC_STATUS bc_cproc_mem_wr(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_mem_wr(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata || !idata->add_cdata) if (!ctx || !idata || !idata->add_cdata)
return BC_STS_INV_ARG; return BC_STS_INV_ARG;
...@@ -226,11 +227,11 @@ static BC_STATUS bc_cproc_mem_wr(struct crystalhd_cmd *ctx, ...@@ -226,11 +227,11 @@ static BC_STATUS bc_cproc_mem_wr(struct crystalhd_cmd *ctx,
return sts; return sts;
} }
static BC_STATUS bc_cproc_cfg_rd(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_cfg_rd(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
uint32_t ix, cnt, off, len; uint32_t ix, cnt, off, len;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
uint32_t *temp; uint32_t *temp;
if (!ctx || !idata) if (!ctx || !idata)
...@@ -258,11 +259,11 @@ static BC_STATUS bc_cproc_cfg_rd(struct crystalhd_cmd *ctx, ...@@ -258,11 +259,11 @@ static BC_STATUS bc_cproc_cfg_rd(struct crystalhd_cmd *ctx,
return sts; return sts;
} }
static BC_STATUS bc_cproc_cfg_wr(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_cfg_wr(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
uint32_t ix, cnt, off, len; uint32_t ix, cnt, off, len;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
uint32_t *temp; uint32_t *temp;
if (!ctx || !idata) if (!ctx || !idata)
...@@ -290,10 +291,10 @@ static BC_STATUS bc_cproc_cfg_wr(struct crystalhd_cmd *ctx, ...@@ -290,10 +291,10 @@ static BC_STATUS bc_cproc_cfg_wr(struct crystalhd_cmd *ctx,
return sts; return sts;
} }
static BC_STATUS bc_cproc_download_fw(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_download_fw(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata || !idata->add_cdata || !idata->add_cdata_sz) { if (!ctx || !idata || !idata->add_cdata || !idata->add_cdata_sz) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -329,9 +330,10 @@ static BC_STATUS bc_cproc_download_fw(struct crystalhd_cmd *ctx, ...@@ -329,9 +330,10 @@ static BC_STATUS bc_cproc_download_fw(struct crystalhd_cmd *ctx,
* Abort pending input transfers and issue decoder flush command. * Abort pending input transfers and issue decoder flush command.
* *
*/ */
static BC_STATUS bc_cproc_do_fw_cmd(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *idata) static enum BC_STATUS bc_cproc_do_fw_cmd(struct crystalhd_cmd *ctx,
struct crystalhd_ioctl_data *idata)
{ {
BC_STATUS sts; enum BC_STATUS sts;
uint32_t *cmd; uint32_t *cmd;
if (!(ctx->state & BC_LINK_INIT)) { if (!(ctx->state & BC_LINK_INIT)) {
...@@ -371,8 +373,8 @@ static BC_STATUS bc_cproc_do_fw_cmd(struct crystalhd_cmd *ctx, crystalhd_ioctl_d ...@@ -371,8 +373,8 @@ static BC_STATUS bc_cproc_do_fw_cmd(struct crystalhd_cmd *ctx, crystalhd_ioctl_d
return sts; return sts;
} }
static void bc_proc_in_completion(crystalhd_dio_req *dio_hnd, static void bc_proc_in_completion(struct crystalhd_dio_req *dio_hnd,
wait_queue_head_t *event, BC_STATUS sts) wait_queue_head_t *event, enum BC_STATUS sts)
{ {
if (!dio_hnd || !event) { if (!dio_hnd || !event) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -386,7 +388,7 @@ static void bc_proc_in_completion(crystalhd_dio_req *dio_hnd, ...@@ -386,7 +388,7 @@ static void bc_proc_in_completion(crystalhd_dio_req *dio_hnd,
crystalhd_set_event(event); crystalhd_set_event(event);
} }
static BC_STATUS bc_cproc_codein_sleep(struct crystalhd_cmd *ctx) static enum BC_STATUS bc_cproc_codein_sleep(struct crystalhd_cmd *ctx)
{ {
wait_queue_head_t sleep_ev; wait_queue_head_t sleep_ev;
int rc = 0; int rc = 0;
...@@ -406,12 +408,12 @@ static BC_STATUS bc_cproc_codein_sleep(struct crystalhd_cmd *ctx) ...@@ -406,12 +408,12 @@ static BC_STATUS bc_cproc_codein_sleep(struct crystalhd_cmd *ctx)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_hw_txdma(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_hw_txdma(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata, struct crystalhd_ioctl_data *idata,
crystalhd_dio_req *dio) struct crystalhd_dio_req *dio)
{ {
uint32_t tx_listid = 0; uint32_t tx_listid = 0;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
wait_queue_head_t event; wait_queue_head_t event;
int rc = 0; int rc = 0;
...@@ -471,7 +473,7 @@ static BC_STATUS bc_cproc_hw_txdma(struct crystalhd_cmd *ctx, ...@@ -471,7 +473,7 @@ static BC_STATUS bc_cproc_hw_txdma(struct crystalhd_cmd *ctx,
} }
/* Helper function to check on user buffers */ /* Helper function to check on user buffers */
static BC_STATUS bc_cproc_check_inbuffs(bool pin, void *ubuff, uint32_t ub_sz, static enum BC_STATUS bc_cproc_check_inbuffs(bool pin, void *ubuff, uint32_t ub_sz,
uint32_t uv_off, bool en_422) uint32_t uv_off, bool en_422)
{ {
if (!ubuff || !ub_sz) { if (!ubuff || !ub_sz) {
...@@ -502,12 +504,13 @@ static BC_STATUS bc_cproc_check_inbuffs(bool pin, void *ubuff, uint32_t ub_sz, ...@@ -502,12 +504,13 @@ static BC_STATUS bc_cproc_check_inbuffs(bool pin, void *ubuff, uint32_t ub_sz,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_proc_input(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *idata) static enum BC_STATUS bc_cproc_proc_input(struct crystalhd_cmd *ctx,
struct crystalhd_ioctl_data *idata)
{ {
void *ubuff; void *ubuff;
uint32_t ub_sz; uint32_t ub_sz;
crystalhd_dio_req *dio_hnd = NULL; struct crystalhd_dio_req *dio_hnd = NULL;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -537,14 +540,14 @@ static BC_STATUS bc_cproc_proc_input(struct crystalhd_cmd *ctx, crystalhd_ioctl_ ...@@ -537,14 +540,14 @@ static BC_STATUS bc_cproc_proc_input(struct crystalhd_cmd *ctx, crystalhd_ioctl_
return sts; return sts;
} }
static BC_STATUS bc_cproc_add_cap_buff(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_add_cap_buff(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
void *ubuff; void *ubuff;
uint32_t ub_sz, uv_off; uint32_t ub_sz, uv_off;
bool en_422; bool en_422;
crystalhd_dio_req *dio_hnd = NULL; struct crystalhd_dio_req *dio_hnd = NULL;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -579,10 +582,10 @@ static BC_STATUS bc_cproc_add_cap_buff(struct crystalhd_cmd *ctx, ...@@ -579,10 +582,10 @@ static BC_STATUS bc_cproc_add_cap_buff(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_fmt_change(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_fmt_change(struct crystalhd_cmd *ctx,
crystalhd_dio_req *dio) struct crystalhd_dio_req *dio)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
sts = crystalhd_hw_add_cap_buffer(&ctx->hw_ctx, dio, 0); sts = crystalhd_hw_add_cap_buffer(&ctx->hw_ctx, dio, 0);
if (sts != BC_STS_SUCCESS) if (sts != BC_STS_SUCCESS)
...@@ -595,12 +598,12 @@ static BC_STATUS bc_cproc_fmt_change(struct crystalhd_cmd *ctx, ...@@ -595,12 +598,12 @@ static BC_STATUS bc_cproc_fmt_change(struct crystalhd_cmd *ctx,
return sts; return sts;
} }
static BC_STATUS bc_cproc_fetch_frame(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_fetch_frame(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
crystalhd_dio_req *dio = NULL; struct crystalhd_dio_req *dio = NULL;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
BC_DEC_OUT_BUFF *frame; struct BC_DEC_OUT_BUFF *frame;
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -636,8 +639,8 @@ static BC_STATUS bc_cproc_fetch_frame(struct crystalhd_cmd *ctx, ...@@ -636,8 +639,8 @@ static BC_STATUS bc_cproc_fetch_frame(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_start_capture(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_start_capture(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
ctx->state |= BC_LINK_CAP_EN; ctx->state |= BC_LINK_CAP_EN;
if (ctx->state == BC_LINK_READY) if (ctx->state == BC_LINK_READY)
...@@ -646,12 +649,12 @@ static BC_STATUS bc_cproc_start_capture(struct crystalhd_cmd *ctx, ...@@ -646,12 +649,12 @@ static BC_STATUS bc_cproc_start_capture(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_flush_cap_buffs(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_flush_cap_buffs(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
crystalhd_dio_req *dio = NULL; struct crystalhd_dio_req *dio = NULL;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
BC_DEC_OUT_BUFF *frame; struct BC_DEC_OUT_BUFF *frame;
uint32_t count; uint32_t count;
if (!ctx || !idata) { if (!ctx || !idata) {
...@@ -681,10 +684,10 @@ static BC_STATUS bc_cproc_flush_cap_buffs(struct crystalhd_cmd *ctx, ...@@ -681,10 +684,10 @@ static BC_STATUS bc_cproc_flush_cap_buffs(struct crystalhd_cmd *ctx,
return crystalhd_hw_stop_capture(&ctx->hw_ctx); return crystalhd_hw_stop_capture(&ctx->hw_ctx);
} }
static BC_STATUS bc_cproc_get_stats(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_get_stats(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
BC_DTS_STATS *stats; struct BC_DTS_STATS *stats;
struct crystalhd_hw_stats hw_stats; struct crystalhd_hw_stats hw_stats;
if (!ctx || !idata) { if (!ctx || !idata) {
...@@ -713,20 +716,20 @@ static BC_STATUS bc_cproc_get_stats(struct crystalhd_cmd *ctx, ...@@ -713,20 +716,20 @@ static BC_STATUS bc_cproc_get_stats(struct crystalhd_cmd *ctx,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_reset_stats(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_reset_stats(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
crystalhd_hw_stats(&ctx->hw_ctx, NULL); crystalhd_hw_stats(&ctx->hw_ctx, NULL);
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS bc_cproc_chg_clk(struct crystalhd_cmd *ctx, static enum BC_STATUS bc_cproc_chg_clk(struct crystalhd_cmd *ctx,
crystalhd_ioctl_data *idata) struct crystalhd_ioctl_data *idata)
{ {
BC_CLOCK *clock; struct BC_CLOCK *clock;
uint32_t oldClk; uint32_t oldClk;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -749,7 +752,7 @@ static BC_STATUS bc_cproc_chg_clk(struct crystalhd_cmd *ctx, ...@@ -749,7 +752,7 @@ static BC_STATUS bc_cproc_chg_clk(struct crystalhd_cmd *ctx,
} }
/*=============== Cmd Proc Table.. ======================================*/ /*=============== Cmd Proc Table.. ======================================*/
static const crystalhd_cmd_tbl_t g_crystalhd_cproc_tbl[] = { static const struct crystalhd_cmd_tbl g_crystalhd_cproc_tbl[] = {
{ BCM_IOC_GET_VERSION, bc_cproc_get_version, 0}, { BCM_IOC_GET_VERSION, bc_cproc_get_version, 0},
{ BCM_IOC_GET_HWTYPE, bc_cproc_get_hwtype, 0}, { BCM_IOC_GET_HWTYPE, bc_cproc_get_hwtype, 0},
{ BCM_IOC_REG_RD, bc_cproc_reg_rd, 0}, { BCM_IOC_REG_RD, bc_cproc_reg_rd, 0},
...@@ -796,9 +799,10 @@ static const crystalhd_cmd_tbl_t g_crystalhd_cproc_tbl[] = { ...@@ -796,9 +799,10 @@ static const crystalhd_cmd_tbl_t g_crystalhd_cproc_tbl[] = {
* we pass on the power mangement notification to our plug-in by completing * we pass on the power mangement notification to our plug-in by completing
* all outstanding requests with BC_STS_IO_USER_ABORT return code. * all outstanding requests with BC_STS_IO_USER_ABORT return code.
*/ */
BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *idata) enum BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx,
struct crystalhd_ioctl_data *idata)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!ctx || !idata) { if (!ctx || !idata) {
BCMLOG_ERR("Invalid Parameters\n"); BCMLOG_ERR("Invalid Parameters\n");
...@@ -854,7 +858,7 @@ BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *ida ...@@ -854,7 +858,7 @@ BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *ida
* start a new playback session from the pre-suspend clip position. * start a new playback session from the pre-suspend clip position.
* *
*/ */
BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx) enum BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx)
{ {
BCMLOG(BCMLOG_DBG, "crystalhd_resume Success %x\n", ctx->state); BCMLOG(BCMLOG_DBG, "crystalhd_resume Success %x\n", ctx->state);
...@@ -875,7 +879,7 @@ BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx) ...@@ -875,7 +879,7 @@ BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx)
* application specific resources. HW layer initialization * application specific resources. HW layer initialization
* is done for the first open request. * is done for the first open request.
*/ */
BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx, enum BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx,
struct crystalhd_user **user_ctx) struct crystalhd_user **user_ctx)
{ {
struct crystalhd_user *uc; struct crystalhd_user *uc;
...@@ -913,7 +917,7 @@ BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx, ...@@ -913,7 +917,7 @@ BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx,
* Closer aplication handle and release app specific * Closer aplication handle and release app specific
* resources. * resources.
*/ */
BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user *uc) enum BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user *uc)
{ {
uint32_t mode = uc->mode; uint32_t mode = uc->mode;
...@@ -948,7 +952,7 @@ BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user ...@@ -948,7 +952,7 @@ BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user
* *
* Called at the time of driver load. * Called at the time of driver load.
*/ */
BC_STATUS __devinit crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx, enum BC_STATUS __devinit crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx,
struct crystalhd_adp *adp) struct crystalhd_adp *adp)
{ {
int i = 0; int i = 0;
...@@ -983,7 +987,7 @@ BC_STATUS __devinit crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx, ...@@ -983,7 +987,7 @@ BC_STATUS __devinit crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx,
* *
* Called at the time of driver un-load. * Called at the time of driver un-load.
*/ */
BC_STATUS __devexit crystalhd_delete_cmd_context(struct crystalhd_cmd *ctx) enum BC_STATUS __devexit crystalhd_delete_cmd_context(struct crystalhd_cmd *ctx)
{ {
BCMLOG(BCMLOG_DBG, "Deleting Command context..\n"); BCMLOG(BCMLOG_DBG, "Deleting Command context..\n");
...@@ -1021,7 +1025,7 @@ crystalhd_cmd_proc crystalhd_get_cmd_proc(struct crystalhd_cmd *ctx, uint32_t cm ...@@ -1021,7 +1025,7 @@ crystalhd_cmd_proc crystalhd_get_cmd_proc(struct crystalhd_cmd *ctx, uint32_t cm
return NULL; return NULL;
} }
tbl_sz = sizeof(g_crystalhd_cproc_tbl) / sizeof(crystalhd_cmd_tbl_t); tbl_sz = sizeof(g_crystalhd_cproc_tbl) / sizeof(struct crystalhd_cmd_tbl);
for (i = 0; i < tbl_sz; i++) { for (i = 0; i < tbl_sz; i++) {
if (g_crystalhd_cproc_tbl[i].cmd_id == cmd) { if (g_crystalhd_cproc_tbl[i].cmd_id == cmd) {
if ((uc->mode == DTS_MONITOR_MODE) && if ((uc->mode == DTS_MONITOR_MODE) &&
......
...@@ -36,7 +36,7 @@ ...@@ -36,7 +36,7 @@
#include "crystalhd_misc.h" #include "crystalhd_misc.h"
#include "crystalhd_hw.h" #include "crystalhd_hw.h"
enum _crystalhd_state{ enum crystalhd_state{
BC_LINK_INVALID = 0x00, BC_LINK_INVALID = 0x00,
BC_LINK_INIT = 0x01, BC_LINK_INIT = 0x01,
BC_LINK_CAP_EN = 0x02, BC_LINK_CAP_EN = 0x02,
...@@ -66,23 +66,22 @@ struct crystalhd_cmd { ...@@ -66,23 +66,22 @@ struct crystalhd_cmd {
struct crystalhd_hw hw_ctx; struct crystalhd_hw hw_ctx;
}; };
typedef BC_STATUS(*crystalhd_cmd_proc)(struct crystalhd_cmd *, crystalhd_ioctl_data *); typedef enum BC_STATUS(*crystalhd_cmd_proc)(struct crystalhd_cmd *, struct crystalhd_ioctl_data *);
typedef struct _crystalhd_cmd_tbl { struct crystalhd_cmd_tbl {
uint32_t cmd_id; uint32_t cmd_id;
const crystalhd_cmd_proc cmd_proc; const crystalhd_cmd_proc cmd_proc;
uint32_t block_mon; uint32_t block_mon;
} crystalhd_cmd_tbl_t; };
BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx, crystalhd_ioctl_data *idata); enum BC_STATUS crystalhd_suspend(struct crystalhd_cmd *ctx, struct crystalhd_ioctl_data *idata);
BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx); enum BC_STATUS crystalhd_resume(struct crystalhd_cmd *ctx);
crystalhd_cmd_proc crystalhd_get_cmd_proc(struct crystalhd_cmd *ctx, uint32_t cmd, crystalhd_cmd_proc crystalhd_get_cmd_proc(struct crystalhd_cmd *ctx, uint32_t cmd,
struct crystalhd_user *uc); struct crystalhd_user *uc);
BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx, struct crystalhd_user **user_ctx); enum BC_STATUS crystalhd_user_open(struct crystalhd_cmd *ctx, struct crystalhd_user **user_ctx);
BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user *uc); enum BC_STATUS crystalhd_user_close(struct crystalhd_cmd *ctx, struct crystalhd_user *uc);
BC_STATUS crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx, struct crystalhd_adp *adp); enum BC_STATUS crystalhd_setup_cmd_context(struct crystalhd_cmd *ctx, struct crystalhd_adp *adp);
BC_STATUS crystalhd_delete_cmd_context(struct crystalhd_cmd *ctx); enum BC_STATUS crystalhd_delete_cmd_context(struct crystalhd_cmd *ctx);
bool crystalhd_cmd_interrupt(struct crystalhd_cmd *ctx); bool crystalhd_cmd_interrupt(struct crystalhd_cmd *ctx);
#endif #endif
...@@ -29,21 +29,17 @@ ...@@ -29,21 +29,17 @@
/* TBD: Pull in only required defs into this file.. */ /* TBD: Pull in only required defs into this file.. */
/* User Data Header */ /* User Data Header */
typedef struct user_data { struct user_data {
struct user_data *next; struct user_data *next;
uint32_t type; uint32_t type;
uint32_t size; uint32_t size;
} UD_HDR; };
/*------------------------------------------------------* /*------------------------------------------------------*
* MPEG Extension to the PPB * * MPEG Extension to the PPB *
*------------------------------------------------------*/ *------------------------------------------------------*/
typedef struct { struct ppb_mpeg {
uint32_t to_be_defined; uint32_t to_be_defined;
uint32_t valid; uint32_t valid;
...@@ -61,15 +57,15 @@ typedef struct { ...@@ -61,15 +57,15 @@ typedef struct {
/* MPEG_VALID_USERDATA /* MPEG_VALID_USERDATA
User data is in the form of a linked list. */ User data is in the form of a linked list. */
int32_t userDataSize; int32_t userDataSize;
UD_HDR *userData; struct user_data *userData;
} PPB_MPEG; };
/*------------------------------------------------------* /*------------------------------------------------------*
* VC1 Extension to the PPB * * VC1 Extension to the PPB *
*------------------------------------------------------*/ *------------------------------------------------------*/
typedef struct { struct ppb_vc1 {
uint32_t to_be_defined; uint32_t to_be_defined;
uint32_t valid; uint32_t valid;
...@@ -88,9 +84,9 @@ typedef struct { ...@@ -88,9 +84,9 @@ typedef struct {
/* VC1_VALID_USERDATA /* VC1_VALID_USERDATA
User data is in the form of a linked list. */ User data is in the form of a linked list. */
int32_t userDataSize; int32_t userDataSize;
UD_HDR *userData; struct user_data *userData;
} PPB_VC1; };
/*------------------------------------------------------* /*------------------------------------------------------*
* H.264 Extension to the PPB * * H.264 Extension to the PPB *
...@@ -108,8 +104,8 @@ typedef struct { ...@@ -108,8 +104,8 @@ typedef struct {
/* maximum number of intervals(as many as 256 intervals?) */ /* maximum number of intervals(as many as 256 intervals?) */
#define MAX_FGT_VALUE_INTERVAL (256) #define MAX_FGT_VALUE_INTERVAL (256)
typedef struct FGT_SEI { struct fgt_sei {
struct FGT_SEI *next; struct fgt_sei *next;
unsigned char model_values[3][MAX_FGT_VALUE_INTERVAL][MAX_FGT_MODEL_VALUE]; unsigned char model_values[3][MAX_FGT_VALUE_INTERVAL][MAX_FGT_MODEL_VALUE];
unsigned char upper_bound[3][MAX_FGT_VALUE_INTERVAL]; unsigned char upper_bound[3][MAX_FGT_VALUE_INTERVAL];
unsigned char lower_bound[3][MAX_FGT_VALUE_INTERVAL]; unsigned char lower_bound[3][MAX_FGT_VALUE_INTERVAL];
...@@ -134,9 +130,9 @@ typedef struct FGT_SEI { ...@@ -134,9 +130,9 @@ typedef struct FGT_SEI {
unsigned char num_model_values[3]; /* Number of model values. */ unsigned char num_model_values[3]; /* Number of model values. */
uint16_t repetition_period; /* Repetition period (0-16384) */ uint16_t repetition_period; /* Repetition period (0-16384) */
} FGT_SEI; };
typedef struct { struct ppb_h264 {
/* 'valid' specifies which fields (or sets of /* 'valid' specifies which fields (or sets of
* fields) below are valid. If the corresponding * fields) below are valid. If the corresponding
* bit in 'valid' is NOT set then that field(s) * bit in 'valid' is NOT set then that field(s)
...@@ -170,14 +166,14 @@ typedef struct { ...@@ -170,14 +166,14 @@ typedef struct {
/* H264_VALID_USER */ /* H264_VALID_USER */
uint32_t user_data_size; uint32_t user_data_size;
UD_HDR *user_data; struct user_data *user_data;
/* H264 VALID FGT */ /* H264 VALID FGT */
FGT_SEI *pfgt; struct fgt_sei *pfgt;
} PPB_H264; };
typedef struct { struct ppb {
/* Common fields. */ /* Common fields. */
uint32_t picture_number; /* Ordinal display number */ uint32_t picture_number; /* Ordinal display number */
uint32_t video_buffer; /* Video (picbuf) number */ uint32_t video_buffer; /* Video (picbuf) number */
...@@ -215,14 +211,14 @@ typedef struct { ...@@ -215,14 +211,14 @@ typedef struct {
/* Protocol-specific extensions. */ /* Protocol-specific extensions. */
union { union {
PPB_H264 h264; struct ppb_h264 h264;
PPB_MPEG mpeg; struct ppb_mpeg mpeg;
PPB_VC1 vc1; struct ppb_vc1 vc1;
} other; } other;
} PPB; };
typedef struct { struct c011_pib {
uint32_t bFormatChange; uint32_t bFormatChange;
uint32_t resolution; uint32_t resolution;
uint32_t channelId; uint32_t channelId;
...@@ -231,13 +227,11 @@ typedef struct { ...@@ -231,13 +227,11 @@ typedef struct {
uint32_t zeroPanscanValid; uint32_t zeroPanscanValid;
uint32_t dramOutBufAddr; uint32_t dramOutBufAddr;
uint32_t yComponent; uint32_t yComponent;
PPB ppb; struct ppb ppb;
} C011_PIB;
};
typedef struct { struct dec_rsp_channel_start_video {
uint32_t command; uint32_t command;
uint32_t sequence; uint32_t sequence;
uint32_t status; uint32_t status;
...@@ -251,12 +245,12 @@ typedef struct { ...@@ -251,12 +245,12 @@ typedef struct {
uint32_t transportStreamCaptureAddr; uint32_t transportStreamCaptureAddr;
uint32_t asyncEventQ; uint32_t asyncEventQ;
} DecRspChannelStartVideo; };
#define eCMD_C011_CMD_BASE (0x73763000) #define eCMD_C011_CMD_BASE (0x73763000)
/* host commands */ /* host commands */
typedef enum { enum c011_ts_cmd {
eCMD_TS_GET_NEXT_PIC = 0x7376F100, /* debug get next picture */ eCMD_TS_GET_NEXT_PIC = 0x7376F100, /* debug get next picture */
eCMD_TS_GET_LAST_PIC = 0x7376F102, /* debug get last pic status */ eCMD_TS_GET_LAST_PIC = 0x7376F102, /* debug get last pic status */
eCMD_TS_READ_WRITE_MEM = 0x7376F104, /* debug read write memory */ eCMD_TS_READ_WRITE_MEM = 0x7376F104, /* debug read write memory */
...@@ -364,6 +358,6 @@ typedef enum { ...@@ -364,6 +358,6 @@ typedef enum {
eNOTIFY_C011_ENC_CHAN_EVENT = eCMD_C011_CMD_BASE + 0x210, eNOTIFY_C011_ENC_CHAN_EVENT = eCMD_C011_CMD_BASE + 0x210,
} eC011_TS_CMD; };
#endif #endif
...@@ -61,8 +61,8 @@ static void crystalhd_start_dram(struct crystalhd_adp *adp) ...@@ -61,8 +61,8 @@ static void crystalhd_start_dram(struct crystalhd_adp *adp)
static bool crystalhd_bring_out_of_rst(struct crystalhd_adp *adp) static bool crystalhd_bring_out_of_rst(struct crystalhd_adp *adp)
{ {
link_misc_perst_deco_ctrl rst_deco_cntrl; union link_misc_perst_deco_ctrl rst_deco_cntrl;
link_misc_perst_clk_ctrl rst_clk_cntrl; union link_misc_perst_clk_ctrl rst_clk_cntrl;
uint32_t temp; uint32_t temp;
/* /*
...@@ -122,8 +122,8 @@ static bool crystalhd_bring_out_of_rst(struct crystalhd_adp *adp) ...@@ -122,8 +122,8 @@ static bool crystalhd_bring_out_of_rst(struct crystalhd_adp *adp)
static bool crystalhd_put_in_reset(struct crystalhd_adp *adp) static bool crystalhd_put_in_reset(struct crystalhd_adp *adp)
{ {
link_misc_perst_deco_ctrl rst_deco_cntrl; union link_misc_perst_deco_ctrl rst_deco_cntrl;
link_misc_perst_clk_ctrl rst_clk_cntrl; union link_misc_perst_clk_ctrl rst_clk_cntrl;
uint32_t temp; uint32_t temp;
/* /*
...@@ -178,7 +178,7 @@ static bool crystalhd_put_in_reset(struct crystalhd_adp *adp) ...@@ -178,7 +178,7 @@ static bool crystalhd_put_in_reset(struct crystalhd_adp *adp)
static void crystalhd_disable_interrupts(struct crystalhd_adp *adp) static void crystalhd_disable_interrupts(struct crystalhd_adp *adp)
{ {
intr_mask_reg intr_mask; union intr_mask_reg intr_mask;
intr_mask.whole_reg = crystalhd_reg_rd(adp, INTR_INTR_MSK_STS_REG); intr_mask.whole_reg = crystalhd_reg_rd(adp, INTR_INTR_MSK_STS_REG);
intr_mask.mask_pcie_err = 1; intr_mask.mask_pcie_err = 1;
intr_mask.mask_pcie_rbusmast_err = 1; intr_mask.mask_pcie_rbusmast_err = 1;
...@@ -194,7 +194,7 @@ static void crystalhd_disable_interrupts(struct crystalhd_adp *adp) ...@@ -194,7 +194,7 @@ static void crystalhd_disable_interrupts(struct crystalhd_adp *adp)
static void crystalhd_enable_interrupts(struct crystalhd_adp *adp) static void crystalhd_enable_interrupts(struct crystalhd_adp *adp)
{ {
intr_mask_reg intr_mask; union intr_mask_reg intr_mask;
intr_mask.whole_reg = crystalhd_reg_rd(adp, INTR_INTR_MSK_STS_REG); intr_mask.whole_reg = crystalhd_reg_rd(adp, INTR_INTR_MSK_STS_REG);
intr_mask.mask_pcie_err = 1; intr_mask.mask_pcie_err = 1;
intr_mask.mask_pcie_rbusmast_err = 1; intr_mask.mask_pcie_rbusmast_err = 1;
...@@ -348,10 +348,10 @@ static bool crystalhd_stop_device(struct crystalhd_adp *adp) ...@@ -348,10 +348,10 @@ static bool crystalhd_stop_device(struct crystalhd_adp *adp)
return true; return true;
} }
static crystalhd_rx_dma_pkt *crystalhd_hw_alloc_rx_pkt(struct crystalhd_hw *hw) static struct crystalhd_rx_dma_pkt *crystalhd_hw_alloc_rx_pkt(struct crystalhd_hw *hw)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_rx_dma_pkt *temp = NULL; struct crystalhd_rx_dma_pkt *temp = NULL;
if (!hw) if (!hw)
return NULL; return NULL;
...@@ -370,7 +370,7 @@ static crystalhd_rx_dma_pkt *crystalhd_hw_alloc_rx_pkt(struct crystalhd_hw *hw) ...@@ -370,7 +370,7 @@ static crystalhd_rx_dma_pkt *crystalhd_hw_alloc_rx_pkt(struct crystalhd_hw *hw)
} }
static void crystalhd_hw_free_rx_pkt(struct crystalhd_hw *hw, static void crystalhd_hw_free_rx_pkt(struct crystalhd_hw *hw,
crystalhd_rx_dma_pkt *pkt) struct crystalhd_rx_dma_pkt *pkt)
{ {
unsigned long flags = 0; unsigned long flags = 0;
...@@ -406,7 +406,7 @@ static void crystalhd_tx_desc_rel_call_back(void *context, void *data) ...@@ -406,7 +406,7 @@ static void crystalhd_tx_desc_rel_call_back(void *context, void *data)
static void crystalhd_rx_pkt_rel_call_back(void *context, void *data) static void crystalhd_rx_pkt_rel_call_back(void *context, void *data)
{ {
struct crystalhd_hw *hw = (struct crystalhd_hw *)context; struct crystalhd_hw *hw = (struct crystalhd_hw *)context;
crystalhd_rx_dma_pkt *pkt = (crystalhd_rx_dma_pkt *)data; struct crystalhd_rx_dma_pkt *pkt = (struct crystalhd_rx_dma_pkt *)data;
if (!pkt || !hw) { if (!pkt || !hw) {
BCMLOG_ERR("Invalid arg - %p %p\n", hw, pkt); BCMLOG_ERR("Invalid arg - %p %p\n", hw, pkt);
...@@ -453,9 +453,9 @@ do { \ ...@@ -453,9 +453,9 @@ do { \
* TX - Active & Free * TX - Active & Free
* RX - Active, Ready and Free. * RX - Active, Ready and Free.
*/ */
static BC_STATUS crystalhd_hw_create_ioqs(struct crystalhd_hw *hw) static enum BC_STATUS crystalhd_hw_create_ioqs(struct crystalhd_hw *hw)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!hw) { if (!hw) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -523,10 +523,10 @@ static bool crystalhd_code_in_full(struct crystalhd_adp *adp, uint32_t needed_sz ...@@ -523,10 +523,10 @@ static bool crystalhd_code_in_full(struct crystalhd_adp *adp, uint32_t needed_sz
return false; return false;
} }
static BC_STATUS crystalhd_hw_tx_req_complete(struct crystalhd_hw *hw, static enum BC_STATUS crystalhd_hw_tx_req_complete(struct crystalhd_hw *hw,
uint32_t list_id, BC_STATUS cs) uint32_t list_id, enum BC_STATUS cs)
{ {
tx_dma_pkt *tx_req; struct tx_dma_pkt *tx_req;
if (!hw || !list_id) { if (!hw || !list_id) {
BCMLOG_ERR("Invalid Arg..\n"); BCMLOG_ERR("Invalid Arg..\n");
...@@ -535,7 +535,7 @@ static BC_STATUS crystalhd_hw_tx_req_complete(struct crystalhd_hw *hw, ...@@ -535,7 +535,7 @@ static BC_STATUS crystalhd_hw_tx_req_complete(struct crystalhd_hw *hw,
hw->pwr_lock--; hw->pwr_lock--;
tx_req = (tx_dma_pkt *)crystalhd_dioq_find_and_fetch(hw->tx_actq, list_id); tx_req = (struct tx_dma_pkt *)crystalhd_dioq_find_and_fetch(hw->tx_actq, list_id);
if (!tx_req) { if (!tx_req) {
if (cs != BC_STS_IO_USER_ABORT) if (cs != BC_STS_IO_USER_ABORT)
BCMLOG_ERR("Find and Fetch Did not find req\n"); BCMLOG_ERR("Find and Fetch Did not find req\n");
...@@ -654,7 +654,7 @@ static void crystalhd_tx_isr(struct crystalhd_hw *hw, uint32_t int_sts) ...@@ -654,7 +654,7 @@ static void crystalhd_tx_isr(struct crystalhd_hw *hw, uint32_t int_sts)
hw->stats.tx_errors++; hw->stats.tx_errors++;
} }
static void crystalhd_hw_dump_desc(pdma_descriptor p_dma_desc, static void crystalhd_hw_dump_desc(struct dma_descriptor *p_dma_desc,
uint32_t ul_desc_index, uint32_t cnt) uint32_t ul_desc_index, uint32_t cnt)
{ {
uint32_t ix, ll = 0; uint32_t ix, ll = 0;
...@@ -682,15 +682,15 @@ static void crystalhd_hw_dump_desc(pdma_descriptor p_dma_desc, ...@@ -682,15 +682,15 @@ static void crystalhd_hw_dump_desc(pdma_descriptor p_dma_desc,
} }
static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq, static enum BC_STATUS crystalhd_hw_fill_desc(struct crystalhd_dio_req *ioreq,
dma_descriptor *desc, struct dma_descriptor *desc,
dma_addr_t desc_paddr_base, dma_addr_t desc_paddr_base,
uint32_t sg_cnt, uint32_t sg_st_ix, uint32_t sg_cnt, uint32_t sg_st_ix,
uint32_t sg_st_off, uint32_t xfr_sz) uint32_t sg_st_off, uint32_t xfr_sz)
{ {
uint32_t count = 0, ix = 0, sg_ix = 0, len = 0, last_desc_ix = 0; uint32_t count = 0, ix = 0, sg_ix = 0, len = 0, last_desc_ix = 0;
dma_addr_t desc_phy_addr = desc_paddr_base; dma_addr_t desc_phy_addr = desc_paddr_base;
addr_64 addr_temp; union addr_64 addr_temp;
if (!ioreq || !desc || !desc_paddr_base || !xfr_sz || if (!ioreq || !desc || !desc_paddr_base || !xfr_sz ||
(!sg_cnt && !ioreq->uinfo.dir_tx)) { (!sg_cnt && !ioreq->uinfo.dir_tx)) {
...@@ -721,7 +721,7 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq, ...@@ -721,7 +721,7 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq,
desc[ix].dma_dir = ioreq->uinfo.dir_tx; desc[ix].dma_dir = ioreq->uinfo.dir_tx;
/* Chain DMA descriptor. */ /* Chain DMA descriptor. */
addr_temp.full_addr = desc_phy_addr + sizeof(dma_descriptor); addr_temp.full_addr = desc_phy_addr + sizeof(struct dma_descriptor);
desc[ix].next_desc_addr_low = addr_temp.low_part; desc[ix].next_desc_addr_low = addr_temp.low_part;
desc[ix].next_desc_addr_high = addr_temp.high_part; desc[ix].next_desc_addr_high = addr_temp.high_part;
...@@ -740,7 +740,7 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq, ...@@ -740,7 +740,7 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq,
crystalhd_hw_dump_desc(desc, ix, 1); crystalhd_hw_dump_desc(desc, ix, 1);
count += len; count += len;
desc_phy_addr += sizeof(dma_descriptor); desc_phy_addr += sizeof(struct dma_descriptor);
} }
last_desc_ix = ix - 1; last_desc_ix = ix - 1;
...@@ -773,15 +773,15 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq, ...@@ -773,15 +773,15 @@ static BC_STATUS crystalhd_hw_fill_desc(crystalhd_dio_req *ioreq,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS crystalhd_xlat_sgl_to_dma_desc(crystalhd_dio_req *ioreq, static enum BC_STATUS crystalhd_xlat_sgl_to_dma_desc(struct crystalhd_dio_req *ioreq,
pdma_desc_mem pdesc_mem, struct dma_desc_mem *pdesc_mem,
uint32_t *uv_desc_index) uint32_t *uv_desc_index)
{ {
dma_descriptor *desc = NULL; struct dma_descriptor *desc = NULL;
dma_addr_t desc_paddr_base = 0; dma_addr_t desc_paddr_base = 0;
uint32_t sg_cnt = 0, sg_st_ix = 0, sg_st_off = 0; uint32_t sg_cnt = 0, sg_st_ix = 0, sg_st_off = 0;
uint32_t xfr_sz = 0; uint32_t xfr_sz = 0;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
/* Check params.. */ /* Check params.. */
if (!ioreq || !pdesc_mem || !uv_desc_index) { if (!ioreq || !pdesc_mem || !uv_desc_index) {
...@@ -821,7 +821,7 @@ static BC_STATUS crystalhd_xlat_sgl_to_dma_desc(crystalhd_dio_req *ioreq, ...@@ -821,7 +821,7 @@ static BC_STATUS crystalhd_xlat_sgl_to_dma_desc(crystalhd_dio_req *ioreq,
/* Prepare for UV mapping.. */ /* Prepare for UV mapping.. */
desc = &pdesc_mem->pdma_desc_start[sg_cnt]; desc = &pdesc_mem->pdma_desc_start[sg_cnt];
desc_paddr_base = pdesc_mem->phy_addr + desc_paddr_base = pdesc_mem->phy_addr +
(sg_cnt * sizeof(dma_descriptor)); (sg_cnt * sizeof(struct dma_descriptor));
/* Done with desc addr.. now update sg stuff.*/ /* Done with desc addr.. now update sg stuff.*/
sg_cnt = ioreq->sg_cnt - ioreq->uinfo.uv_sg_ix; sg_cnt = ioreq->sg_cnt - ioreq->uinfo.uv_sg_ix;
...@@ -858,7 +858,7 @@ static void crystalhd_start_tx_dma_engine(struct crystalhd_hw *hw) ...@@ -858,7 +858,7 @@ static void crystalhd_start_tx_dma_engine(struct crystalhd_hw *hw)
* Verify if the Stop generates a completion interrupt or not. * Verify if the Stop generates a completion interrupt or not.
* if it does not generate an interrupt, then add polling here. * if it does not generate an interrupt, then add polling here.
*/ */
static BC_STATUS crystalhd_stop_tx_dma_engine(struct crystalhd_hw *hw) static enum BC_STATUS crystalhd_stop_tx_dma_engine(struct crystalhd_hw *hw)
{ {
uint32_t dma_cntrl, cnt = 30; uint32_t dma_cntrl, cnt = 30;
uint32_t l1 = 1, l2 = 1; uint32_t l1 = 1, l2 = 1;
...@@ -1021,7 +1021,7 @@ static bool crystalhd_rel_addr_to_pib_Q(struct crystalhd_hw *hw, uint32_t addr_t ...@@ -1021,7 +1021,7 @@ static bool crystalhd_rel_addr_to_pib_Q(struct crystalhd_hw *hw, uint32_t addr_t
return true; return true;
} }
static void cpy_pib_to_app(C011_PIB *src_pib, BC_PIC_INFO_BLOCK *dst_pib) static void cpy_pib_to_app(struct c011_pib *src_pib, struct BC_PIC_INFO_BLOCK *dst_pib)
{ {
if (!src_pib || !dst_pib) { if (!src_pib || !dst_pib) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -1046,10 +1046,10 @@ static void cpy_pib_to_app(C011_PIB *src_pib, BC_PIC_INFO_BLOCK *dst_pib) ...@@ -1046,10 +1046,10 @@ static void cpy_pib_to_app(C011_PIB *src_pib, BC_PIC_INFO_BLOCK *dst_pib)
static void crystalhd_hw_proc_pib(struct crystalhd_hw *hw) static void crystalhd_hw_proc_pib(struct crystalhd_hw *hw)
{ {
unsigned int cnt; unsigned int cnt;
C011_PIB src_pib; struct c011_pib src_pib;
uint32_t pib_addr, pib_cnt; uint32_t pib_addr, pib_cnt;
BC_PIC_INFO_BLOCK *AppPib; struct BC_PIC_INFO_BLOCK *AppPib;
crystalhd_rx_dma_pkt *rx_pkt = NULL; struct crystalhd_rx_dma_pkt *rx_pkt = NULL;
pib_cnt = crystalhd_get_pib_avail_cnt(hw); pib_cnt = crystalhd_get_pib_avail_cnt(hw);
...@@ -1059,11 +1059,11 @@ static void crystalhd_hw_proc_pib(struct crystalhd_hw *hw) ...@@ -1059,11 +1059,11 @@ static void crystalhd_hw_proc_pib(struct crystalhd_hw *hw)
for (cnt = 0; cnt < pib_cnt; cnt++) { for (cnt = 0; cnt < pib_cnt; cnt++) {
pib_addr = crystalhd_get_addr_from_pib_Q(hw); pib_addr = crystalhd_get_addr_from_pib_Q(hw);
crystalhd_mem_rd(hw->adp, pib_addr, sizeof(C011_PIB) / 4, crystalhd_mem_rd(hw->adp, pib_addr, sizeof(struct c011_pib) / 4,
(uint32_t *)&src_pib); (uint32_t *)&src_pib);
if (src_pib.bFormatChange) { if (src_pib.bFormatChange) {
rx_pkt = (crystalhd_rx_dma_pkt *)crystalhd_dioq_fetch(hw->rx_freeq); rx_pkt = (struct crystalhd_rx_dma_pkt *)crystalhd_dioq_fetch(hw->rx_freeq);
if (!rx_pkt) if (!rx_pkt)
return; return;
rx_pkt->flags = 0; rx_pkt->flags = 0;
...@@ -1168,11 +1168,11 @@ static void crystalhd_stop_rx_dma_engine(struct crystalhd_hw *hw) ...@@ -1168,11 +1168,11 @@ static void crystalhd_stop_rx_dma_engine(struct crystalhd_hw *hw)
count, hw->rx_list_sts[0], hw->rx_list_sts[1]); count, hw->rx_list_sts[0], hw->rx_list_sts[1]);
} }
static BC_STATUS crystalhd_hw_prog_rxdma(struct crystalhd_hw *hw, crystalhd_rx_dma_pkt *rx_pkt) static enum BC_STATUS crystalhd_hw_prog_rxdma(struct crystalhd_hw *hw, struct crystalhd_rx_dma_pkt *rx_pkt)
{ {
uint32_t y_low_addr_reg, y_high_addr_reg; uint32_t y_low_addr_reg, y_high_addr_reg;
uint32_t uv_low_addr_reg, uv_high_addr_reg; uint32_t uv_low_addr_reg, uv_high_addr_reg;
addr_64 desc_addr; union addr_64 desc_addr;
unsigned long flags; unsigned long flags;
if (!hw || !rx_pkt) { if (!hw || !rx_pkt) {
...@@ -1228,10 +1228,10 @@ static BC_STATUS crystalhd_hw_prog_rxdma(struct crystalhd_hw *hw, crystalhd_rx_d ...@@ -1228,10 +1228,10 @@ static BC_STATUS crystalhd_hw_prog_rxdma(struct crystalhd_hw *hw, crystalhd_rx_d
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static BC_STATUS crystalhd_hw_post_cap_buff(struct crystalhd_hw *hw, static enum BC_STATUS crystalhd_hw_post_cap_buff(struct crystalhd_hw *hw,
crystalhd_rx_dma_pkt *rx_pkt) struct crystalhd_rx_dma_pkt *rx_pkt)
{ {
BC_STATUS sts = crystalhd_hw_prog_rxdma(hw, rx_pkt); enum BC_STATUS sts = crystalhd_hw_prog_rxdma(hw, rx_pkt);
if (sts == BC_STS_BUSY) if (sts == BC_STS_BUSY)
crystalhd_dioq_add(hw->rx_freeq, (void *)rx_pkt, crystalhd_dioq_add(hw->rx_freeq, (void *)rx_pkt,
...@@ -1287,12 +1287,12 @@ static void crystalhd_hw_finalize_pause(struct crystalhd_hw *hw) ...@@ -1287,12 +1287,12 @@ static void crystalhd_hw_finalize_pause(struct crystalhd_hw *hw)
crystalhd_reg_wr(hw->adp, PCIE_DLL_DATA_LINK_CONTROL, aspm); crystalhd_reg_wr(hw->adp, PCIE_DLL_DATA_LINK_CONTROL, aspm);
} }
static BC_STATUS crystalhd_rx_pkt_done(struct crystalhd_hw *hw, uint32_t list_index, static enum BC_STATUS crystalhd_rx_pkt_done(struct crystalhd_hw *hw, uint32_t list_index,
BC_STATUS comp_sts) enum BC_STATUS comp_sts)
{ {
crystalhd_rx_dma_pkt *rx_pkt = NULL; struct crystalhd_rx_dma_pkt *rx_pkt = NULL;
uint32_t y_dw_dnsz, uv_dw_dnsz; uint32_t y_dw_dnsz, uv_dw_dnsz;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
if (!hw || list_index >= DMA_ENGINE_CNT) { if (!hw || list_index >= DMA_ENGINE_CNT) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -1328,7 +1328,7 @@ static bool crystalhd_rx_list0_handler(struct crystalhd_hw *hw, uint32_t int_sts ...@@ -1328,7 +1328,7 @@ static bool crystalhd_rx_list0_handler(struct crystalhd_hw *hw, uint32_t int_sts
uint32_t y_err_sts, uint32_t uv_err_sts) uint32_t y_err_sts, uint32_t uv_err_sts)
{ {
uint32_t tmp; uint32_t tmp;
list_sts tmp_lsts; enum list_sts tmp_lsts;
if (!(y_err_sts & GET_Y0_ERR_MSK) && !(uv_err_sts & GET_UV0_ERR_MSK)) if (!(y_err_sts & GET_Y0_ERR_MSK) && !(uv_err_sts & GET_UV0_ERR_MSK))
return false; return false;
...@@ -1396,7 +1396,7 @@ static bool crystalhd_rx_list1_handler(struct crystalhd_hw *hw, uint32_t int_sts ...@@ -1396,7 +1396,7 @@ static bool crystalhd_rx_list1_handler(struct crystalhd_hw *hw, uint32_t int_sts
uint32_t y_err_sts, uint32_t uv_err_sts) uint32_t y_err_sts, uint32_t uv_err_sts)
{ {
uint32_t tmp; uint32_t tmp;
list_sts tmp_lsts; enum list_sts tmp_lsts;
if (!(y_err_sts & GET_Y1_ERR_MSK) && !(uv_err_sts & GET_UV1_ERR_MSK)) if (!(y_err_sts & GET_Y1_ERR_MSK) && !(uv_err_sts & GET_UV1_ERR_MSK))
return false; return false;
...@@ -1467,7 +1467,7 @@ static void crystalhd_rx_isr(struct crystalhd_hw *hw, uint32_t intr_sts) ...@@ -1467,7 +1467,7 @@ static void crystalhd_rx_isr(struct crystalhd_hw *hw, uint32_t intr_sts)
{ {
unsigned long flags; unsigned long flags;
uint32_t i, list_avail = 0; uint32_t i, list_avail = 0;
BC_STATUS comp_sts = BC_STS_NO_DATA; enum BC_STATUS comp_sts = BC_STS_NO_DATA;
uint32_t y_err_sts, uv_err_sts, y_dn_sz = 0, uv_dn_sz = 0; uint32_t y_err_sts, uv_err_sts, y_dn_sz = 0, uv_dn_sz = 0;
bool ret = 0; bool ret = 0;
...@@ -1535,15 +1535,15 @@ static void crystalhd_rx_isr(struct crystalhd_hw *hw, uint32_t intr_sts) ...@@ -1535,15 +1535,15 @@ static void crystalhd_rx_isr(struct crystalhd_hw *hw, uint32_t intr_sts)
} }
} }
static BC_STATUS crystalhd_fw_cmd_post_proc(struct crystalhd_hw *hw, static enum BC_STATUS crystalhd_fw_cmd_post_proc(struct crystalhd_hw *hw,
BC_FW_CMD *fw_cmd) struct BC_FW_CMD *fw_cmd)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
DecRspChannelStartVideo *st_rsp = NULL; struct dec_rsp_channel_start_video *st_rsp = NULL;
switch (fw_cmd->cmd[0]) { switch (fw_cmd->cmd[0]) {
case eCMD_C011_DEC_CHAN_START_VIDEO: case eCMD_C011_DEC_CHAN_START_VIDEO:
st_rsp = (DecRspChannelStartVideo *)fw_cmd->rsp; st_rsp = (struct dec_rsp_channel_start_video *)fw_cmd->rsp;
hw->pib_del_Q_addr = st_rsp->picInfoDeliveryQ; hw->pib_del_Q_addr = st_rsp->picInfoDeliveryQ;
hw->pib_rel_Q_addr = st_rsp->picInfoReleaseQ; hw->pib_rel_Q_addr = st_rsp->picInfoReleaseQ;
BCMLOG(BCMLOG_DBG, "DelQAddr:%x RelQAddr:%x\n", BCMLOG(BCMLOG_DBG, "DelQAddr:%x RelQAddr:%x\n",
...@@ -1561,10 +1561,10 @@ static BC_STATUS crystalhd_fw_cmd_post_proc(struct crystalhd_hw *hw, ...@@ -1561,10 +1561,10 @@ static BC_STATUS crystalhd_fw_cmd_post_proc(struct crystalhd_hw *hw,
return sts; return sts;
} }
static BC_STATUS crystalhd_put_ddr2sleep(struct crystalhd_hw *hw) static enum BC_STATUS crystalhd_put_ddr2sleep(struct crystalhd_hw *hw)
{ {
uint32_t reg; uint32_t reg;
link_misc_perst_decoder_ctrl rst_cntrl_reg; union link_misc_perst_decoder_ctrl rst_cntrl_reg;
/* Pulse reset pin of 7412 (MISC_PERST_DECODER_CTRL) */ /* Pulse reset pin of 7412 (MISC_PERST_DECODER_CTRL) */
rst_cntrl_reg.whole_reg = crystalhd_reg_rd(hw->adp, MISC_PERST_DECODER_CTRL); rst_cntrl_reg.whole_reg = crystalhd_reg_rd(hw->adp, MISC_PERST_DECODER_CTRL);
...@@ -1622,7 +1622,7 @@ static BC_STATUS crystalhd_put_ddr2sleep(struct crystalhd_hw *hw) ...@@ -1622,7 +1622,7 @@ static BC_STATUS crystalhd_put_ddr2sleep(struct crystalhd_hw *hw)
** **
*************************************************/ *************************************************/
BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp, void *buffer, uint32_t sz) enum BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp, void *buffer, uint32_t sz)
{ {
uint32_t reg_data, cnt, *temp_buff; uint32_t reg_data, cnt, *temp_buff;
uint32_t fw_sig_len = 36; uint32_t fw_sig_len = 36;
...@@ -1714,13 +1714,14 @@ BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp, void *buffer, uint32_ ...@@ -1714,13 +1714,14 @@ BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp, void *buffer, uint32_
return BC_STS_SUCCESS;; return BC_STS_SUCCESS;;
} }
BC_STATUS crystalhd_do_fw_cmd(struct crystalhd_hw *hw, BC_FW_CMD *fw_cmd) enum BC_STATUS crystalhd_do_fw_cmd(struct crystalhd_hw *hw,
struct BC_FW_CMD *fw_cmd)
{ {
uint32_t cnt = 0, cmd_res_addr; uint32_t cnt = 0, cmd_res_addr;
uint32_t *cmd_buff, *res_buff; uint32_t *cmd_buff, *res_buff;
wait_queue_head_t fw_cmd_event; wait_queue_head_t fw_cmd_event;
int rc = 0; int rc = 0;
BC_STATUS sts; enum BC_STATUS sts;
crystalhd_create_event(&fw_cmd_event); crystalhd_create_event(&fw_cmd_event);
...@@ -1854,7 +1855,7 @@ bool crystalhd_hw_interrupt(struct crystalhd_adp *adp, struct crystalhd_hw *hw) ...@@ -1854,7 +1855,7 @@ bool crystalhd_hw_interrupt(struct crystalhd_adp *adp, struct crystalhd_hw *hw)
return rc; return rc;
} }
BC_STATUS crystalhd_hw_open(struct crystalhd_hw *hw, struct crystalhd_adp *adp) enum BC_STATUS crystalhd_hw_open(struct crystalhd_hw *hw, struct crystalhd_adp *adp)
{ {
if (!hw || !adp) { if (!hw || !adp) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -1886,7 +1887,7 @@ BC_STATUS crystalhd_hw_open(struct crystalhd_hw *hw, struct crystalhd_adp *adp) ...@@ -1886,7 +1887,7 @@ BC_STATUS crystalhd_hw_open(struct crystalhd_hw *hw, struct crystalhd_adp *adp)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_close(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_close(struct crystalhd_hw *hw)
{ {
if (!hw) { if (!hw) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -1903,14 +1904,14 @@ BC_STATUS crystalhd_hw_close(struct crystalhd_hw *hw) ...@@ -1903,14 +1904,14 @@ BC_STATUS crystalhd_hw_close(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw)
{ {
unsigned int i; unsigned int i;
void *mem; void *mem;
size_t mem_len; size_t mem_len;
dma_addr_t phy_addr; dma_addr_t phy_addr;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
crystalhd_rx_dma_pkt *rpkt; struct crystalhd_rx_dma_pkt *rpkt;
if (!hw || !hw->adp) { if (!hw || !hw->adp) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -1923,7 +1924,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw) ...@@ -1923,7 +1924,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw)
return sts; return sts;
} }
mem_len = BC_LINK_MAX_SGLS * sizeof(dma_descriptor); mem_len = BC_LINK_MAX_SGLS * sizeof(struct dma_descriptor);
for (i = 0; i < BC_TX_LIST_CNT; i++) { for (i = 0; i < BC_TX_LIST_CNT; i++) {
mem = bc_kern_dma_alloc(hw->adp, mem_len, &phy_addr); mem = bc_kern_dma_alloc(hw->adp, mem_len, &phy_addr);
...@@ -1938,7 +1939,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw) ...@@ -1938,7 +1939,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw)
hw->tx_pkt_pool[i].desc_mem.pdma_desc_start = mem; hw->tx_pkt_pool[i].desc_mem.pdma_desc_start = mem;
hw->tx_pkt_pool[i].desc_mem.phy_addr = phy_addr; hw->tx_pkt_pool[i].desc_mem.phy_addr = phy_addr;
hw->tx_pkt_pool[i].desc_mem.sz = BC_LINK_MAX_SGLS * hw->tx_pkt_pool[i].desc_mem.sz = BC_LINK_MAX_SGLS *
sizeof(dma_descriptor); sizeof(struct dma_descriptor);
hw->tx_pkt_pool[i].list_tag = 0; hw->tx_pkt_pool[i].list_tag = 0;
/* Add TX dma requests to Free Queue..*/ /* Add TX dma requests to Free Queue..*/
...@@ -1968,7 +1969,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw) ...@@ -1968,7 +1969,7 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw)
} }
rpkt->desc_mem.pdma_desc_start = mem; rpkt->desc_mem.pdma_desc_start = mem;
rpkt->desc_mem.phy_addr = phy_addr; rpkt->desc_mem.phy_addr = phy_addr;
rpkt->desc_mem.sz = BC_LINK_MAX_SGLS * sizeof(dma_descriptor); rpkt->desc_mem.sz = BC_LINK_MAX_SGLS * sizeof(struct dma_descriptor);
rpkt->pkt_tag = hw->rx_pkt_tag_seed + i; rpkt->pkt_tag = hw->rx_pkt_tag_seed + i;
crystalhd_hw_free_rx_pkt(hw, rpkt); crystalhd_hw_free_rx_pkt(hw, rpkt);
} }
...@@ -1976,10 +1977,10 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw) ...@@ -1976,10 +1977,10 @@ BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *hw)
{ {
unsigned int i; unsigned int i;
crystalhd_rx_dma_pkt *rpkt = NULL; struct crystalhd_rx_dma_pkt *rpkt = NULL;
if (!hw || !hw->adp) { if (!hw || !hw->adp) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -2014,16 +2015,16 @@ BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *hw) ...@@ -2014,16 +2015,16 @@ BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq, enum BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, struct crystalhd_dio_req *ioreq,
hw_comp_callback call_back, hw_comp_callback call_back,
wait_queue_head_t *cb_event, uint32_t *list_id, wait_queue_head_t *cb_event, uint32_t *list_id,
uint8_t data_flags) uint8_t data_flags)
{ {
tx_dma_pkt *tx_dma_packet = NULL; struct tx_dma_pkt *tx_dma_packet = NULL;
uint32_t first_desc_u_addr, first_desc_l_addr; uint32_t first_desc_u_addr, first_desc_l_addr;
uint32_t low_addr, high_addr; uint32_t low_addr, high_addr;
addr_64 desc_addr; union addr_64 desc_addr;
BC_STATUS sts, add_sts; enum BC_STATUS sts, add_sts;
uint32_t dummy_index = 0; uint32_t dummy_index = 0;
unsigned long flags; unsigned long flags;
bool rc; bool rc;
...@@ -2048,7 +2049,7 @@ BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq ...@@ -2048,7 +2049,7 @@ BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq
} }
/* Get a list from TxFreeQ */ /* Get a list from TxFreeQ */
tx_dma_packet = (tx_dma_pkt *)crystalhd_dioq_fetch(hw->tx_freeq); tx_dma_packet = (struct tx_dma_pkt *)crystalhd_dioq_fetch(hw->tx_freeq);
if (!tx_dma_packet) { if (!tx_dma_packet) {
BCMLOG_ERR("No empty elements..\n"); BCMLOG_ERR("No empty elements..\n");
return BC_STS_ERR_USAGE; return BC_STS_ERR_USAGE;
...@@ -2121,7 +2122,7 @@ BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq ...@@ -2121,7 +2122,7 @@ BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq
* *
* FIX_ME: Not Tested the actual condition.. * FIX_ME: Not Tested the actual condition..
*/ */
BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id) enum BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id)
{ {
if (!hw || !list_id) { if (!hw || !list_id) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -2134,12 +2135,12 @@ BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id) ...@@ -2134,12 +2135,12 @@ BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw, enum BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw,
crystalhd_dio_req *ioreq, bool en_post) struct crystalhd_dio_req *ioreq, bool en_post)
{ {
crystalhd_rx_dma_pkt *rpkt; struct crystalhd_rx_dma_pkt *rpkt;
uint32_t tag, uv_desc_ix = 0; uint32_t tag, uv_desc_ix = 0;
BC_STATUS sts; enum BC_STATUS sts;
if (!hw || !ioreq) { if (!hw || !ioreq) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -2164,7 +2165,7 @@ BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw, ...@@ -2164,7 +2165,7 @@ BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw,
/* Store the address of UV in the rx packet for post*/ /* Store the address of UV in the rx packet for post*/
if (uv_desc_ix) if (uv_desc_ix)
rpkt->uv_phy_addr = rpkt->desc_mem.phy_addr + rpkt->uv_phy_addr = rpkt->desc_mem.phy_addr +
(sizeof(dma_descriptor) * (uv_desc_ix + 1)); (sizeof(struct dma_descriptor) * (uv_desc_ix + 1));
if (en_post) if (en_post)
sts = crystalhd_hw_post_cap_buff(hw, rpkt); sts = crystalhd_hw_post_cap_buff(hw, rpkt);
...@@ -2174,11 +2175,11 @@ BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw, ...@@ -2174,11 +2175,11 @@ BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw,
return sts; return sts;
} }
BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw, enum BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw,
BC_PIC_INFO_BLOCK *pib, struct BC_PIC_INFO_BLOCK *pib,
crystalhd_dio_req **ioreq) struct crystalhd_dio_req **ioreq)
{ {
crystalhd_rx_dma_pkt *rpkt; struct crystalhd_rx_dma_pkt *rpkt;
uint32_t timeout = BC_PROC_OUTPUT_TIMEOUT / 1000; uint32_t timeout = BC_PROC_OUTPUT_TIMEOUT / 1000;
uint32_t sig_pending = 0; uint32_t sig_pending = 0;
...@@ -2210,10 +2211,10 @@ BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw, ...@@ -2210,10 +2211,10 @@ BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw,
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw)
{ {
crystalhd_rx_dma_pkt *rx_pkt; struct crystalhd_rx_dma_pkt *rx_pkt;
BC_STATUS sts; enum BC_STATUS sts;
uint32_t i; uint32_t i;
if (!hw) { if (!hw) {
...@@ -2235,7 +2236,7 @@ BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw) ...@@ -2235,7 +2236,7 @@ BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw)
{ {
void *temp = NULL; void *temp = NULL;
...@@ -2255,7 +2256,7 @@ BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw) ...@@ -2255,7 +2256,7 @@ BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw)
{ {
hw->stats.pause_cnt++; hw->stats.pause_cnt++;
hw->stop_pending = 1; hw->stop_pending = 1;
...@@ -2267,9 +2268,9 @@ BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw) ...@@ -2267,9 +2268,9 @@ BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw)
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw)
{ {
BC_STATUS sts; enum BC_STATUS sts;
uint32_t aspm; uint32_t aspm;
hw->stop_pending = 0; hw->stop_pending = 0;
...@@ -2283,9 +2284,9 @@ BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw) ...@@ -2283,9 +2284,9 @@ BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw)
return sts; return sts;
} }
BC_STATUS crystalhd_hw_suspend(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_suspend(struct crystalhd_hw *hw)
{ {
BC_STATUS sts; enum BC_STATUS sts;
if (!hw) { if (!hw) {
BCMLOG_ERR("Invalid Arguments\n"); BCMLOG_ERR("Invalid Arguments\n");
...@@ -2324,7 +2325,7 @@ void crystalhd_hw_stats(struct crystalhd_hw *hw, struct crystalhd_hw_stats *stat ...@@ -2324,7 +2325,7 @@ void crystalhd_hw_stats(struct crystalhd_hw *hw, struct crystalhd_hw_stats *stat
memcpy(stats, &hw->stats, sizeof(*stats)); memcpy(stats, &hw->stats, sizeof(*stats));
} }
BC_STATUS crystalhd_hw_set_core_clock(struct crystalhd_hw *hw) enum BC_STATUS crystalhd_hw_set_core_clock(struct crystalhd_hw *hw)
{ {
uint32_t reg, n, i; uint32_t reg, n, i;
uint32_t vco_mg, refresh_reg; uint32_t vco_mg, refresh_reg;
......
...@@ -109,7 +109,7 @@ ...@@ -109,7 +109,7 @@
#define DecHt_HostSwReset 0x340000 #define DecHt_HostSwReset 0x340000
#define BC_DRAM_FW_CFG_ADDR 0x001c2000 #define BC_DRAM_FW_CFG_ADDR 0x001c2000
typedef union _addr_64_ { union addr_64 {
struct { struct {
uint32_t low_part; uint32_t low_part;
uint32_t high_part; uint32_t high_part;
...@@ -117,9 +117,9 @@ typedef union _addr_64_ { ...@@ -117,9 +117,9 @@ typedef union _addr_64_ {
uint64_t full_addr; uint64_t full_addr;
} addr_64; };
typedef union _intr_mask_reg_ { union intr_mask_reg {
struct { struct {
uint32_t mask_tx_done:1; uint32_t mask_tx_done:1;
uint32_t mask_tx_err:1; uint32_t mask_tx_err:1;
...@@ -133,9 +133,9 @@ typedef union _intr_mask_reg_ { ...@@ -133,9 +133,9 @@ typedef union _intr_mask_reg_ {
uint32_t whole_reg; uint32_t whole_reg;
} intr_mask_reg; };
typedef union _link_misc_perst_deco_ctrl_ { union link_misc_perst_deco_ctrl {
struct { struct {
uint32_t bcm7412_rst:1; /* 1 -> BCM7412 is held in reset. Reset value 1.*/ uint32_t bcm7412_rst:1; /* 1 -> BCM7412 is held in reset. Reset value 1.*/
uint32_t reserved0:3; /* Reserved.No Effect*/ uint32_t reserved0:3; /* Reserved.No Effect*/
...@@ -145,9 +145,9 @@ typedef union _link_misc_perst_deco_ctrl_ { ...@@ -145,9 +145,9 @@ typedef union _link_misc_perst_deco_ctrl_ {
uint32_t whole_reg; uint32_t whole_reg;
} link_misc_perst_deco_ctrl; };
typedef union _link_misc_perst_clk_ctrl_ { union link_misc_perst_clk_ctrl {
struct { struct {
uint32_t sel_alt_clk:1; /* When set, selects a 6.75MHz clock as the source of core_clk */ uint32_t sel_alt_clk:1; /* When set, selects a 6.75MHz clock as the source of core_clk */
uint32_t stop_core_clk:1; /* When set, stops the branch of core_clk that is not needed for low power operation */ uint32_t stop_core_clk:1; /* When set, stops the branch of core_clk that is not needed for low power operation */
...@@ -161,10 +161,9 @@ typedef union _link_misc_perst_clk_ctrl_ { ...@@ -161,10 +161,9 @@ typedef union _link_misc_perst_clk_ctrl_ {
uint32_t whole_reg; uint32_t whole_reg;
} link_misc_perst_clk_ctrl; };
typedef union _link_misc_perst_decoder_ctrl_ { union link_misc_perst_decoder_ctrl {
struct { struct {
uint32_t bcm_7412_rst:1; /* 1 -> BCM7412 is held in reset. Reset value 1.*/ uint32_t bcm_7412_rst:1; /* 1 -> BCM7412 is held in reset. Reset value 1.*/
uint32_t res0:3; /* Reserved.No Effect*/ uint32_t res0:3; /* Reserved.No Effect*/
...@@ -174,10 +173,9 @@ typedef union _link_misc_perst_decoder_ctrl_ { ...@@ -174,10 +173,9 @@ typedef union _link_misc_perst_decoder_ctrl_ {
uint32_t whole_reg; uint32_t whole_reg;
} link_misc_perst_decoder_ctrl; };
typedef union _desc_low_addr_reg_ { union desc_low_addr_reg {
struct { struct {
uint32_t list_valid:1; uint32_t list_valid:1;
uint32_t reserved:4; uint32_t reserved:4;
...@@ -186,9 +184,9 @@ typedef union _desc_low_addr_reg_ { ...@@ -186,9 +184,9 @@ typedef union _desc_low_addr_reg_ {
uint32_t whole_reg; uint32_t whole_reg;
} desc_low_addr_reg; };
typedef struct _dma_descriptor_ { /* 8 32-bit values */ struct dma_descriptor { /* 8 32-bit values */
/* 0th u32 */ /* 0th u32 */
uint32_t sdram_buff_addr:28; /* bits 0-27: SDRAM Address */ uint32_t sdram_buff_addr:28; /* bits 0-27: SDRAM Address */
uint32_t res0:4; /* bits 28-31: Reserved */ uint32_t res0:4; /* bits 28-31: Reserved */
...@@ -220,24 +218,22 @@ typedef struct _dma_descriptor_ { /* 8 32-bit values */ ...@@ -220,24 +218,22 @@ typedef struct _dma_descriptor_ { /* 8 32-bit values */
/* 7th u32 */ /* 7th u32 */
uint32_t res8; /* Last 32bits reserved */ uint32_t res8; /* Last 32bits reserved */
} dma_descriptor, *pdma_descriptor; };
/* /*
* We will allocate the memory in 4K pages * We will allocate the memory in 4K pages
* the linked list will be a list of 32 byte descriptors. * the linked list will be a list of 32 byte descriptors.
* The virtual address will determine what should be freed. * The virtual address will determine what should be freed.
*/ */
typedef struct _dma_desc_mem_ { struct dma_desc_mem {
pdma_descriptor pdma_desc_start; /* 32-bytes for dma descriptor. should be first element */ struct dma_descriptor *pdma_desc_start; /* 32-bytes for dma descriptor. should be first element */
dma_addr_t phy_addr; /* physical address of each DMA desc */ dma_addr_t phy_addr; /* physical address of each DMA desc */
uint32_t sz; uint32_t sz;
struct _dma_desc_mem_ *Next; /* points to Next Descriptor in chain */ struct _dma_desc_mem_ *Next; /* points to Next Descriptor in chain */
} dma_desc_mem, *pdma_desc_mem; };
typedef enum _list_sts_ { enum list_sts {
sts_free = 0, sts_free = 0,
/* RX-Y Bits 0:7 */ /* RX-Y Bits 0:7 */
...@@ -253,30 +249,27 @@ typedef enum _list_sts_ { ...@@ -253,30 +249,27 @@ typedef enum _list_sts_ {
rx_y_mask = 0x000000FF, rx_y_mask = 0x000000FF,
rx_uv_mask = 0x0000FF00, rx_uv_mask = 0x0000FF00,
};
} list_sts; struct tx_dma_pkt {
struct dma_desc_mem desc_mem;
typedef struct _tx_dma_pkt_ {
dma_desc_mem desc_mem;
hw_comp_callback call_back; hw_comp_callback call_back;
crystalhd_dio_req *dio_req; struct crystalhd_dio_req *dio_req;
wait_queue_head_t *cb_event; wait_queue_head_t *cb_event;
uint32_t list_tag; uint32_t list_tag;
};
} tx_dma_pkt; struct crystalhd_rx_dma_pkt {
struct dma_desc_mem desc_mem;
typedef struct _crystalhd_rx_dma_pkt { struct crystalhd_dio_req *dio_req;
dma_desc_mem desc_mem;
crystalhd_dio_req *dio_req;
uint32_t pkt_tag; uint32_t pkt_tag;
uint32_t flags; uint32_t flags;
BC_PIC_INFO_BLOCK pib; struct BC_PIC_INFO_BLOCK pib;
dma_addr_t uv_phy_addr; dma_addr_t uv_phy_addr;
struct _crystalhd_rx_dma_pkt *next; struct crystalhd_rx_dma_pkt *next;
};
} crystalhd_rx_dma_pkt;
struct crystalhd_hw_stats{ struct crystalhd_hw_stats {
uint32_t rx_errors; uint32_t rx_errors;
uint32_t tx_errors; uint32_t tx_errors;
uint32_t freeq_count; uint32_t freeq_count;
...@@ -288,13 +281,13 @@ struct crystalhd_hw_stats{ ...@@ -288,13 +281,13 @@ struct crystalhd_hw_stats{
}; };
struct crystalhd_hw { struct crystalhd_hw {
tx_dma_pkt tx_pkt_pool[DMA_ENGINE_CNT]; struct tx_dma_pkt tx_pkt_pool[DMA_ENGINE_CNT];
spinlock_t lock; spinlock_t lock;
uint32_t tx_ioq_tag_seed; uint32_t tx_ioq_tag_seed;
uint32_t tx_list_post_index; uint32_t tx_list_post_index;
crystalhd_rx_dma_pkt *rx_pkt_pool_head; struct crystalhd_rx_dma_pkt *rx_pkt_pool_head;
uint32_t rx_pkt_tag_seed; uint32_t rx_pkt_tag_seed;
bool dev_started; bool dev_started;
...@@ -306,16 +299,16 @@ struct crystalhd_hw { ...@@ -306,16 +299,16 @@ struct crystalhd_hw {
uint32_t pib_del_Q_addr; uint32_t pib_del_Q_addr;
uint32_t pib_rel_Q_addr; uint32_t pib_rel_Q_addr;
crystalhd_dioq_t *tx_freeq; struct crystalhd_dioq *tx_freeq;
crystalhd_dioq_t *tx_actq; struct crystalhd_dioq *tx_actq;
/* Rx DMA Engine Specific Locks */ /* Rx DMA Engine Specific Locks */
spinlock_t rx_lock; spinlock_t rx_lock;
uint32_t rx_list_post_index; uint32_t rx_list_post_index;
list_sts rx_list_sts[DMA_ENGINE_CNT]; enum list_sts rx_list_sts[DMA_ENGINE_CNT];
crystalhd_dioq_t *rx_rdyq; struct crystalhd_dioq *rx_rdyq;
crystalhd_dioq_t *rx_freeq; struct crystalhd_dioq *rx_freeq;
crystalhd_dioq_t *rx_actq; struct crystalhd_dioq *rx_actq;
uint32_t stop_pending; uint32_t stop_pending;
/* HW counters.. */ /* HW counters.. */
...@@ -364,35 +357,35 @@ struct crystalhd_hw { ...@@ -364,35 +357,35 @@ struct crystalhd_hw {
/**** API Exposed to the other layers ****/ /**** API Exposed to the other layers ****/
BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp, enum BC_STATUS crystalhd_download_fw(struct crystalhd_adp *adp,
void *buffer, uint32_t sz); void *buffer, uint32_t sz);
BC_STATUS crystalhd_do_fw_cmd(struct crystalhd_hw *hw, BC_FW_CMD *fw_cmd); enum BC_STATUS crystalhd_do_fw_cmd(struct crystalhd_hw *hw, struct BC_FW_CMD *fw_cmd);
bool crystalhd_hw_interrupt(struct crystalhd_adp *adp, struct crystalhd_hw *hw); bool crystalhd_hw_interrupt(struct crystalhd_adp *adp, struct crystalhd_hw *hw);
BC_STATUS crystalhd_hw_open(struct crystalhd_hw *, struct crystalhd_adp *); enum BC_STATUS crystalhd_hw_open(struct crystalhd_hw *, struct crystalhd_adp *);
BC_STATUS crystalhd_hw_close(struct crystalhd_hw *); enum BC_STATUS crystalhd_hw_close(struct crystalhd_hw *);
BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *); enum BC_STATUS crystalhd_hw_setup_dma_rings(struct crystalhd_hw *);
BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *); enum BC_STATUS crystalhd_hw_free_dma_rings(struct crystalhd_hw *);
BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, crystalhd_dio_req *ioreq, enum BC_STATUS crystalhd_hw_post_tx(struct crystalhd_hw *hw, struct crystalhd_dio_req *ioreq,
hw_comp_callback call_back, hw_comp_callback call_back,
wait_queue_head_t *cb_event, wait_queue_head_t *cb_event,
uint32_t *list_id, uint8_t data_flags); uint32_t *list_id, uint8_t data_flags);
BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw); enum BC_STATUS crystalhd_hw_pause(struct crystalhd_hw *hw);
BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw); enum BC_STATUS crystalhd_hw_unpause(struct crystalhd_hw *hw);
BC_STATUS crystalhd_hw_suspend(struct crystalhd_hw *hw); enum BC_STATUS crystalhd_hw_suspend(struct crystalhd_hw *hw);
BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id); enum BC_STATUS crystalhd_hw_cancel_tx(struct crystalhd_hw *hw, uint32_t list_id);
BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw, enum BC_STATUS crystalhd_hw_add_cap_buffer(struct crystalhd_hw *hw,
crystalhd_dio_req *ioreq, bool en_post); struct crystalhd_dio_req *ioreq, bool en_post);
BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw, enum BC_STATUS crystalhd_hw_get_cap_buffer(struct crystalhd_hw *hw,
BC_PIC_INFO_BLOCK *pib, struct BC_PIC_INFO_BLOCK *pib,
crystalhd_dio_req **ioreq); struct crystalhd_dio_req **ioreq);
BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw); enum BC_STATUS crystalhd_hw_stop_capture(struct crystalhd_hw *hw);
BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw); enum BC_STATUS crystalhd_hw_start_capture(struct crystalhd_hw *hw);
void crystalhd_hw_stats(struct crystalhd_hw *hw, struct crystalhd_hw_stats *stats); void crystalhd_hw_stats(struct crystalhd_hw *hw, struct crystalhd_hw_stats *stats);
/* API to program the core clock on the decoder */ /* API to program the core clock on the decoder */
BC_STATUS crystalhd_hw_set_core_clock(struct crystalhd_hw *); enum BC_STATUS crystalhd_hw_set_core_clock(struct crystalhd_hw *);
#endif #endif
...@@ -73,10 +73,10 @@ static int chd_dec_disable_int(struct crystalhd_adp *adp) ...@@ -73,10 +73,10 @@ static int chd_dec_disable_int(struct crystalhd_adp *adp)
return 0; return 0;
} }
crystalhd_ioctl_data *chd_dec_alloc_iodata(struct crystalhd_adp *adp, bool isr) struct crystalhd_ioctl_data *chd_dec_alloc_iodata(struct crystalhd_adp *adp, bool isr)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_ioctl_data *temp; struct crystalhd_ioctl_data *temp;
if (!adp) if (!adp)
return NULL; return NULL;
...@@ -93,7 +93,7 @@ crystalhd_ioctl_data *chd_dec_alloc_iodata(struct crystalhd_adp *adp, bool isr) ...@@ -93,7 +93,7 @@ crystalhd_ioctl_data *chd_dec_alloc_iodata(struct crystalhd_adp *adp, bool isr)
return temp; return temp;
} }
void chd_dec_free_iodata(struct crystalhd_adp *adp, crystalhd_ioctl_data *iodata, void chd_dec_free_iodata(struct crystalhd_adp *adp, struct crystalhd_ioctl_data *iodata,
bool isr) bool isr)
{ {
unsigned long flags = 0; unsigned long flags = 0;
...@@ -129,7 +129,7 @@ static inline int crystalhd_user_data(unsigned long ud, void *dr, int size, int ...@@ -129,7 +129,7 @@ static inline int crystalhd_user_data(unsigned long ud, void *dr, int size, int
return rc; return rc;
} }
static int chd_dec_fetch_cdata(struct crystalhd_adp *adp, crystalhd_ioctl_data *io, static int chd_dec_fetch_cdata(struct crystalhd_adp *adp, struct crystalhd_ioctl_data *io,
uint32_t m_sz, unsigned long ua) uint32_t m_sz, unsigned long ua)
{ {
unsigned long ua_off; unsigned long ua_off;
...@@ -163,7 +163,7 @@ static int chd_dec_fetch_cdata(struct crystalhd_adp *adp, crystalhd_ioctl_data * ...@@ -163,7 +163,7 @@ static int chd_dec_fetch_cdata(struct crystalhd_adp *adp, crystalhd_ioctl_data *
} }
static int chd_dec_release_cdata(struct crystalhd_adp *adp, static int chd_dec_release_cdata(struct crystalhd_adp *adp,
crystalhd_ioctl_data *io, unsigned long ua) struct crystalhd_ioctl_data *io, unsigned long ua)
{ {
unsigned long ua_off; unsigned long ua_off;
int rc; int rc;
...@@ -193,7 +193,7 @@ static int chd_dec_release_cdata(struct crystalhd_adp *adp, ...@@ -193,7 +193,7 @@ static int chd_dec_release_cdata(struct crystalhd_adp *adp,
} }
static int chd_dec_proc_user_data(struct crystalhd_adp *adp, static int chd_dec_proc_user_data(struct crystalhd_adp *adp,
crystalhd_ioctl_data *io, struct crystalhd_ioctl_data *io,
unsigned long ua, int set) unsigned long ua, int set)
{ {
int rc; int rc;
...@@ -231,8 +231,8 @@ static int chd_dec_api_cmd(struct crystalhd_adp *adp, unsigned long ua, ...@@ -231,8 +231,8 @@ static int chd_dec_api_cmd(struct crystalhd_adp *adp, unsigned long ua,
uint32_t uid, uint32_t cmd, crystalhd_cmd_proc func) uint32_t uid, uint32_t cmd, crystalhd_cmd_proc func)
{ {
int rc; int rc;
crystalhd_ioctl_data *temp; struct crystalhd_ioctl_data *temp;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
temp = chd_dec_alloc_iodata(adp, 0); temp = chd_dec_alloc_iodata(adp, 0);
if (!temp) { if (!temp) {
...@@ -296,7 +296,7 @@ static int chd_dec_open(struct inode *in, struct file *fd) ...@@ -296,7 +296,7 @@ static int chd_dec_open(struct inode *in, struct file *fd)
{ {
struct crystalhd_adp *adp = chd_get_adp(); struct crystalhd_adp *adp = chd_get_adp();
int rc = 0; int rc = 0;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
struct crystalhd_user *uc = NULL; struct crystalhd_user *uc = NULL;
BCMLOG_ENTER; BCMLOG_ENTER;
...@@ -356,7 +356,7 @@ static const struct file_operations chd_dec_fops = { ...@@ -356,7 +356,7 @@ static const struct file_operations chd_dec_fops = {
static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp) static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp)
{ {
crystalhd_ioctl_data *temp; struct crystalhd_ioctl_data *temp;
struct device *dev; struct device *dev;
int rc = -ENODEV, i = 0; int rc = -ENODEV, i = 0;
...@@ -394,7 +394,7 @@ static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp) ...@@ -394,7 +394,7 @@ static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp)
/* Allocate general purpose ioctl pool. */ /* Allocate general purpose ioctl pool. */
for (i = 0; i < CHD_IODATA_POOL_SZ; i++) { for (i = 0; i < CHD_IODATA_POOL_SZ; i++) {
/* FIXME: jarod: why atomic? */ /* FIXME: jarod: why atomic? */
temp = kzalloc(sizeof(crystalhd_ioctl_data), GFP_ATOMIC); temp = kzalloc(sizeof(struct crystalhd_ioctl_data), GFP_ATOMIC);
if (!temp) { if (!temp) {
BCMLOG_ERR("ioctl data pool kzalloc failed\n"); BCMLOG_ERR("ioctl data pool kzalloc failed\n");
rc = -ENOMEM; rc = -ENOMEM;
...@@ -418,7 +418,7 @@ static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp) ...@@ -418,7 +418,7 @@ static int __devinit chd_dec_init_chdev(struct crystalhd_adp *adp)
static void __devexit chd_dec_release_chdev(struct crystalhd_adp *adp) static void __devexit chd_dec_release_chdev(struct crystalhd_adp *adp)
{ {
crystalhd_ioctl_data *temp = NULL; struct crystalhd_ioctl_data *temp = NULL;
if (!adp) if (!adp)
return; return;
...@@ -513,7 +513,7 @@ static void __devexit chd_pci_release_mem(struct crystalhd_adp *pinfo) ...@@ -513,7 +513,7 @@ static void __devexit chd_pci_release_mem(struct crystalhd_adp *pinfo)
static void __devexit chd_dec_pci_remove(struct pci_dev *pdev) static void __devexit chd_dec_pci_remove(struct pci_dev *pdev)
{ {
struct crystalhd_adp *pinfo; struct crystalhd_adp *pinfo;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
BCMLOG_ENTER; BCMLOG_ENTER;
...@@ -543,7 +543,7 @@ static int __devinit chd_dec_pci_probe(struct pci_dev *pdev, ...@@ -543,7 +543,7 @@ static int __devinit chd_dec_pci_probe(struct pci_dev *pdev,
{ {
struct crystalhd_adp *pinfo; struct crystalhd_adp *pinfo;
int rc; int rc;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
BCMLOG(BCMLOG_DBG, "PCI_INFO: Vendor:0x%04x Device:0x%04x " BCMLOG(BCMLOG_DBG, "PCI_INFO: Vendor:0x%04x Device:0x%04x "
"s_vendor:0x%04x s_device: 0x%04x\n", "s_vendor:0x%04x s_device: 0x%04x\n",
...@@ -623,8 +623,8 @@ static int __devinit chd_dec_pci_probe(struct pci_dev *pdev, ...@@ -623,8 +623,8 @@ static int __devinit chd_dec_pci_probe(struct pci_dev *pdev,
int chd_dec_pci_suspend(struct pci_dev *pdev, pm_message_t state) int chd_dec_pci_suspend(struct pci_dev *pdev, pm_message_t state)
{ {
struct crystalhd_adp *adp; struct crystalhd_adp *adp;
crystalhd_ioctl_data *temp; struct crystalhd_ioctl_data *temp;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
adp = (struct crystalhd_adp *)pci_get_drvdata(pdev); adp = (struct crystalhd_adp *)pci_get_drvdata(pdev);
if (!adp) { if (!adp) {
...@@ -657,7 +657,7 @@ int chd_dec_pci_suspend(struct pci_dev *pdev, pm_message_t state) ...@@ -657,7 +657,7 @@ int chd_dec_pci_suspend(struct pci_dev *pdev, pm_message_t state)
int chd_dec_pci_resume(struct pci_dev *pdev) int chd_dec_pci_resume(struct pci_dev *pdev)
{ {
struct crystalhd_adp *adp; struct crystalhd_adp *adp;
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
int rc; int rc;
adp = (struct crystalhd_adp *)pci_get_drvdata(pdev); adp = (struct crystalhd_adp *)pci_get_drvdata(pdev);
......
...@@ -79,12 +79,12 @@ struct crystalhd_adp { ...@@ -79,12 +79,12 @@ struct crystalhd_adp {
unsigned int chd_dec_major; unsigned int chd_dec_major;
unsigned int cfg_users; unsigned int cfg_users;
crystalhd_ioctl_data *idata_free_head; /* ioctl data pool */ struct crystalhd_ioctl_data *idata_free_head; /* ioctl data pool */
crystalhd_elem_t *elem_pool_head; /* Queue element pool */ struct crystalhd_elem *elem_pool_head; /* Queue element pool */
struct crystalhd_cmd cmds; struct crystalhd_cmd cmds;
crystalhd_dio_req *ua_map_free_head; struct crystalhd_dio_req *ua_map_free_head;
struct pci_pool *fill_byte_pool; struct pci_pool *fill_byte_pool;
}; };
......
...@@ -43,15 +43,15 @@ static inline void crystalhd_dram_wr(struct crystalhd_adp *adp, uint32_t mem_off ...@@ -43,15 +43,15 @@ static inline void crystalhd_dram_wr(struct crystalhd_adp *adp, uint32_t mem_off
bc_dec_reg_wr(adp, (0x00380000 | (mem_off & 0x0007FFFF)), val); bc_dec_reg_wr(adp, (0x00380000 | (mem_off & 0x0007FFFF)), val);
} }
static inline BC_STATUS bc_chk_dram_range(struct crystalhd_adp *adp, uint32_t start_off, uint32_t cnt) static inline enum BC_STATUS bc_chk_dram_range(struct crystalhd_adp *adp, uint32_t start_off, uint32_t cnt)
{ {
return BC_STS_SUCCESS; return BC_STS_SUCCESS;
} }
static crystalhd_dio_req *crystalhd_alloc_dio(struct crystalhd_adp *adp) static struct crystalhd_dio_req *crystalhd_alloc_dio(struct crystalhd_adp *adp)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_dio_req *temp = NULL; struct crystalhd_dio_req *temp = NULL;
if (!adp) { if (!adp) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -67,7 +67,7 @@ static crystalhd_dio_req *crystalhd_alloc_dio(struct crystalhd_adp *adp) ...@@ -67,7 +67,7 @@ static crystalhd_dio_req *crystalhd_alloc_dio(struct crystalhd_adp *adp)
return temp; return temp;
} }
static void crystalhd_free_dio(struct crystalhd_adp *adp, crystalhd_dio_req *dio) static void crystalhd_free_dio(struct crystalhd_adp *adp, struct crystalhd_dio_req *dio)
{ {
unsigned long flags = 0; unsigned long flags = 0;
...@@ -83,10 +83,10 @@ static void crystalhd_free_dio(struct crystalhd_adp *adp, crystalhd_dio_req *dio ...@@ -83,10 +83,10 @@ static void crystalhd_free_dio(struct crystalhd_adp *adp, crystalhd_dio_req *dio
spin_unlock_irqrestore(&adp->lock, flags); spin_unlock_irqrestore(&adp->lock, flags);
} }
static crystalhd_elem_t *crystalhd_alloc_elem(struct crystalhd_adp *adp) static struct crystalhd_elem *crystalhd_alloc_elem(struct crystalhd_adp *adp)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_elem_t *temp = NULL; struct crystalhd_elem *temp = NULL;
if (!adp) if (!adp)
return temp; return temp;
...@@ -100,7 +100,7 @@ static crystalhd_elem_t *crystalhd_alloc_elem(struct crystalhd_adp *adp) ...@@ -100,7 +100,7 @@ static crystalhd_elem_t *crystalhd_alloc_elem(struct crystalhd_adp *adp)
return temp; return temp;
} }
static void crystalhd_free_elem(struct crystalhd_adp *adp, crystalhd_elem_t *elem) static void crystalhd_free_elem(struct crystalhd_adp *adp, struct crystalhd_elem *elem)
{ {
unsigned long flags = 0; unsigned long flags = 0;
...@@ -230,7 +230,7 @@ void crystalhd_reg_wr(struct crystalhd_adp *adp, uint32_t reg_off, uint32_t val) ...@@ -230,7 +230,7 @@ void crystalhd_reg_wr(struct crystalhd_adp *adp, uint32_t reg_off, uint32_t val)
* *
* 7412's Dram read routine. * 7412's Dram read routine.
*/ */
BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *adp, uint32_t start_off, enum BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *adp, uint32_t start_off,
uint32_t dw_cnt, uint32_t *rd_buff) uint32_t dw_cnt, uint32_t *rd_buff)
{ {
uint32_t ix = 0; uint32_t ix = 0;
...@@ -258,7 +258,7 @@ BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *adp, uint32_t start_off, ...@@ -258,7 +258,7 @@ BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *adp, uint32_t start_off,
* *
* 7412's Dram write routine. * 7412's Dram write routine.
*/ */
BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *adp, uint32_t start_off, enum BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *adp, uint32_t start_off,
uint32_t dw_cnt, uint32_t *wr_buff) uint32_t dw_cnt, uint32_t *wr_buff)
{ {
uint32_t ix = 0; uint32_t ix = 0;
...@@ -286,10 +286,10 @@ BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *adp, uint32_t start_off, ...@@ -286,10 +286,10 @@ BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *adp, uint32_t start_off,
* *
* Get value from Link's PCIe config space. * Get value from Link's PCIe config space.
*/ */
BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *adp, uint32_t off, enum BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *adp, uint32_t off,
uint32_t len, uint32_t *val) uint32_t len, uint32_t *val)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
int rc = 0; int rc = 0;
if (!adp || !val) { if (!adp || !val) {
...@@ -331,10 +331,10 @@ BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *adp, uint32_t off, ...@@ -331,10 +331,10 @@ BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *adp, uint32_t off,
* *
* Set value to Link's PCIe config space. * Set value to Link's PCIe config space.
*/ */
BC_STATUS crystalhd_pci_cfg_wr(struct crystalhd_adp *adp, uint32_t off, enum BC_STATUS crystalhd_pci_cfg_wr(struct crystalhd_adp *adp, uint32_t off,
uint32_t len, uint32_t val) uint32_t len, uint32_t val)
{ {
BC_STATUS sts = BC_STS_SUCCESS; enum BC_STATUS sts = BC_STS_SUCCESS;
int rc = 0; int rc = 0;
if (!adp || !val) { if (!adp || !val) {
...@@ -429,11 +429,11 @@ void bc_kern_dma_free(struct crystalhd_adp *adp, uint32_t sz, void *ka, ...@@ -429,11 +429,11 @@ void bc_kern_dma_free(struct crystalhd_adp *adp, uint32_t sz, void *ka,
* Initialize Generic DIO queue to hold any data. Callback * Initialize Generic DIO queue to hold any data. Callback
* will be used to free elements while deleting the queue. * will be used to free elements while deleting the queue.
*/ */
BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp, enum BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp,
crystalhd_dioq_t **dioq_hnd, struct crystalhd_dioq **dioq_hnd,
crystalhd_data_free_cb cb, void *cbctx) crystalhd_data_free_cb cb, void *cbctx)
{ {
crystalhd_dioq_t *dioq = NULL; struct crystalhd_dioq *dioq = NULL;
if (!adp || !dioq_hnd) { if (!adp || !dioq_hnd) {
BCMLOG_ERR("Invalid arg!!\n"); BCMLOG_ERR("Invalid arg!!\n");
...@@ -446,8 +446,8 @@ BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp, ...@@ -446,8 +446,8 @@ BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp,
spin_lock_init(&dioq->lock); spin_lock_init(&dioq->lock);
dioq->sig = BC_LINK_DIOQ_SIG; dioq->sig = BC_LINK_DIOQ_SIG;
dioq->head = (crystalhd_elem_t *)&dioq->head; dioq->head = (struct crystalhd_elem *)&dioq->head;
dioq->tail = (crystalhd_elem_t *)&dioq->head; dioq->tail = (struct crystalhd_elem *)&dioq->head;
crystalhd_create_event(&dioq->event); crystalhd_create_event(&dioq->event);
dioq->adp = adp; dioq->adp = adp;
dioq->data_rel_cb = cb; dioq->data_rel_cb = cb;
...@@ -470,7 +470,7 @@ BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp, ...@@ -470,7 +470,7 @@ BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *adp,
* by calling the call back provided during creation. * by calling the call back provided during creation.
* *
*/ */
void crystalhd_delete_dioq(struct crystalhd_adp *adp, crystalhd_dioq_t *dioq) void crystalhd_delete_dioq(struct crystalhd_adp *adp, struct crystalhd_dioq *dioq)
{ {
void *temp; void *temp;
...@@ -498,11 +498,11 @@ void crystalhd_delete_dioq(struct crystalhd_adp *adp, crystalhd_dioq_t *dioq) ...@@ -498,11 +498,11 @@ void crystalhd_delete_dioq(struct crystalhd_adp *adp, crystalhd_dioq_t *dioq)
* *
* Insert new element to Q tail. * Insert new element to Q tail.
*/ */
BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data, enum BC_STATUS crystalhd_dioq_add(struct crystalhd_dioq *ioq, void *data,
bool wake, uint32_t tag) bool wake, uint32_t tag)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_elem_t *tmp; struct crystalhd_elem *tmp;
if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG) || !data) { if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG) || !data) {
BCMLOG_ERR("Invalid arg!!\n"); BCMLOG_ERR("Invalid arg!!\n");
...@@ -518,7 +518,7 @@ BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data, ...@@ -518,7 +518,7 @@ BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data,
tmp->data = data; tmp->data = data;
tmp->tag = tag; tmp->tag = tag;
spin_lock_irqsave(&ioq->lock, flags); spin_lock_irqsave(&ioq->lock, flags);
tmp->flink = (crystalhd_elem_t *)&ioq->head; tmp->flink = (struct crystalhd_elem *)&ioq->head;
tmp->blink = ioq->tail; tmp->blink = ioq->tail;
tmp->flink->blink = tmp; tmp->flink->blink = tmp;
tmp->blink->flink = tmp; tmp->blink->flink = tmp;
...@@ -540,11 +540,11 @@ BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data, ...@@ -540,11 +540,11 @@ BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data,
* *
* Remove an element from Queue. * Remove an element from Queue.
*/ */
void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq) void *crystalhd_dioq_fetch(struct crystalhd_dioq *ioq)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_elem_t *tmp; struct crystalhd_elem *tmp;
crystalhd_elem_t *ret = NULL; struct crystalhd_elem *ret = NULL;
void *data = NULL; void *data = NULL;
if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG)) { if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG)) {
...@@ -554,7 +554,7 @@ void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq) ...@@ -554,7 +554,7 @@ void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq)
spin_lock_irqsave(&ioq->lock, flags); spin_lock_irqsave(&ioq->lock, flags);
tmp = ioq->head; tmp = ioq->head;
if (tmp != (crystalhd_elem_t *)&ioq->head) { if (tmp != (struct crystalhd_elem *)&ioq->head) {
ret = tmp; ret = tmp;
tmp->flink->blink = tmp->blink; tmp->flink->blink = tmp->blink;
tmp->blink->flink = tmp->flink; tmp->blink->flink = tmp->flink;
...@@ -578,11 +578,11 @@ void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq) ...@@ -578,11 +578,11 @@ void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq)
* *
* Search TAG and remove the element. * Search TAG and remove the element.
*/ */
void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag) void *crystalhd_dioq_find_and_fetch(struct crystalhd_dioq *ioq, uint32_t tag)
{ {
unsigned long flags = 0; unsigned long flags = 0;
crystalhd_elem_t *tmp; struct crystalhd_elem *tmp;
crystalhd_elem_t *ret = NULL; struct crystalhd_elem *ret = NULL;
void *data = NULL; void *data = NULL;
if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG)) { if (!ioq || (ioq->sig != BC_LINK_DIOQ_SIG)) {
...@@ -592,7 +592,7 @@ void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag) ...@@ -592,7 +592,7 @@ void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag)
spin_lock_irqsave(&ioq->lock, flags); spin_lock_irqsave(&ioq->lock, flags);
tmp = ioq->head; tmp = ioq->head;
while (tmp != (crystalhd_elem_t *)&ioq->head) { while (tmp != (struct crystalhd_elem *)&ioq->head) {
if (tmp->tag == tag) { if (tmp->tag == tag) {
ret = tmp; ret = tmp;
tmp->flink->blink = tmp->blink; tmp->flink->blink = tmp->blink;
...@@ -623,7 +623,7 @@ void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag) ...@@ -623,7 +623,7 @@ void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag)
* Return element from head if Q is not empty. Wait for new element * Return element from head if Q is not empty. Wait for new element
* if Q is empty for Timeout seconds. * if Q is empty for Timeout seconds.
*/ */
void *crystalhd_dioq_fetch_wait(crystalhd_dioq_t *ioq, uint32_t to_secs, void *crystalhd_dioq_fetch_wait(struct crystalhd_dioq *ioq, uint32_t to_secs,
uint32_t *sig_pend) uint32_t *sig_pend)
{ {
unsigned long flags = 0; unsigned long flags = 0;
...@@ -673,12 +673,12 @@ void *crystalhd_dioq_fetch_wait(crystalhd_dioq_t *ioq, uint32_t to_secs, ...@@ -673,12 +673,12 @@ void *crystalhd_dioq_fetch_wait(crystalhd_dioq_t *ioq, uint32_t to_secs,
* This routine maps user address and lock pages for DMA. * This routine maps user address and lock pages for DMA.
* *
*/ */
BC_STATUS crystalhd_map_dio(struct crystalhd_adp *adp, void *ubuff, enum BC_STATUS crystalhd_map_dio(struct crystalhd_adp *adp, void *ubuff,
uint32_t ubuff_sz, uint32_t uv_offset, uint32_t ubuff_sz, uint32_t uv_offset,
bool en_422mode, bool dir_tx, bool en_422mode, bool dir_tx,
crystalhd_dio_req **dio_hnd) struct crystalhd_dio_req **dio_hnd)
{ {
crystalhd_dio_req *dio; struct crystalhd_dio_req *dio;
/* FIXME: jarod: should some of these unsigned longs be uint32_t or uintptr_t? */ /* FIXME: jarod: should some of these unsigned longs be uint32_t or uintptr_t? */
unsigned long start = 0, end = 0, uaddr = 0, count = 0; unsigned long start = 0, end = 0, uaddr = 0, count = 0;
unsigned long spsz = 0, uv_start = 0; unsigned long spsz = 0, uv_start = 0;
...@@ -820,7 +820,7 @@ BC_STATUS crystalhd_map_dio(struct crystalhd_adp *adp, void *ubuff, ...@@ -820,7 +820,7 @@ BC_STATUS crystalhd_map_dio(struct crystalhd_adp *adp, void *ubuff,
* *
* This routine is to unmap the user buffer pages. * This routine is to unmap the user buffer pages.
*/ */
BC_STATUS crystalhd_unmap_dio(struct crystalhd_adp *adp, crystalhd_dio_req *dio) enum BC_STATUS crystalhd_unmap_dio(struct crystalhd_adp *adp, struct crystalhd_dio_req *dio)
{ {
struct page *page = NULL; struct page *page = NULL;
int j = 0; int j = 0;
...@@ -864,7 +864,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages) ...@@ -864,7 +864,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages)
{ {
uint32_t asz = 0, i = 0; uint32_t asz = 0, i = 0;
uint8_t *temp; uint8_t *temp;
crystalhd_dio_req *dio; struct crystalhd_dio_req *dio;
if (!adp || !max_pages) { if (!adp || !max_pages) {
BCMLOG_ERR("Invalid Arg!!\n"); BCMLOG_ERR("Invalid Arg!!\n");
...@@ -893,7 +893,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages) ...@@ -893,7 +893,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages)
return -ENOMEM; return -ENOMEM;
} }
dio = (crystalhd_dio_req *)temp; dio = (struct crystalhd_dio_req *)temp;
temp += sizeof(*dio); temp += sizeof(*dio);
dio->pages = (struct page **)temp; dio->pages = (struct page **)temp;
temp += (sizeof(*dio->pages) * max_pages); temp += (sizeof(*dio->pages) * max_pages);
...@@ -923,7 +923,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages) ...@@ -923,7 +923,7 @@ int crystalhd_create_dio_pool(struct crystalhd_adp *adp, uint32_t max_pages)
*/ */
void crystalhd_destroy_dio_pool(struct crystalhd_adp *adp) void crystalhd_destroy_dio_pool(struct crystalhd_adp *adp)
{ {
crystalhd_dio_req *dio; struct crystalhd_dio_req *dio;
int count = 0; int count = 0;
if (!adp) { if (!adp) {
...@@ -965,7 +965,7 @@ int __devinit crystalhd_create_elem_pool(struct crystalhd_adp *adp, ...@@ -965,7 +965,7 @@ int __devinit crystalhd_create_elem_pool(struct crystalhd_adp *adp,
uint32_t pool_size) uint32_t pool_size)
{ {
uint32_t i; uint32_t i;
crystalhd_elem_t *temp; struct crystalhd_elem *temp;
if (!adp || !pool_size) if (!adp || !pool_size)
return -EINVAL; return -EINVAL;
...@@ -993,7 +993,7 @@ int __devinit crystalhd_create_elem_pool(struct crystalhd_adp *adp, ...@@ -993,7 +993,7 @@ int __devinit crystalhd_create_elem_pool(struct crystalhd_adp *adp,
*/ */
void crystalhd_delete_elem_pool(struct crystalhd_adp *adp) void crystalhd_delete_elem_pool(struct crystalhd_adp *adp)
{ {
crystalhd_elem_t *temp; struct crystalhd_elem *temp;
int dbg_cnt = 0; int dbg_cnt = 0;
if (!adp) if (!adp)
......
...@@ -54,7 +54,7 @@ extern uint32_t g_linklog_level; ...@@ -54,7 +54,7 @@ extern uint32_t g_linklog_level;
/* Scatter Gather memory pool size for Tx and Rx */ /* Scatter Gather memory pool size for Tx and Rx */
#define BC_LINK_SG_POOL_SZ (BC_TX_LIST_CNT + BC_RX_LIST_CNT) #define BC_LINK_SG_POOL_SZ (BC_TX_LIST_CNT + BC_RX_LIST_CNT)
enum _crystalhd_dio_sig { enum crystalhd_dio_sig {
crystalhd_dio_inv = 0, crystalhd_dio_inv = 0,
crystalhd_dio_locked, crystalhd_dio_locked,
crystalhd_dio_sg_mapped, crystalhd_dio_sg_mapped,
...@@ -76,7 +76,7 @@ struct crystalhd_dio_user_info { ...@@ -76,7 +76,7 @@ struct crystalhd_dio_user_info {
bool b422mode; bool b422mode;
}; };
typedef struct _crystalhd_dio_req { struct crystalhd_dio_req {
uint32_t sig; uint32_t sig;
uint32_t max_pages; uint32_t max_pages;
struct page **pages; struct page **pages;
...@@ -88,34 +88,34 @@ typedef struct _crystalhd_dio_req { ...@@ -88,34 +88,34 @@ typedef struct _crystalhd_dio_req {
void *fb_va; void *fb_va;
uint32_t fb_size; uint32_t fb_size;
dma_addr_t fb_pa; dma_addr_t fb_pa;
struct _crystalhd_dio_req *next; struct crystalhd_dio_req *next;
} crystalhd_dio_req; };
#define BC_LINK_DIOQ_SIG (0x09223280) #define BC_LINK_DIOQ_SIG (0x09223280)
typedef struct _crystalhd_elem_s { struct crystalhd_elem {
struct _crystalhd_elem_s *flink; struct crystalhd_elem *flink;
struct _crystalhd_elem_s *blink; struct crystalhd_elem *blink;
void *data; void *data;
uint32_t tag; uint32_t tag;
} crystalhd_elem_t; };
typedef void (*crystalhd_data_free_cb)(void *context, void *data); typedef void (*crystalhd_data_free_cb)(void *context, void *data);
typedef struct _crystalhd_dioq_s { struct crystalhd_dioq {
uint32_t sig; uint32_t sig;
struct crystalhd_adp *adp; struct crystalhd_adp *adp;
crystalhd_elem_t *head; struct crystalhd_elem *head;
crystalhd_elem_t *tail; struct crystalhd_elem *tail;
uint32_t count; uint32_t count;
spinlock_t lock; spinlock_t lock;
wait_queue_head_t event; wait_queue_head_t event;
crystalhd_data_free_cb data_rel_cb; crystalhd_data_free_cb data_rel_cb;
void *cb_context; void *cb_context;
} crystalhd_dioq_t; };
typedef void (*hw_comp_callback)(crystalhd_dio_req *, typedef void (*hw_comp_callback)(struct crystalhd_dio_req *,
wait_queue_head_t *event, BC_STATUS sts); wait_queue_head_t *event, enum BC_STATUS sts);
/*========= Decoder (7412) register access routines.================= */ /*========= Decoder (7412) register access routines.================= */
uint32_t bc_dec_reg_rd(struct crystalhd_adp *, uint32_t); uint32_t bc_dec_reg_rd(struct crystalhd_adp *, uint32_t);
...@@ -126,12 +126,12 @@ uint32_t crystalhd_reg_rd(struct crystalhd_adp *, uint32_t); ...@@ -126,12 +126,12 @@ uint32_t crystalhd_reg_rd(struct crystalhd_adp *, uint32_t);
void crystalhd_reg_wr(struct crystalhd_adp *, uint32_t, uint32_t); void crystalhd_reg_wr(struct crystalhd_adp *, uint32_t, uint32_t);
/*========= Decoder (7412) memory access routines..=================*/ /*========= Decoder (7412) memory access routines..=================*/
BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *); enum BC_STATUS crystalhd_mem_rd(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *);
BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *); enum BC_STATUS crystalhd_mem_wr(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *);
/*==========Link (70012) PCIe Config access routines.================*/ /*==========Link (70012) PCIe Config access routines.================*/
BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *); enum BC_STATUS crystalhd_pci_cfg_rd(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t *);
BC_STATUS crystalhd_pci_cfg_wr(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t); enum BC_STATUS crystalhd_pci_cfg_wr(struct crystalhd_adp *, uint32_t, uint32_t, uint32_t);
/*========= Linux Kernel Interface routines. ======================= */ /*========= Linux Kernel Interface routines. ======================= */
void *bc_kern_dma_alloc(struct crystalhd_adp *, uint32_t, dma_addr_t *); void *bc_kern_dma_alloc(struct crystalhd_adp *, uint32_t, dma_addr_t *);
...@@ -167,20 +167,20 @@ do { \ ...@@ -167,20 +167,20 @@ do { \
/*================ Direct IO mapping routines ==================*/ /*================ Direct IO mapping routines ==================*/
extern int crystalhd_create_dio_pool(struct crystalhd_adp *, uint32_t); extern int crystalhd_create_dio_pool(struct crystalhd_adp *, uint32_t);
extern void crystalhd_destroy_dio_pool(struct crystalhd_adp *); extern void crystalhd_destroy_dio_pool(struct crystalhd_adp *);
extern BC_STATUS crystalhd_map_dio(struct crystalhd_adp *, void *, uint32_t, extern enum BC_STATUS crystalhd_map_dio(struct crystalhd_adp *, void *, uint32_t,
uint32_t, bool, bool, crystalhd_dio_req**); uint32_t, bool, bool, struct crystalhd_dio_req**);
extern BC_STATUS crystalhd_unmap_dio(struct crystalhd_adp *, crystalhd_dio_req*); extern enum BC_STATUS crystalhd_unmap_dio(struct crystalhd_adp *, struct crystalhd_dio_req*);
#define crystalhd_get_sgle_paddr(_dio, _ix) (cpu_to_le64(sg_dma_address(&_dio->sg[_ix]))) #define crystalhd_get_sgle_paddr(_dio, _ix) (cpu_to_le64(sg_dma_address(&_dio->sg[_ix])))
#define crystalhd_get_sgle_len(_dio, _ix) (cpu_to_le32(sg_dma_len(&_dio->sg[_ix]))) #define crystalhd_get_sgle_len(_dio, _ix) (cpu_to_le32(sg_dma_len(&_dio->sg[_ix])))
/*================ General Purpose Queues ==================*/ /*================ General Purpose Queues ==================*/
extern BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *, crystalhd_dioq_t **, crystalhd_data_free_cb , void *); extern enum BC_STATUS crystalhd_create_dioq(struct crystalhd_adp *, struct crystalhd_dioq **, crystalhd_data_free_cb , void *);
extern void crystalhd_delete_dioq(struct crystalhd_adp *, crystalhd_dioq_t *); extern void crystalhd_delete_dioq(struct crystalhd_adp *, struct crystalhd_dioq *);
extern BC_STATUS crystalhd_dioq_add(crystalhd_dioq_t *ioq, void *data, bool wake, uint32_t tag); extern enum BC_STATUS crystalhd_dioq_add(struct crystalhd_dioq *ioq, void *data, bool wake, uint32_t tag);
extern void *crystalhd_dioq_fetch(crystalhd_dioq_t *ioq); extern void *crystalhd_dioq_fetch(struct crystalhd_dioq *ioq);
extern void *crystalhd_dioq_find_and_fetch(crystalhd_dioq_t *ioq, uint32_t tag); extern void *crystalhd_dioq_find_and_fetch(struct crystalhd_dioq *ioq, uint32_t tag);
extern void *crystalhd_dioq_fetch_wait(crystalhd_dioq_t *ioq, uint32_t to_secs, uint32_t *sig_pend); extern void *crystalhd_dioq_fetch_wait(struct crystalhd_dioq *ioq, uint32_t to_secs, uint32_t *sig_pend);
#define crystalhd_dioq_count(_ioq) ((_ioq) ? _ioq->count : 0) #define crystalhd_dioq_count(_ioq) ((_ioq) ? _ioq->count : 0)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment