while (pvr_fw_irq_pending(pvr_dev)) {
pvr_fw_irq_clear(pvr_dev);
- if (pvr_dev->fw_dev.initialised) {
+ if (READ_ONCE(pvr_dev->fw_dev.initialised)) {
pvr_fwccb_process(pvr_dev);
pvr_kccb_wake_up_waiters(pvr_dev);
pvr_device_process_active_queues(pvr_dev);
goto err_fw_stop;
}
- fw_dev->initialised = true;
+ WRITE_ONCE(fw_dev->initialised, true);
return 0;
{
struct pvr_fw_device *fw_dev = &pvr_dev->fw_dev;
- fw_dev->initialised = false;
+ WRITE_ONCE(fw_dev->initialised, false);
pvr_fw_destroy_structures(pvr_dev);
pvr_fw_object_unmap_and_destroy(pvr_dev->kccb.rtn_obj);
return -EIO;
/* Can't flush MMU if the firmware hasn't been initialised yet. */
- if (!pvr_dev->fw_dev.initialised)
+ if (!READ_ONCE(pvr_dev->fw_dev.initialised))
goto err_drm_dev_exit;
cmd_mmu_cache_data->cache_flags =
if (pm_runtime_get_if_in_use(from_pvr_device(pvr_dev)->dev) <= 0)
goto out_requeue;
- if (!pvr_dev->fw_dev.initialised)
+ if (!READ_ONCE(pvr_dev->fw_dev.initialised))
goto out_pm_runtime_put;
stalled = pvr_watchdog_kccb_stalled(pvr_dev);
if (!drm_dev_enter(drm_dev, &idx))
return -EIO;
- if (pvr_dev->fw_dev.initialised) {
+ if (READ_ONCE(pvr_dev->fw_dev.initialised)) {
err = pvr_power_fw_disable(pvr_dev, false);
if (err)
goto err_drm_dev_exit;
if (err)
goto err_drm_dev_exit;
- if (pvr_dev->fw_dev.initialised) {
+ if (READ_ONCE(pvr_dev->fw_dev.initialised)) {
err = pvr_power_fw_enable(pvr_dev);
if (err)
goto err_power_off;
err = pvr_power_fw_disable(pvr_dev, hard_reset, false);
if (!err) {
if (hard_reset) {
- pvr_dev->fw_dev.initialised = false;
+ WRITE_ONCE(pvr_dev->fw_dev.initialised, false);
WARN_ON(pvr_power_device_suspend(from_pvr_device(pvr_dev)->dev));
err = pvr_fw_hard_reset(pvr_dev);
goto err_device_lost;
err = pvr_power_device_resume(from_pvr_device(pvr_dev)->dev);
- pvr_dev->fw_dev.initialised = true;
+ WRITE_ONCE(pvr_dev->fw_dev.initialised, true);
if (err)
goto err_device_lost;
} else {