diff options
Diffstat (limited to 'arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h')
-rw-r--r-- | arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h | 162 |
1 files changed, 162 insertions, 0 deletions
diff --git a/arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h b/arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h new file mode 100644 index 0000000..5c62252 --- /dev/null +++ b/arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h @@ -0,0 +1,162 @@ +/* linux/arch/arm/mach-exynos/include/mach/regs-fimg2d3x.h + * + * Copyright (c) 2010 Samsung Electronics Co., Ltd. + * http://www.samsung.com/ + * + * Register Definitions for Samsung Graphics 2D Hardware + * + * 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 __ASM_ARCH_REGS_FIMG2D3X_H +#define __ASM_ARCH_REGS_FIMG2D3X_H __FILE__ + +/* Macros */ +#define FIMG2D_ADDR(v) ((v) << 0) +#define FIMG2D_STRIDE(v) (((v) & (0xffff)) << 0) +#define FIMG2D_OFFSET(x, y) ((((y) & 0x1fff) << 16) | (((x) & 0x1fff) << 0)) +#define FIMG2D_SIZE(w, h) ((((h) & 0x1fff) << 16) | (((w) & 0x1fff) << 0)) +#define FIMG2D_COLOR(v) ((v) << 0) + +/* Registers */ +#define FIMG2D_SOFT_RESET_REG (0x000) +#define FIMG2D_INTEN_REG (0x004) +#define FIMG2D_INTC_PEND_REG (0x00c) +#define FIMG2D_FIFO_STAT_REG (0x010) +#define FIMG2D_AXI_ID_MODE_REG (0x014) +#define FIMG2D_CACHECTL_REG (0x018) +#define FIMG2D_BITBLT_START_REG (0x100) +#define FIMG2D_BITBLT_COMMAND_REG (0x104) +#define FIMG2D_ROTATE_REG (0x200) +#define FIMG2D_SRC_MSK_DIRECT_REG (0x204) +#define FIMG2D_DST_PAT_DIRECT_REG (0x208) +#define FIMG2D_SRC_SELECT_REG (0x300) +#define FIMG2D_SRC_BASE_ADDR_REG (0x304) +#define FIMG2D_SRC_STRIDE_REG (0x308) +#define FIMG2D_SRC_COLOR_MODE_REG (0x30c) +#define FIMG2D_SRC_LEFT_TOP_REG (0x310) +#define FIMG2D_SRC_RIGHT_BOTTOM_REG (0x314) +#define FIMG2D_DST_SELECT_REG (0x400) +#define FIMG2D_DST_BASE_ADDR_REG (0x404) +#define FIMG2D_DST_STRIDE_REG (0x408) +#define FIMG2D_DST_COLOR_MODE_REG (0x40c) +#define FIMG2D_DST_LEFT_TOP_REG (0x410) +#define FIMG2D_DST_RIGHT_BOTTOM_REG (0x414) +#define FIMG2D_PAT_BASE_ADDR_REG (0x500) +#define FIMG2D_PAT_SIZE_REG (0x504) +#define FIMG2D_PAT_COLOR_MODE_REG (0x508) +#define FIMG2D_PAT_OFFSET_REG (0x50c) +#define FIMG2D_PAT_STRIDE_REG (0x510) +#define FIMG2D_CW_LT_REG (0x600) +#define FIMG2D_CW_RB_REG (0x604) +#define FIMG2D_THIRD_OPERAND_REG (0x610) +#define FIMG2D_ROP4_REG (0x614) +#define FIMG2D_ALPHA_REG (0x618) +#define FIMG2D_FG_COLOR_REG (0x700) +#define FIMG2D_BG_COLOR_REG (0x704) +#define FIMG2D_BS_COLOR_REG (0x708) +#define FIMG2D_SRC_COLORKEY_CTRL_REG (0x710) +#define FIMG2D_SRC_COLORKEY_DR_MIN_REG (0x714) +#define FIMG2D_SRC_COLORKEY_DR_MAX_REG (0x718) +#define FIMG2D_DST_COLORKEY_CTRL_REG (0x71c) +#define FIMG2D_DST_COLORKEY_DR_MIN_REG (0x720) +#define FIMG2D_DST_COLORKEY_DR_MAX_REG (0x724) + +/* Bit Definitions */ + +/* SOFT_RESET_REG */ +#define FIMG2D_SOFT_RESET (1 << 0) + +/* INTEN_REG */ +#define FIMG2D_INT_EN (1 << 0) + +/* INTC_PEND_REG */ +#define FIMG2D_INTP_CMD_FIN (1 << 0) + +/* FIFO_STAT_REG */ +#define FIMG2D_CMD_FIN (1 << 0) + +/* CACHECTL_REG */ +#define FIMG2D_PATCACHE_CLEAR (1 << 2) +#define FIMG2D_SRCBUFFER_CLEAR (1 << 1) +#define FIMG2D_MASKBUFFER_CLEAR (1 << 0) + +/* BITBLT_START_REG */ +#define FIMG2D_START_BITBLT (1 << 0) + +/* BITBLT_COMMAND_REG */ +#define FIMG2D_NONPREBLEND_DISABLE (0 << 22) +#define FIMG2D_NONPREBLEND_CONSTANT (1 << 22) +#define FIMG2D_NONPREBLEND_PERPIXEL (2 << 22) +#define FIMG2D_NONPREBLEND_MASK (3 << 22) + +#define FIMG2D_ALPHA_MODE_NONE (0 << 20) +#define FIMG2D_ALPHA_MODE_ALPHA (1 << 20) +#define FIMG2D_ALPHA_MODE_FADING (2 << 20) +#define FIMG2D_ALPHA_MODE_MASK (3 << 20) + +#define FIMG2D_ENABLE_CW (1 << 8) +#define FIMG2D_ENABLE_STRETCH (1 << 4) +#define FIMG2D_ENABLE_MASK (1 << 0) + +/* ROTATE_REG */ +#define FIMG2D_ROTATE_90_ENABLE (1 << 0) + +/* SRC_MSK_DIRECT_REG */ +#define FIMG2D_MSK_X_DIR_NEGATIVE (1 << 4) +#define FIMG2D_MSK_Y_DIR_NEGATIVE (1 << 5) +#define FIMG2D_MSK_DIR_MASK (3 << 4) + +#define FIMG2D_SRC_X_DIR_NEGATIVE (1 << 0) +#define FIMG2D_SRC_Y_DIR_NEGATIVE (1 << 1) +#define FIMG2D_SRC_DIR_MASK (3 << 0) + +/* DST_PAT_DIRECT_REG */ +#define FIMG2D_PAT_X_DIR_NEGATIVE (1 << 4) +#define FIMG2D_PAT_Y_DIR_NEGATIVE (1 << 5) +#define FIMG2D_PAT_DIR_MASK (3 << 4) + +#define FIMG2D_DST_X_DIR_NEGATIVE (1 << 0) +#define FIMG2D_DST_Y_DIR_NEGATIVE (1 << 1) +#define FIMG2D_DST_DIR_MASK (3 << 0) + +/* XXX_SELECT_REG */ +#define FIMG2D_IMG_TYPE_MEMORY (0 << 0) +#define FIMG2D_IMG_TYPE_FGCOLOR (1 << 0) +#define FIMG2D_IMG_TYPE_BGCOLOR (2 << 0) +#define FIMG2D_IMG_TYPE_MASK (3 << 0) + +/* XXX_COLOR_MODE_REG */ +#define FIMG2D_CHANNEL_ORDER_SHIFT (4) +#define FIMG2D_COLOR_FORMAT_SHIFT (0) + +/* XXX_LEFT_TOP_REG & XXX_RIGHT_BOTTOM_REG */ +#define FIMG2D_COORD_TOP_Y_SHIFT (16) +#define FIMG2D_COORD_LEFT_X_SHIFT (0) +#define FIMG2D_COORD_BOTTOM_Y_SHIFT (16) +#define FIMG2D_COORD_RIGHT_X_SHIFT (0) + +/* THIRD_OPERAND_REG */ +#define FIMG2D_MASKED_OPR3_PATTERN (0 << 4) +#define FIMG2D_MASKED_OPR3_FGCOLOR (1 << 4) +#define FIMG2D_MASKED_OPR3_BGCOLOR (2 << 4) +#define FIMG2D_MASKED_OPR3_MASK (3 << 4) + +#define FIMG2D_UNMASKED_OPR3_PATTERN (0 << 0) +#define FIMG2D_UNMASKED_OPR3_FGCOLOR (1 << 0) +#define FIMG2D_UNMASKED_OPR3_BGCOLOR (2 << 0) +#define FIMG2D_UNMASKED_OPR3_MASK (3 << 0) + +/* ROP4_REG */ +#define FIMG2D_MASKED_ROP3_SHIFT (8) +#define FIMG2D_UNMASKED_ROP3_SHIFT (0) + +/* ALPHA_REG */ +#define FIMG2D_FADING_OFFSET_SHIFT (8) +#define FIMG2D_FADING_OFFSET_MASK (0xff) +#define FIMG2D_ALPHA_VALUE_SHIFT (0) +#define FIMG2D_ALPHA_VALUE_MASK (0xff) + +#endif /* __ASM_MACH_REGS_FIMG2D3X_H */ |