
This patch supports HIP based video processing subsystem by reorganizing the HLS generated code to align with xilinx driver guidelines. Signed-off-by: Rohit Consul <rohit.consul@xilinx.com> Reviewed-by: Andrei Simion <andreis@xilinx.com>
143 lines
6 KiB
C
143 lines
6 KiB
C
// ==============================================================
|
|
// File generated by Vivado(TM) HLS - High-Level Synthesis from C, C++ and SystemC
|
|
// Version: 2015.1
|
|
// Copyright (C) 2015 Xilinx Inc. All rights reserved.
|
|
//
|
|
// ==============================================================
|
|
|
|
#ifndef XV_HCRESAMPLER_H
|
|
#define XV_HCRESAMPLER_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/***************************** Include Files *********************************/
|
|
#ifndef __linux__
|
|
#include "xil_types.h"
|
|
#include "xil_assert.h"
|
|
#include "xstatus.h"
|
|
#include "xil_io.h"
|
|
#else
|
|
#include <stdint.h>
|
|
#include <assert.h>
|
|
#include <dirent.h>
|
|
#include <fcntl.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <sys/mman.h>
|
|
#include <unistd.h>
|
|
#include <stddef.h>
|
|
#endif
|
|
#include "xv_hcresampler_hw.h"
|
|
|
|
/**************************** Type Definitions ******************************/
|
|
#ifdef __linux__
|
|
typedef uint8_t u8;
|
|
typedef uint16_t u16;
|
|
typedef uint32_t u32;
|
|
#else
|
|
/**
|
|
* This typedef contains configuration information for the horziontal
|
|
* chroma resampler core. Each core instance should have a configuration
|
|
* structure associated.
|
|
*/
|
|
typedef struct {
|
|
u16 DeviceId; /**< Unique ID of device */
|
|
u32 BaseAddress; /**< The base address of the core instance. */
|
|
int PixPerClk; /**< Samples Per Clock supported by core instance */
|
|
u16 MaxWidth; /**< Maximum columns supported by core instance */
|
|
u16 MaxHeight; /**< Maximum rows supported by core instance */
|
|
int MaxDataWidth; /**< Maximum Data width of each channel */
|
|
int ResamplingType; /**< Resampling Method selected */
|
|
u8 NumTaps; /**< Number of filter taps */
|
|
} XV_hcresampler_Config;
|
|
#endif
|
|
|
|
/**
|
|
* Driver instance data. An instance must be allocated for each core in use.
|
|
*/
|
|
typedef struct {
|
|
XV_hcresampler_Config Config; /**< Hardware Configuration */
|
|
u32 IsReady; /**< Device is initialized and ready */
|
|
} XV_hcresampler;
|
|
|
|
/***************** Macros (Inline Functions) Definitions *********************/
|
|
#ifndef __linux__
|
|
#define XV_hcresampler_WriteReg(BaseAddress, RegOffset, Data) \
|
|
Xil_Out32((BaseAddress) + (RegOffset), (u32)(Data))
|
|
#define XV_hcresampler_ReadReg(BaseAddress, RegOffset) \
|
|
Xil_In32((BaseAddress) + (RegOffset))
|
|
#else
|
|
#define XV_hcresampler_WriteReg(BaseAddress, RegOffset, Data) \
|
|
*(volatile u32*)((BaseAddress) + (RegOffset)) = (u32)(Data)
|
|
#define XV_hcresampler_ReadReg(BaseAddress, RegOffset) \
|
|
*(volatile u32*)((BaseAddress) + (RegOffset))
|
|
|
|
#define Xil_AssertVoid(expr) assert(expr)
|
|
#define Xil_AssertNonvoid(expr) assert(expr)
|
|
|
|
#define XST_SUCCESS 0
|
|
#define XST_DEVICE_NOT_FOUND 2
|
|
#define XST_OPEN_DEVICE_FAILED 3
|
|
#define XIL_COMPONENT_IS_READY 1
|
|
#endif
|
|
|
|
/************************** Function Prototypes *****************************/
|
|
#ifndef __linux__
|
|
int XV_hcresampler_Initialize(XV_hcresampler *InstancePtr, u16 DeviceId);
|
|
XV_hcresampler_Config* XV_hcresampler_LookupConfig(u16 DeviceId);
|
|
int XV_hcresampler_CfgInitialize(XV_hcresampler *InstancePtr,
|
|
XV_hcresampler_Config *ConfigPtr,
|
|
u32 EffectiveAddr);
|
|
#else
|
|
int XV_hcresampler_Initialize(XV_hcresampler *InstancePtr, const char* InstanceName);
|
|
int XV_hcresampler_Release(XV_hcresampler *InstancePtr);
|
|
#endif
|
|
|
|
void XV_hcresampler_Start(XV_hcresampler *InstancePtr);
|
|
u32 XV_hcresampler_IsDone(XV_hcresampler *InstancePtr);
|
|
u32 XV_hcresampler_IsIdle(XV_hcresampler *InstancePtr);
|
|
u32 XV_hcresampler_IsReady(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_EnableAutoRestart(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_DisableAutoRestart(XV_hcresampler *InstancePtr);
|
|
|
|
void XV_hcresampler_Set_HwReg_width(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_width(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_height(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_height(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_input_video_format(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_input_video_format(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_output_video_format(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_output_video_format(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_0_0(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_0_0(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_0_1(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_0_1(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_0_2(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_0_2(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_0_3(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_0_3(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_1_0(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_1_0(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_1_1(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_1_1(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_1_2(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_1_2(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_Set_HwReg_coefs_1_3(XV_hcresampler *InstancePtr, u32 Data);
|
|
u32 XV_hcresampler_Get_HwReg_coefs_1_3(XV_hcresampler *InstancePtr);
|
|
|
|
void XV_hcresampler_InterruptGlobalEnable(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_InterruptGlobalDisable(XV_hcresampler *InstancePtr);
|
|
void XV_hcresampler_InterruptEnable(XV_hcresampler *InstancePtr, u32 Mask);
|
|
void XV_hcresampler_InterruptDisable(XV_hcresampler *InstancePtr, u32 Mask);
|
|
void XV_hcresampler_InterruptClear(XV_hcresampler *InstancePtr, u32 Mask);
|
|
u32 XV_hcresampler_InterruptGetEnabled(XV_hcresampler *InstancePtr);
|
|
u32 XV_hcresampler_InterruptGetStatus(XV_hcresampler *InstancePtr);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|