| /* |
| * Copyright (c) 2013 Texas Instruments Inc. |
| * |
| * David Griego, <dagriego@biglakesoftware.com> |
| * Dale Farnsworth, <dale@farnsworth.org> |
| * Archit Taneja, <archit@ti.com> |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 as published by |
| * the Free Software Foundation. |
| */ |
| |
| #ifndef _TI_VPDMA_PRIV_H_ |
| #define _TI_VPDMA_PRIV_H_ |
| |
| /* |
| * VPDMA Register offsets |
| */ |
| |
| /* Top level */ |
| #define VPDMA_PID 0x00 |
| #define VPDMA_LIST_ADDR 0x04 |
| #define VPDMA_LIST_ATTR 0x08 |
| #define VPDMA_LIST_STAT_SYNC 0x0c |
| #define VPDMA_BG_RGB 0x18 |
| #define VPDMA_BG_YUV 0x1c |
| #define VPDMA_SETUP 0x30 |
| #define VPDMA_MAX_SIZE1 0x34 |
| #define VPDMA_MAX_SIZE2 0x38 |
| #define VPDMA_MAX_SIZE3 0x3c |
| |
| /* Interrupts */ |
| #define VPDMA_INT_CHAN_STAT(grp) (0x40 + grp * 8) |
| #define VPDMA_INT_CHAN_MASK(grp) (VPDMA_INT_CHAN_STAT(grp) + 4) |
| #define VPDMA_INT_CLIENT0_STAT 0x78 |
| #define VPDMA_INT_CLIENT0_MASK 0x7c |
| #define VPDMA_INT_CLIENT1_STAT 0x80 |
| #define VPDMA_INT_CLIENT1_MASK 0x84 |
| #define VPDMA_INT_LIST0_STAT 0x88 |
| #define VPDMA_INT_LIST0_MASK 0x8c |
| |
| #define VPDMA_PERFMON(i) (0x200 + i * 4) |
| |
| /* VPE specific client registers */ |
| #define VPDMA_DEI_CHROMA1_CSTAT 0x0300 |
| #define VPDMA_DEI_LUMA1_CSTAT 0x0304 |
| #define VPDMA_DEI_LUMA2_CSTAT 0x0308 |
| #define VPDMA_DEI_CHROMA2_CSTAT 0x030c |
| #define VPDMA_DEI_LUMA3_CSTAT 0x0310 |
| #define VPDMA_DEI_CHROMA3_CSTAT 0x0314 |
| #define VPDMA_DEI_MV_IN_CSTAT 0x0330 |
| #define VPDMA_DEI_MV_OUT_CSTAT 0x033c |
| #define VPDMA_VIP_UP_Y_CSTAT 0x0390 |
| #define VPDMA_VIP_UP_UV_CSTAT 0x0394 |
| #define VPDMA_VPI_CTL_CSTAT 0x03d0 |
| |
| /* Reg field info for VPDMA_CLIENT_CSTAT registers */ |
| #define VPDMA_CSTAT_LINE_MODE_MASK 0x03 |
| #define VPDMA_CSTAT_LINE_MODE_SHIFT 8 |
| #define VPDMA_CSTAT_FRAME_START_MASK 0xf |
| #define VPDMA_CSTAT_FRAME_START_SHIFT 10 |
| |
| #define VPDMA_LIST_NUM_MASK 0x07 |
| #define VPDMA_LIST_NUM_SHFT 24 |
| #define VPDMA_LIST_STOP_SHFT 20 |
| #define VPDMA_LIST_RDY_MASK 0x01 |
| #define VPDMA_LIST_RDY_SHFT 19 |
| #define VPDMA_LIST_TYPE_MASK 0x03 |
| #define VPDMA_LIST_TYPE_SHFT 16 |
| #define VPDMA_LIST_SIZE_MASK 0xffff |
| |
| /* VPDMA data type values for data formats */ |
| #define DATA_TYPE_Y444 0x0 |
| #define DATA_TYPE_Y422 0x1 |
| #define DATA_TYPE_Y420 0x2 |
| #define DATA_TYPE_C444 0x4 |
| #define DATA_TYPE_C422 0x5 |
| #define DATA_TYPE_C420 0x6 |
| #define DATA_TYPE_YC422 0x7 |
| #define DATA_TYPE_YC444 0x8 |
| #define DATA_TYPE_CY422 0x27 |
| |
| #define DATA_TYPE_RGB16_565 0x0 |
| #define DATA_TYPE_ARGB_1555 0x1 |
| #define DATA_TYPE_ARGB_4444 0x2 |
| #define DATA_TYPE_RGBA_5551 0x3 |
| #define DATA_TYPE_RGBA_4444 0x4 |
| #define DATA_TYPE_ARGB24_6666 0x5 |
| #define DATA_TYPE_RGB24_888 0x6 |
| #define DATA_TYPE_ARGB32_8888 0x7 |
| #define DATA_TYPE_RGBA24_6666 0x8 |
| #define DATA_TYPE_RGBA32_8888 0x9 |
| #define DATA_TYPE_BGR16_565 0x10 |
| #define DATA_TYPE_ABGR_1555 0x11 |
| #define DATA_TYPE_ABGR_4444 0x12 |
| #define DATA_TYPE_BGRA_5551 0x13 |
| #define DATA_TYPE_BGRA_4444 0x14 |
| #define DATA_TYPE_ABGR24_6666 0x15 |
| #define DATA_TYPE_BGR24_888 0x16 |
| #define DATA_TYPE_ABGR32_8888 0x17 |
| #define DATA_TYPE_BGRA24_6666 0x18 |
| #define DATA_TYPE_BGRA32_8888 0x19 |
| |
| #define DATA_TYPE_MV 0x3 |
| |
| /* VPDMA channel numbers(only VPE channels for now) */ |
| #define VPE_CHAN_NUM_LUMA1_IN 0 |
| #define VPE_CHAN_NUM_CHROMA1_IN 1 |
| #define VPE_CHAN_NUM_LUMA2_IN 2 |
| #define VPE_CHAN_NUM_CHROMA2_IN 3 |
| #define VPE_CHAN_NUM_LUMA3_IN 4 |
| #define VPE_CHAN_NUM_CHROMA3_IN 5 |
| #define VPE_CHAN_NUM_MV_IN 12 |
| #define VPE_CHAN_NUM_MV_OUT 15 |
| #define VPE_CHAN_NUM_LUMA_OUT 102 |
| #define VPE_CHAN_NUM_CHROMA_OUT 103 |
| #define VPE_CHAN_NUM_RGB_OUT 106 |
| |
| /* |
| * a VPDMA address data block payload for a configuration descriptor needs to |
| * have each sub block length as a multiple of 16 bytes. Therefore, the overall |
| * size of the payload also needs to be a multiple of 16 bytes. The sub block |
| * lengths should be ensured to be aligned by the VPDMA user. |
| */ |
| #define VPDMA_ADB_SIZE_ALIGN 0x0f |
| |
| /* |
| * data transfer descriptor |
| */ |
| struct vpdma_dtd { |
| u32 type_ctl_stride; |
| union { |
| u32 xfer_length_height; |
| u32 w1; |
| }; |
| dma_addr_t start_addr; |
| u32 pkt_ctl; |
| union { |
| u32 frame_width_height; /* inbound */ |
| dma_addr_t desc_write_addr; /* outbound */ |
| }; |
| union { |
| u32 start_h_v; /* inbound */ |
| u32 max_width_height; /* outbound */ |
| }; |
| u32 client_attr0; |
| u32 client_attr1; |
| }; |
| |
| /* Data Transfer Descriptor specifics */ |
| #define DTD_NO_NOTIFY 0 |
| #define DTD_NOTIFY 1 |
| |
| #define DTD_PKT_TYPE 0xa |
| #define DTD_DIR_IN 0 |
| #define DTD_DIR_OUT 1 |
| |
| /* type_ctl_stride */ |
| #define DTD_DATA_TYPE_MASK 0x3f |
| #define DTD_DATA_TYPE_SHFT 26 |
| #define DTD_NOTIFY_MASK 0x01 |
| #define DTD_NOTIFY_SHFT 25 |
| #define DTD_FIELD_MASK 0x01 |
| #define DTD_FIELD_SHFT 24 |
| #define DTD_1D_MASK 0x01 |
| #define DTD_1D_SHFT 23 |
| #define DTD_EVEN_LINE_SKIP_MASK 0x01 |
| #define DTD_EVEN_LINE_SKIP_SHFT 20 |
| #define DTD_ODD_LINE_SKIP_MASK 0x01 |
| #define DTD_ODD_LINE_SKIP_SHFT 16 |
| #define DTD_LINE_STRIDE_MASK 0xffff |
| #define DTD_LINE_STRIDE_SHFT 0 |
| |
| /* xfer_length_height */ |
| #define DTD_LINE_LENGTH_MASK 0xffff |
| #define DTD_LINE_LENGTH_SHFT 16 |
| #define DTD_XFER_HEIGHT_MASK 0xffff |
| #define DTD_XFER_HEIGHT_SHFT 0 |
| |
| /* pkt_ctl */ |
| #define DTD_PKT_TYPE_MASK 0x1f |
| #define DTD_PKT_TYPE_SHFT 27 |
| #define DTD_MODE_MASK 0x01 |
| #define DTD_MODE_SHFT 26 |
| #define DTD_DIR_MASK 0x01 |
| #define DTD_DIR_SHFT 25 |
| #define DTD_CHAN_MASK 0x01ff |
| #define DTD_CHAN_SHFT 16 |
| #define DTD_PRI_MASK 0x0f |
| #define DTD_PRI_SHFT 9 |
| #define DTD_NEXT_CHAN_MASK 0x01ff |
| #define DTD_NEXT_CHAN_SHFT 0 |
| |
| /* frame_width_height */ |
| #define DTD_FRAME_WIDTH_MASK 0xffff |
| #define DTD_FRAME_WIDTH_SHFT 16 |
| #define DTD_FRAME_HEIGHT_MASK 0xffff |
| #define DTD_FRAME_HEIGHT_SHFT 0 |
| |
| /* start_h_v */ |
| #define DTD_H_START_MASK 0xffff |
| #define DTD_H_START_SHFT 16 |
| #define DTD_V_START_MASK 0xffff |
| #define DTD_V_START_SHFT 0 |
| |
| #define DTD_DESC_START_SHIFT 5 |
| #define DTD_WRITE_DESC_MASK 0x01 |
| #define DTD_WRITE_DESC_SHIFT 2 |
| #define DTD_DROP_DATA_MASK 0x01 |
| #define DTD_DROP_DATA_SHIFT 1 |
| #define DTD_USE_DESC_MASK 0x01 |
| #define DTD_USE_DESC_SHIFT 0 |
| |
| /* max_width_height */ |
| #define DTD_MAX_WIDTH_MASK 0x07 |
| #define DTD_MAX_WIDTH_SHFT 4 |
| #define DTD_MAX_HEIGHT_MASK 0x07 |
| #define DTD_MAX_HEIGHT_SHFT 0 |
| |
| /* max width configurations */ |
| /* unlimited width */ |
| #define MAX_OUT_WIDTH_UNLIMITED 0 |
| /* as specified in max_size1 reg */ |
| #define MAX_OUT_WIDTH_REG1 1 |
| /* as specified in max_size2 reg */ |
| #define MAX_OUT_WIDTH_REG2 2 |
| /* as specified in max_size3 reg */ |
| #define MAX_OUT_WIDTH_REG3 3 |
| /* maximum of 352 pixels as width */ |
| #define MAX_OUT_WIDTH_352 4 |
| /* maximum of 768 pixels as width */ |
| #define MAX_OUT_WIDTH_768 5 |
| /* maximum of 1280 pixels width */ |
| #define MAX_OUT_WIDTH_1280 6 |
| /* maximum of 1920 pixels as width */ |
| #define MAX_OUT_WIDTH_1920 7 |
| |
| /* max height configurations */ |
| /* unlimited height */ |
| #define MAX_OUT_HEIGHT_UNLIMITED 0 |
| /* as specified in max_size1 reg */ |
| #define MAX_OUT_HEIGHT_REG1 1 |
| /* as specified in max_size2 reg */ |
| #define MAX_OUT_HEIGHT_REG2 2 |
| /* as specified in max_size3 reg */ |
| #define MAX_OUT_HEIGHT_REG3 3 |
| /* maximum of 288 lines as height */ |
| #define MAX_OUT_HEIGHT_288 4 |
| /* maximum of 576 lines as height */ |
| #define MAX_OUT_HEIGHT_576 5 |
| /* maximum of 720 lines as height */ |
| #define MAX_OUT_HEIGHT_720 6 |
| /* maximum of 1080 lines as height */ |
| #define MAX_OUT_HEIGHT_1080 7 |
| |
| static inline u32 dtd_type_ctl_stride(int type, bool notify, int field, |
| bool one_d, bool even_line_skip, bool odd_line_skip, |
| int line_stride) |
| { |
| return (type << DTD_DATA_TYPE_SHFT) | (notify << DTD_NOTIFY_SHFT) | |
| (field << DTD_FIELD_SHFT) | (one_d << DTD_1D_SHFT) | |
| (even_line_skip << DTD_EVEN_LINE_SKIP_SHFT) | |
| (odd_line_skip << DTD_ODD_LINE_SKIP_SHFT) | |
| line_stride; |
| } |
| |
| static inline u32 dtd_xfer_length_height(int line_length, int xfer_height) |
| { |
| return (line_length << DTD_LINE_LENGTH_SHFT) | xfer_height; |
| } |
| |
| static inline u32 dtd_pkt_ctl(bool mode, bool dir, int chan, int pri, |
| int next_chan) |
| { |
| return (DTD_PKT_TYPE << DTD_PKT_TYPE_SHFT) | (mode << DTD_MODE_SHFT) | |
| (dir << DTD_DIR_SHFT) | (chan << DTD_CHAN_SHFT) | |
| (pri << DTD_PRI_SHFT) | next_chan; |
| } |
| |
| static inline u32 dtd_frame_width_height(int width, int height) |
| { |
| return (width << DTD_FRAME_WIDTH_SHFT) | height; |
| } |
| |
| static inline u32 dtd_desc_write_addr(unsigned int addr, bool write_desc, |
| bool drop_data, bool use_desc) |
| { |
| return (addr << DTD_DESC_START_SHIFT) | |
| (write_desc << DTD_WRITE_DESC_SHIFT) | |
| (drop_data << DTD_DROP_DATA_SHIFT) | |
| use_desc; |
| } |
| |
| static inline u32 dtd_start_h_v(int h_start, int v_start) |
| { |
| return (h_start << DTD_H_START_SHFT) | v_start; |
| } |
| |
| static inline u32 dtd_max_width_height(int max_width, int max_height) |
| { |
| return (max_width << DTD_MAX_WIDTH_SHFT) | max_height; |
| } |
| |
| static inline int dtd_get_data_type(struct vpdma_dtd *dtd) |
| { |
| return dtd->type_ctl_stride >> DTD_DATA_TYPE_SHFT; |
| } |
| |
| static inline bool dtd_get_notify(struct vpdma_dtd *dtd) |
| { |
| return (dtd->type_ctl_stride >> DTD_NOTIFY_SHFT) & DTD_NOTIFY_MASK; |
| } |
| |
| static inline int dtd_get_field(struct vpdma_dtd *dtd) |
| { |
| return (dtd->type_ctl_stride >> DTD_FIELD_SHFT) & DTD_FIELD_MASK; |
| } |
| |
| static inline bool dtd_get_1d(struct vpdma_dtd *dtd) |
| { |
| return (dtd->type_ctl_stride >> DTD_1D_SHFT) & DTD_1D_MASK; |
| } |
| |
| static inline bool dtd_get_even_line_skip(struct vpdma_dtd *dtd) |
| { |
| return (dtd->type_ctl_stride >> DTD_EVEN_LINE_SKIP_SHFT) |
| & DTD_EVEN_LINE_SKIP_MASK; |
| } |
| |
| static inline bool dtd_get_odd_line_skip(struct vpdma_dtd *dtd) |
| { |
| return (dtd->type_ctl_stride >> DTD_ODD_LINE_SKIP_SHFT) |
| & DTD_ODD_LINE_SKIP_MASK; |
| } |
| |
| static inline int dtd_get_line_stride(struct vpdma_dtd *dtd) |
| { |
| return dtd->type_ctl_stride & DTD_LINE_STRIDE_MASK; |
| } |
| |
| static inline int dtd_get_line_length(struct vpdma_dtd *dtd) |
| { |
| return dtd->xfer_length_height >> DTD_LINE_LENGTH_SHFT; |
| } |
| |
| static inline int dtd_get_xfer_height(struct vpdma_dtd *dtd) |
| { |
| return dtd->xfer_length_height & DTD_XFER_HEIGHT_MASK; |
| } |
| |
| static inline int dtd_get_pkt_type(struct vpdma_dtd *dtd) |
| { |
| return dtd->pkt_ctl >> DTD_PKT_TYPE_SHFT; |
| } |
| |
| static inline bool dtd_get_mode(struct vpdma_dtd *dtd) |
| { |
| return (dtd->pkt_ctl >> DTD_MODE_SHFT) & DTD_MODE_MASK; |
| } |
| |
| static inline bool dtd_get_dir(struct vpdma_dtd *dtd) |
| { |
| return (dtd->pkt_ctl >> DTD_DIR_SHFT) & DTD_DIR_MASK; |
| } |
| |
| static inline int dtd_get_chan(struct vpdma_dtd *dtd) |
| { |
| return (dtd->pkt_ctl >> DTD_CHAN_SHFT) & DTD_CHAN_MASK; |
| } |
| |
| static inline int dtd_get_priority(struct vpdma_dtd *dtd) |
| { |
| return (dtd->pkt_ctl >> DTD_PRI_SHFT) & DTD_PRI_MASK; |
| } |
| |
| static inline int dtd_get_next_chan(struct vpdma_dtd *dtd) |
| { |
| return (dtd->pkt_ctl >> DTD_NEXT_CHAN_SHFT) & DTD_NEXT_CHAN_MASK; |
| } |
| |
| static inline int dtd_get_frame_width(struct vpdma_dtd *dtd) |
| { |
| return dtd->frame_width_height >> DTD_FRAME_WIDTH_SHFT; |
| } |
| |
| static inline int dtd_get_frame_height(struct vpdma_dtd *dtd) |
| { |
| return dtd->frame_width_height & DTD_FRAME_HEIGHT_MASK; |
| } |
| |
| static inline int dtd_get_desc_write_addr(struct vpdma_dtd *dtd) |
| { |
| return dtd->desc_write_addr >> DTD_DESC_START_SHIFT; |
| } |
| |
| static inline bool dtd_get_write_desc(struct vpdma_dtd *dtd) |
| { |
| return (dtd->desc_write_addr >> DTD_WRITE_DESC_SHIFT) & |
| DTD_WRITE_DESC_MASK; |
| } |
| |
| static inline bool dtd_get_drop_data(struct vpdma_dtd *dtd) |
| { |
| return (dtd->desc_write_addr >> DTD_DROP_DATA_SHIFT) & |
| DTD_DROP_DATA_MASK; |
| } |
| |
| static inline bool dtd_get_use_desc(struct vpdma_dtd *dtd) |
| { |
| return dtd->desc_write_addr & DTD_USE_DESC_MASK; |
| } |
| |
| static inline int dtd_get_h_start(struct vpdma_dtd *dtd) |
| { |
| return dtd->start_h_v >> DTD_H_START_SHFT; |
| } |
| |
| static inline int dtd_get_v_start(struct vpdma_dtd *dtd) |
| { |
| return dtd->start_h_v & DTD_V_START_MASK; |
| } |
| |
| static inline int dtd_get_max_width(struct vpdma_dtd *dtd) |
| { |
| return (dtd->max_width_height >> DTD_MAX_WIDTH_SHFT) & |
| DTD_MAX_WIDTH_MASK; |
| } |
| |
| static inline int dtd_get_max_height(struct vpdma_dtd *dtd) |
| { |
| return (dtd->max_width_height >> DTD_MAX_HEIGHT_SHFT) & |
| DTD_MAX_HEIGHT_MASK; |
| } |
| |
| /* |
| * configuration descriptor |
| */ |
| struct vpdma_cfd { |
| union { |
| u32 dest_addr_offset; |
| u32 w0; |
| }; |
| union { |
| u32 block_len; /* in words */ |
| u32 w1; |
| }; |
| u32 payload_addr; |
| u32 ctl_payload_len; /* in words */ |
| }; |
| |
| /* Configuration descriptor specifics */ |
| |
| #define CFD_PKT_TYPE 0xb |
| |
| #define CFD_DIRECT 1 |
| #define CFD_INDIRECT 0 |
| #define CFD_CLS_ADB 0 |
| #define CFD_CLS_BLOCK 1 |
| |
| /* block_len */ |
| #define CFD__BLOCK_LEN_MASK 0xffff |
| #define CFD__BLOCK_LEN_SHFT 0 |
| |
| /* ctl_payload_len */ |
| #define CFD_PKT_TYPE_MASK 0x1f |
| #define CFD_PKT_TYPE_SHFT 27 |
| #define CFD_DIRECT_MASK 0x01 |
| #define CFD_DIRECT_SHFT 26 |
| #define CFD_CLASS_MASK 0x03 |
| #define CFD_CLASS_SHFT 24 |
| #define CFD_DEST_MASK 0xff |
| #define CFD_DEST_SHFT 16 |
| #define CFD_PAYLOAD_LEN_MASK 0xffff |
| #define CFD_PAYLOAD_LEN_SHFT 0 |
| |
| static inline u32 cfd_pkt_payload_len(bool direct, int cls, int dest, |
| int payload_len) |
| { |
| return (CFD_PKT_TYPE << CFD_PKT_TYPE_SHFT) | |
| (direct << CFD_DIRECT_SHFT) | |
| (cls << CFD_CLASS_SHFT) | |
| (dest << CFD_DEST_SHFT) | |
| payload_len; |
| } |
| |
| static inline int cfd_get_pkt_type(struct vpdma_cfd *cfd) |
| { |
| return cfd->ctl_payload_len >> CFD_PKT_TYPE_SHFT; |
| } |
| |
| static inline bool cfd_get_direct(struct vpdma_cfd *cfd) |
| { |
| return (cfd->ctl_payload_len >> CFD_DIRECT_SHFT) & CFD_DIRECT_MASK; |
| } |
| |
| static inline bool cfd_get_class(struct vpdma_cfd *cfd) |
| { |
| return (cfd->ctl_payload_len >> CFD_CLASS_SHFT) & CFD_CLASS_MASK; |
| } |
| |
| static inline int cfd_get_dest(struct vpdma_cfd *cfd) |
| { |
| return (cfd->ctl_payload_len >> CFD_DEST_SHFT) & CFD_DEST_MASK; |
| } |
| |
| static inline int cfd_get_payload_len(struct vpdma_cfd *cfd) |
| { |
| return cfd->ctl_payload_len & CFD_PAYLOAD_LEN_MASK; |
| } |
| |
| /* |
| * control descriptor |
| */ |
| struct vpdma_ctd { |
| union { |
| u32 timer_value; |
| u32 list_addr; |
| u32 w0; |
| }; |
| union { |
| u32 pixel_line_count; |
| u32 list_size; |
| u32 w1; |
| }; |
| union { |
| u32 event; |
| u32 fid_ctl; |
| u32 w2; |
| }; |
| u32 type_source_ctl; |
| }; |
| |
| /* control descriptor types */ |
| #define CTD_TYPE_SYNC_ON_CLIENT 0 |
| #define CTD_TYPE_SYNC_ON_LIST 1 |
| #define CTD_TYPE_SYNC_ON_EXT 2 |
| #define CTD_TYPE_SYNC_ON_LM_TIMER 3 |
| #define CTD_TYPE_SYNC_ON_CHANNEL 4 |
| #define CTD_TYPE_CHNG_CLIENT_IRQ 5 |
| #define CTD_TYPE_SEND_IRQ 6 |
| #define CTD_TYPE_RELOAD_LIST 7 |
| #define CTD_TYPE_ABORT_CHANNEL 8 |
| |
| #define CTD_PKT_TYPE 0xc |
| |
| /* timer_value */ |
| #define CTD_TIMER_VALUE_MASK 0xffff |
| #define CTD_TIMER_VALUE_SHFT 0 |
| |
| /* pixel_line_count */ |
| #define CTD_PIXEL_COUNT_MASK 0xffff |
| #define CTD_PIXEL_COUNT_SHFT 16 |
| #define CTD_LINE_COUNT_MASK 0xffff |
| #define CTD_LINE_COUNT_SHFT 0 |
| |
| /* list_size */ |
| #define CTD_LIST_SIZE_MASK 0xffff |
| #define CTD_LIST_SIZE_SHFT 0 |
| |
| /* event */ |
| #define CTD_EVENT_MASK 0x0f |
| #define CTD_EVENT_SHFT 0 |
| |
| /* fid_ctl */ |
| #define CTD_FID2_MASK 0x03 |
| #define CTD_FID2_SHFT 4 |
| #define CTD_FID1_MASK 0x03 |
| #define CTD_FID1_SHFT 2 |
| #define CTD_FID0_MASK 0x03 |
| #define CTD_FID0_SHFT 0 |
| |
| /* type_source_ctl */ |
| #define CTD_PKT_TYPE_MASK 0x1f |
| #define CTD_PKT_TYPE_SHFT 27 |
| #define CTD_SOURCE_MASK 0xff |
| #define CTD_SOURCE_SHFT 16 |
| #define CTD_CONTROL_MASK 0x0f |
| #define CTD_CONTROL_SHFT 0 |
| |
| static inline u32 ctd_pixel_line_count(int pixel_count, int line_count) |
| { |
| return (pixel_count << CTD_PIXEL_COUNT_SHFT) | line_count; |
| } |
| |
| static inline u32 ctd_set_fid_ctl(int fid0, int fid1, int fid2) |
| { |
| return (fid2 << CTD_FID2_SHFT) | (fid1 << CTD_FID1_SHFT) | fid0; |
| } |
| |
| static inline u32 ctd_type_source_ctl(int source, int control) |
| { |
| return (CTD_PKT_TYPE << CTD_PKT_TYPE_SHFT) | |
| (source << CTD_SOURCE_SHFT) | control; |
| } |
| |
| static inline u32 ctd_get_pixel_count(struct vpdma_ctd *ctd) |
| { |
| return ctd->pixel_line_count >> CTD_PIXEL_COUNT_SHFT; |
| } |
| |
| static inline int ctd_get_line_count(struct vpdma_ctd *ctd) |
| { |
| return ctd->pixel_line_count & CTD_LINE_COUNT_MASK; |
| } |
| |
| static inline int ctd_get_event(struct vpdma_ctd *ctd) |
| { |
| return ctd->event & CTD_EVENT_MASK; |
| } |
| |
| static inline int ctd_get_fid2_ctl(struct vpdma_ctd *ctd) |
| { |
| return (ctd->fid_ctl >> CTD_FID2_SHFT) & CTD_FID2_MASK; |
| } |
| |
| static inline int ctd_get_fid1_ctl(struct vpdma_ctd *ctd) |
| { |
| return (ctd->fid_ctl >> CTD_FID1_SHFT) & CTD_FID1_MASK; |
| } |
| |
| static inline int ctd_get_fid0_ctl(struct vpdma_ctd *ctd) |
| { |
| return ctd->fid_ctl & CTD_FID2_MASK; |
| } |
| |
| static inline int ctd_get_pkt_type(struct vpdma_ctd *ctd) |
| { |
| return ctd->type_source_ctl >> CTD_PKT_TYPE_SHFT; |
| } |
| |
| static inline int ctd_get_source(struct vpdma_ctd *ctd) |
| { |
| return (ctd->type_source_ctl >> CTD_SOURCE_SHFT) & CTD_SOURCE_MASK; |
| } |
| |
| static inline int ctd_get_ctl(struct vpdma_ctd *ctd) |
| { |
| return ctd->type_source_ctl & CTD_CONTROL_MASK; |
| } |
| |
| #endif |