Commit 9a9b138e authored by Bingbu Cao's avatar Bingbu Cao Committed by Mauro Carvalho Chehab

media: staging: imgu: make imgu work on low frequency for low input

Currently, imgu is working on 450MHz for all cases, however
in some cases (input frame less than 2048x1152), the imgu
did not need work in high frequency.
This patch make imgu work on 200MHz if the imgu input
frame is less than 2048x1152 to save power.
Signed-off-by: default avatarBingbu Cao <bingbu.cao@intel.com>
Reviewed-by: default avatarTomasz Figa <tfiga@chromium.org>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 6de18fa3
...@@ -210,12 +210,12 @@ static int imgu_hw_wait(void __iomem *base, int reg, u32 mask, u32 cmp) ...@@ -210,12 +210,12 @@ static int imgu_hw_wait(void __iomem *base, int reg, u32 mask, u32 cmp)
/* Initialize the IPU3 CSS hardware and associated h/w blocks */ /* Initialize the IPU3 CSS hardware and associated h/w blocks */
int imgu_css_set_powerup(struct device *dev, void __iomem *base) int imgu_css_set_powerup(struct device *dev, void __iomem *base,
unsigned int freq)
{ {
static const unsigned int freq = 450;
u32 pm_ctrl, state, val; u32 pm_ctrl, state, val;
dev_dbg(dev, "%s\n", __func__); dev_dbg(dev, "%s with freq %u\n", __func__, freq);
/* Clear the CSS busy signal */ /* Clear the CSS busy signal */
readl(base + IMGU_REG_GP_BUSY); readl(base + IMGU_REG_GP_BUSY);
writel(0, base + IMGU_REG_GP_BUSY); writel(0, base + IMGU_REG_GP_BUSY);
......
...@@ -187,7 +187,8 @@ bool imgu_css_is_streaming(struct imgu_css *css); ...@@ -187,7 +187,8 @@ bool imgu_css_is_streaming(struct imgu_css *css);
bool imgu_css_pipe_queue_empty(struct imgu_css *css, unsigned int pipe); bool imgu_css_pipe_queue_empty(struct imgu_css *css, unsigned int pipe);
/******************* css hw *******************/ /******************* css hw *******************/
int imgu_css_set_powerup(struct device *dev, void __iomem *base); int imgu_css_set_powerup(struct device *dev, void __iomem *base,
unsigned int freq);
void imgu_css_set_powerdown(struct device *dev, void __iomem *base); void imgu_css_set_powerdown(struct device *dev, void __iomem *base);
int imgu_css_irq_ack(struct imgu_css *css); int imgu_css_irq_ack(struct imgu_css *css);
......
...@@ -345,8 +345,20 @@ int imgu_queue_buffers(struct imgu_device *imgu, bool initial, unsigned int pipe ...@@ -345,8 +345,20 @@ int imgu_queue_buffers(struct imgu_device *imgu, bool initial, unsigned int pipe
static int imgu_powerup(struct imgu_device *imgu) static int imgu_powerup(struct imgu_device *imgu)
{ {
int r; int r;
unsigned int pipe;
unsigned int freq = 200;
struct v4l2_mbus_framefmt *fmt;
/* input larger than 2048*1152, ask imgu to work on high freq */
for_each_set_bit(pipe, imgu->css.enabled_pipes, IMGU_MAX_PIPE_NUM) {
fmt = &imgu->imgu_pipe[pipe].nodes[IMGU_NODE_IN].pad_fmt;
dev_dbg(&imgu->pci_dev->dev, "pipe %u input format = %ux%u",
pipe, fmt->width, fmt->height);
if ((fmt->width * fmt->height) >= (2048 * 1152))
freq = 450;
}
r = imgu_css_set_powerup(&imgu->pci_dev->dev, imgu->base); r = imgu_css_set_powerup(&imgu->pci_dev->dev, imgu->base, freq);
if (r) if (r)
return r; return r;
...@@ -666,7 +678,7 @@ static int imgu_pci_probe(struct pci_dev *pci_dev, ...@@ -666,7 +678,7 @@ static int imgu_pci_probe(struct pci_dev *pci_dev,
atomic_set(&imgu->qbuf_barrier, 0); atomic_set(&imgu->qbuf_barrier, 0);
init_waitqueue_head(&imgu->buf_drain_wq); init_waitqueue_head(&imgu->buf_drain_wq);
r = imgu_css_set_powerup(&pci_dev->dev, imgu->base); r = imgu_css_set_powerup(&pci_dev->dev, imgu->base, 200);
if (r) { if (r) {
dev_err(&pci_dev->dev, dev_err(&pci_dev->dev,
"failed to power up CSS (%d)\n", r); "failed to power up CSS (%d)\n", r);
......
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