mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-23 19:14:30 +08:00
2025cf9e19
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms and conditions of the gnu general public license version 2 as published by the free software foundation this program is distributed in the hope it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 263 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Alexios Zavras <alexios.zavras@intel.com> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190529141901.208660670@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
44 lines
1004 B
C
44 lines
1004 B
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Copyright (c) 2014, Patrik Jakobsson
|
|
* All Rights Reserved.
|
|
*
|
|
* Authors: Patrik Jakobsson <patrik.r.jakobsson@gmail.com>
|
|
*/
|
|
|
|
#include "psb_drv.h"
|
|
|
|
#include "blitter.h"
|
|
#include "psb_reg.h"
|
|
|
|
/* Wait for the blitter to be completely idle */
|
|
int gma_blt_wait_idle(struct drm_psb_private *dev_priv)
|
|
{
|
|
unsigned long stop = jiffies + HZ;
|
|
int busy = 1;
|
|
|
|
/* NOP for Cedarview */
|
|
if (IS_CDV(dev_priv->dev))
|
|
return 0;
|
|
|
|
/* First do a quick check */
|
|
if ((PSB_RSGX32(PSB_CR_2D_SOCIF) == _PSB_C2_SOCIF_EMPTY) &&
|
|
((PSB_RSGX32(PSB_CR_2D_BLIT_STATUS) & _PSB_C2B_STATUS_BUSY) == 0))
|
|
return 0;
|
|
|
|
do {
|
|
busy = (PSB_RSGX32(PSB_CR_2D_SOCIF) != _PSB_C2_SOCIF_EMPTY);
|
|
} while (busy && !time_after_eq(jiffies, stop));
|
|
|
|
if (busy)
|
|
return -EBUSY;
|
|
|
|
do {
|
|
busy = ((PSB_RSGX32(PSB_CR_2D_BLIT_STATUS) &
|
|
_PSB_C2B_STATUS_BUSY) != 0);
|
|
} while (busy && !time_after_eq(jiffies, stop));
|
|
|
|
/* If still busy, we probably have a hang */
|
|
return (busy) ? -EBUSY : 0;
|
|
}
|