cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

mxc-jpeg-hw.c (4896B)


      1// SPDX-License-Identifier: GPL-2.0
      2/*
      3 * i.MX8QXP/i.MX8QM JPEG encoder/decoder v4l2 driver
      4 *
      5 * Copyright 2018-2019 NXP
      6 */
      7
      8#include <linux/delay.h>
      9#include <media/videobuf2-core.h>
     10#include "mxc-jpeg-hw.h"
     11
     12#define print_wrapper_reg(dev, base_address, reg_offset)\
     13		internal_print_wrapper_reg(dev, (base_address), #reg_offset,\
     14					   (reg_offset))
     15#define internal_print_wrapper_reg(dev, base_address, reg_name, reg_offset) {\
     16		int val;\
     17		val = readl((base_address) + (reg_offset));\
     18		dev_dbg(dev, "Wrapper reg %s = 0x%x\n", reg_name, val);\
     19}
     20
     21void print_descriptor_info(struct device *dev, struct mxc_jpeg_desc *desc)
     22{
     23	dev_dbg(dev, " MXC JPEG NEXT_DESCPT_PTR 0x%x\n",
     24		desc->next_descpt_ptr);
     25	dev_dbg(dev, " MXC JPEG BUF_BASE0 0x%x\n", desc->buf_base0);
     26	dev_dbg(dev, " MXC JPEG BUF_BASE1 0x%x\n", desc->buf_base1);
     27	dev_dbg(dev, " MXC JPEG LINE_PITCH %d\n", desc->line_pitch);
     28	dev_dbg(dev, " MXC JPEG STM_BUFBASE 0x%x\n", desc->stm_bufbase);
     29	dev_dbg(dev, " MXC JPEG STM_BUFSIZE %d\n", desc->stm_bufsize);
     30	dev_dbg(dev, " MXC JPEG IMGSIZE %x (%d x %d)\n", desc->imgsize,
     31		desc->imgsize >> 16, desc->imgsize & 0xFFFF);
     32	dev_dbg(dev, " MXC JPEG STM_CTRL 0x%x\n", desc->stm_ctrl);
     33}
     34
     35void print_cast_status(struct device *dev, void __iomem *reg,
     36		       unsigned int mode)
     37{
     38	dev_dbg(dev, "CAST IP status regs:\n");
     39	print_wrapper_reg(dev, reg, CAST_STATUS0);
     40	print_wrapper_reg(dev, reg, CAST_STATUS1);
     41	print_wrapper_reg(dev, reg, CAST_STATUS2);
     42	print_wrapper_reg(dev, reg, CAST_STATUS3);
     43	print_wrapper_reg(dev, reg, CAST_STATUS4);
     44	print_wrapper_reg(dev, reg, CAST_STATUS5);
     45	print_wrapper_reg(dev, reg, CAST_STATUS6);
     46	print_wrapper_reg(dev, reg, CAST_STATUS7);
     47	print_wrapper_reg(dev, reg, CAST_STATUS8);
     48	print_wrapper_reg(dev, reg, CAST_STATUS9);
     49	print_wrapper_reg(dev, reg, CAST_STATUS10);
     50	print_wrapper_reg(dev, reg, CAST_STATUS11);
     51	print_wrapper_reg(dev, reg, CAST_STATUS12);
     52	print_wrapper_reg(dev, reg, CAST_STATUS13);
     53	if (mode == MXC_JPEG_DECODE)
     54		return;
     55	print_wrapper_reg(dev, reg, CAST_STATUS14);
     56	print_wrapper_reg(dev, reg, CAST_STATUS15);
     57	print_wrapper_reg(dev, reg, CAST_STATUS16);
     58	print_wrapper_reg(dev, reg, CAST_STATUS17);
     59	print_wrapper_reg(dev, reg, CAST_STATUS18);
     60	print_wrapper_reg(dev, reg, CAST_STATUS19);
     61}
     62
     63void print_wrapper_info(struct device *dev, void __iomem *reg)
     64{
     65	dev_dbg(dev, "Wrapper regs:\n");
     66	print_wrapper_reg(dev, reg, GLB_CTRL);
     67	print_wrapper_reg(dev, reg, COM_STATUS);
     68	print_wrapper_reg(dev, reg, BUF_BASE0);
     69	print_wrapper_reg(dev, reg, BUF_BASE1);
     70	print_wrapper_reg(dev, reg, LINE_PITCH);
     71	print_wrapper_reg(dev, reg, STM_BUFBASE);
     72	print_wrapper_reg(dev, reg, STM_BUFSIZE);
     73	print_wrapper_reg(dev, reg, IMGSIZE);
     74	print_wrapper_reg(dev, reg, STM_CTRL);
     75}
     76
     77void mxc_jpeg_enable_irq(void __iomem *reg, int slot)
     78{
     79	writel(0xFFFFFFFF, reg + MXC_SLOT_OFFSET(slot, SLOT_IRQ_EN));
     80}
     81
     82void mxc_jpeg_sw_reset(void __iomem *reg)
     83{
     84	/*
     85	 * engine soft reset, internal state machine reset
     86	 * this will not reset registers, however, it seems
     87	 * the registers may remain inconsistent with the internal state
     88	 * so, on purpose, at least let GLB_CTRL bits clear after this reset
     89	 */
     90	writel(GLB_CTRL_SFT_RST, reg + GLB_CTRL);
     91}
     92
     93void mxc_jpeg_enc_mode_conf(struct device *dev, void __iomem *reg)
     94{
     95	dev_dbg(dev, "CAST Encoder CONFIG...\n");
     96	/*
     97	 * "Config_Mode" enabled, "Config_Mode auto clear enabled",
     98	 */
     99	writel(0xa0, reg + CAST_MODE);
    100
    101	/* all markers and segments */
    102	writel(0x3ff, reg + CAST_CFG_MODE);
    103
    104	/* quality factor */
    105	writel(0x4b, reg + CAST_QUALITY);
    106}
    107
    108void mxc_jpeg_enc_mode_go(struct device *dev, void __iomem *reg)
    109{
    110	dev_dbg(dev, "CAST Encoder GO...\n");
    111	/*
    112	 * "GO" enabled, "GO bit auto clear" enabled
    113	 */
    114	writel(0x140, reg + CAST_MODE);
    115}
    116
    117void mxc_jpeg_dec_mode_go(struct device *dev, void __iomem *reg)
    118{
    119	dev_dbg(dev, "CAST Decoder GO...\n");
    120	writel(MXC_DEC_EXIT_IDLE_MODE, reg + CAST_CTRL);
    121}
    122
    123int mxc_jpeg_enable(void __iomem *reg)
    124{
    125	u32 regval;
    126
    127	writel(GLB_CTRL_JPG_EN, reg + GLB_CTRL);
    128	regval = readl(reg);
    129	return regval;
    130}
    131
    132void mxc_jpeg_enable_slot(void __iomem *reg, int slot)
    133{
    134	u32 regval;
    135
    136	regval = readl(reg + GLB_CTRL);
    137	writel(GLB_CTRL_SLOT_EN(slot) | regval, reg + GLB_CTRL);
    138}
    139
    140void mxc_jpeg_set_l_endian(void __iomem *reg, int le)
    141{
    142	u32 regval;
    143
    144	regval = readl(reg + GLB_CTRL);
    145	regval &= ~GLB_CTRL_L_ENDIAN(1); /* clear */
    146	writel(GLB_CTRL_L_ENDIAN(le) | regval, reg + GLB_CTRL); /* set */
    147}
    148
    149void mxc_jpeg_set_bufsize(struct mxc_jpeg_desc *desc,  u32 bufsize)
    150{
    151	desc->stm_bufsize = bufsize;
    152}
    153
    154void mxc_jpeg_set_res(struct mxc_jpeg_desc *desc, u16 w, u16 h)
    155{
    156	desc->imgsize = w << 16 | h;
    157}
    158
    159void mxc_jpeg_set_line_pitch(struct mxc_jpeg_desc *desc, u32 line_pitch)
    160{
    161	desc->line_pitch = line_pitch;
    162}
    163
    164void mxc_jpeg_set_desc(u32 desc, void __iomem *reg, int slot)
    165{
    166	writel(desc | MXC_NXT_DESCPT_EN,
    167	       reg + MXC_SLOT_OFFSET(slot, SLOT_NXT_DESCPT_PTR));
    168}