Commit 356583b9 authored by Dave Airlie's avatar Dave Airlie

Merge tag 'drm-misc-fixes-2020-11-05' of git://anongit.freedesktop.org/drm/drm-misc into drm-fixes

Some patches for vc4 to fix some resources cleanup issues, two fixes for
panfrost for madvise and the shrinker and a constification of fonts
structure
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>

From: Maxime Ripard <maxime@cerno.tech>
Link: https://patchwork.freedesktop.org/patch/msgid/20201105101354.socyu26jwyns7lfj@gilmour.lan
parents f56fb012 9522750c
...@@ -626,6 +626,7 @@ static int panfrost_probe(struct platform_device *pdev) ...@@ -626,6 +626,7 @@ static int panfrost_probe(struct platform_device *pdev)
err_out1: err_out1:
pm_runtime_disable(pfdev->dev); pm_runtime_disable(pfdev->dev);
panfrost_device_fini(pfdev); panfrost_device_fini(pfdev);
pm_runtime_set_suspended(pfdev->dev);
err_out0: err_out0:
drm_dev_put(ddev); drm_dev_put(ddev);
return err; return err;
...@@ -640,9 +641,9 @@ static int panfrost_remove(struct platform_device *pdev) ...@@ -640,9 +641,9 @@ static int panfrost_remove(struct platform_device *pdev)
panfrost_gem_shrinker_cleanup(ddev); panfrost_gem_shrinker_cleanup(ddev);
pm_runtime_get_sync(pfdev->dev); pm_runtime_get_sync(pfdev->dev);
panfrost_device_fini(pfdev);
pm_runtime_put_sync_suspend(pfdev->dev);
pm_runtime_disable(pfdev->dev); pm_runtime_disable(pfdev->dev);
panfrost_device_fini(pfdev);
pm_runtime_set_suspended(pfdev->dev);
drm_dev_put(ddev); drm_dev_put(ddev);
return 0; return 0;
......
...@@ -105,14 +105,12 @@ void panfrost_gem_mapping_put(struct panfrost_gem_mapping *mapping) ...@@ -105,14 +105,12 @@ void panfrost_gem_mapping_put(struct panfrost_gem_mapping *mapping)
kref_put(&mapping->refcount, panfrost_gem_mapping_release); kref_put(&mapping->refcount, panfrost_gem_mapping_release);
} }
void panfrost_gem_teardown_mappings(struct panfrost_gem_object *bo) void panfrost_gem_teardown_mappings_locked(struct panfrost_gem_object *bo)
{ {
struct panfrost_gem_mapping *mapping; struct panfrost_gem_mapping *mapping;
mutex_lock(&bo->mappings.lock);
list_for_each_entry(mapping, &bo->mappings.list, node) list_for_each_entry(mapping, &bo->mappings.list, node)
panfrost_gem_teardown_mapping(mapping); panfrost_gem_teardown_mapping(mapping);
mutex_unlock(&bo->mappings.lock);
} }
int panfrost_gem_open(struct drm_gem_object *obj, struct drm_file *file_priv) int panfrost_gem_open(struct drm_gem_object *obj, struct drm_file *file_priv)
......
...@@ -82,7 +82,7 @@ struct panfrost_gem_mapping * ...@@ -82,7 +82,7 @@ struct panfrost_gem_mapping *
panfrost_gem_mapping_get(struct panfrost_gem_object *bo, panfrost_gem_mapping_get(struct panfrost_gem_object *bo,
struct panfrost_file_priv *priv); struct panfrost_file_priv *priv);
void panfrost_gem_mapping_put(struct panfrost_gem_mapping *mapping); void panfrost_gem_mapping_put(struct panfrost_gem_mapping *mapping);
void panfrost_gem_teardown_mappings(struct panfrost_gem_object *bo); void panfrost_gem_teardown_mappings_locked(struct panfrost_gem_object *bo);
void panfrost_gem_shrinker_init(struct drm_device *dev); void panfrost_gem_shrinker_init(struct drm_device *dev);
void panfrost_gem_shrinker_cleanup(struct drm_device *dev); void panfrost_gem_shrinker_cleanup(struct drm_device *dev);
......
...@@ -40,18 +40,26 @@ static bool panfrost_gem_purge(struct drm_gem_object *obj) ...@@ -40,18 +40,26 @@ static bool panfrost_gem_purge(struct drm_gem_object *obj)
{ {
struct drm_gem_shmem_object *shmem = to_drm_gem_shmem_obj(obj); struct drm_gem_shmem_object *shmem = to_drm_gem_shmem_obj(obj);
struct panfrost_gem_object *bo = to_panfrost_bo(obj); struct panfrost_gem_object *bo = to_panfrost_bo(obj);
bool ret = false;
if (atomic_read(&bo->gpu_usecount)) if (atomic_read(&bo->gpu_usecount))
return false; return false;
if (!mutex_trylock(&shmem->pages_lock)) if (!mutex_trylock(&bo->mappings.lock))
return false; return false;
panfrost_gem_teardown_mappings(bo); if (!mutex_trylock(&shmem->pages_lock))
goto unlock_mappings;
panfrost_gem_teardown_mappings_locked(bo);
drm_gem_shmem_purge_locked(obj); drm_gem_shmem_purge_locked(obj);
ret = true;
mutex_unlock(&shmem->pages_lock); mutex_unlock(&shmem->pages_lock);
return true;
unlock_mappings:
mutex_unlock(&bo->mappings.lock);
return ret;
} }
static unsigned long static unsigned long
......
...@@ -449,7 +449,7 @@ struct vc4_bo *vc4_bo_create(struct drm_device *dev, size_t unaligned_size, ...@@ -449,7 +449,7 @@ struct vc4_bo *vc4_bo_create(struct drm_device *dev, size_t unaligned_size,
} }
if (IS_ERR(cma_obj)) { if (IS_ERR(cma_obj)) {
struct drm_printer p = drm_info_printer(vc4->dev->dev); struct drm_printer p = drm_info_printer(vc4->base.dev);
DRM_ERROR("Failed to allocate from CMA:\n"); DRM_ERROR("Failed to allocate from CMA:\n");
vc4_bo_stats_print(&p, vc4); vc4_bo_stats_print(&p, vc4);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
...@@ -590,7 +590,7 @@ static void vc4_bo_cache_time_work(struct work_struct *work) ...@@ -590,7 +590,7 @@ static void vc4_bo_cache_time_work(struct work_struct *work)
{ {
struct vc4_dev *vc4 = struct vc4_dev *vc4 =
container_of(work, struct vc4_dev, bo_cache.time_work); container_of(work, struct vc4_dev, bo_cache.time_work);
struct drm_device *dev = vc4->dev; struct drm_device *dev = &vc4->base;
mutex_lock(&vc4->bo_lock); mutex_lock(&vc4->bo_lock);
vc4_bo_cache_free_old(dev); vc4_bo_cache_free_old(dev);
...@@ -1005,6 +1005,7 @@ int vc4_get_tiling_ioctl(struct drm_device *dev, void *data, ...@@ -1005,6 +1005,7 @@ int vc4_get_tiling_ioctl(struct drm_device *dev, void *data,
return 0; return 0;
} }
static void vc4_bo_cache_destroy(struct drm_device *dev, void *unused);
int vc4_bo_cache_init(struct drm_device *dev) int vc4_bo_cache_init(struct drm_device *dev)
{ {
struct vc4_dev *vc4 = to_vc4_dev(dev); struct vc4_dev *vc4 = to_vc4_dev(dev);
...@@ -1033,10 +1034,10 @@ int vc4_bo_cache_init(struct drm_device *dev) ...@@ -1033,10 +1034,10 @@ int vc4_bo_cache_init(struct drm_device *dev)
INIT_WORK(&vc4->bo_cache.time_work, vc4_bo_cache_time_work); INIT_WORK(&vc4->bo_cache.time_work, vc4_bo_cache_time_work);
timer_setup(&vc4->bo_cache.time_timer, vc4_bo_cache_time_timer, 0); timer_setup(&vc4->bo_cache.time_timer, vc4_bo_cache_time_timer, 0);
return 0; return drmm_add_action_or_reset(dev, vc4_bo_cache_destroy, NULL);
} }
void vc4_bo_cache_destroy(struct drm_device *dev) static void vc4_bo_cache_destroy(struct drm_device *dev, void *unused)
{ {
struct vc4_dev *vc4 = to_vc4_dev(dev); struct vc4_dev *vc4 = to_vc4_dev(dev);
int i; int i;
......
...@@ -257,37 +257,37 @@ static int vc4_drm_bind(struct device *dev) ...@@ -257,37 +257,37 @@ static int vc4_drm_bind(struct device *dev)
dev->coherent_dma_mask = DMA_BIT_MASK(32); dev->coherent_dma_mask = DMA_BIT_MASK(32);
vc4 = devm_kzalloc(dev, sizeof(*vc4), GFP_KERNEL);
if (!vc4)
return -ENOMEM;
/* If VC4 V3D is missing, don't advertise render nodes. */ /* If VC4 V3D is missing, don't advertise render nodes. */
node = of_find_matching_node_and_match(NULL, vc4_v3d_dt_match, NULL); node = of_find_matching_node_and_match(NULL, vc4_v3d_dt_match, NULL);
if (!node || !of_device_is_available(node)) if (!node || !of_device_is_available(node))
vc4_drm_driver.driver_features &= ~DRIVER_RENDER; vc4_drm_driver.driver_features &= ~DRIVER_RENDER;
of_node_put(node); of_node_put(node);
drm = drm_dev_alloc(&vc4_drm_driver, dev); vc4 = devm_drm_dev_alloc(dev, &vc4_drm_driver, struct vc4_dev, base);
if (IS_ERR(drm)) if (IS_ERR(vc4))
return PTR_ERR(drm); return PTR_ERR(vc4);
drm = &vc4->base;
platform_set_drvdata(pdev, drm); platform_set_drvdata(pdev, drm);
vc4->dev = drm;
drm->dev_private = vc4;
INIT_LIST_HEAD(&vc4->debugfs_list); INIT_LIST_HEAD(&vc4->debugfs_list);
mutex_init(&vc4->bin_bo_lock); mutex_init(&vc4->bin_bo_lock);
ret = vc4_bo_cache_init(drm); ret = vc4_bo_cache_init(drm);
if (ret) if (ret)
goto dev_put; return ret;
drm_mode_config_init(drm); ret = drmm_mode_config_init(drm);
if (ret)
return ret;
vc4_gem_init(drm); ret = vc4_gem_init(drm);
if (ret)
return ret;
ret = component_bind_all(dev, drm); ret = component_bind_all(dev, drm);
if (ret) if (ret)
goto gem_destroy; return ret;
ret = vc4_plane_create_additional_planes(drm); ret = vc4_plane_create_additional_planes(drm);
if (ret) if (ret)
...@@ -312,30 +312,17 @@ static int vc4_drm_bind(struct device *dev) ...@@ -312,30 +312,17 @@ static int vc4_drm_bind(struct device *dev)
unbind_all: unbind_all:
component_unbind_all(dev, drm); component_unbind_all(dev, drm);
gem_destroy:
vc4_gem_destroy(drm);
drm_mode_config_cleanup(drm);
vc4_bo_cache_destroy(drm);
dev_put:
drm_dev_put(drm);
return ret; return ret;
} }
static void vc4_drm_unbind(struct device *dev) static void vc4_drm_unbind(struct device *dev)
{ {
struct drm_device *drm = dev_get_drvdata(dev); struct drm_device *drm = dev_get_drvdata(dev);
struct vc4_dev *vc4 = to_vc4_dev(drm);
drm_dev_unregister(drm); drm_dev_unregister(drm);
drm_atomic_helper_shutdown(drm); drm_atomic_helper_shutdown(drm);
drm_mode_config_cleanup(drm);
drm_atomic_private_obj_fini(&vc4->load_tracker);
drm_atomic_private_obj_fini(&vc4->ctm_manager);
drm_dev_put(drm);
} }
static const struct component_master_ops vc4_drm_ops = { static const struct component_master_ops vc4_drm_ops = {
......
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
#include <drm/drm_device.h> #include <drm/drm_device.h>
#include <drm/drm_encoder.h> #include <drm/drm_encoder.h>
#include <drm/drm_gem_cma_helper.h> #include <drm/drm_gem_cma_helper.h>
#include <drm/drm_managed.h>
#include <drm/drm_mm.h> #include <drm/drm_mm.h>
#include <drm/drm_modeset_lock.h> #include <drm/drm_modeset_lock.h>
...@@ -71,7 +72,7 @@ struct vc4_perfmon { ...@@ -71,7 +72,7 @@ struct vc4_perfmon {
}; };
struct vc4_dev { struct vc4_dev {
struct drm_device *dev; struct drm_device base;
struct vc4_hvs *hvs; struct vc4_hvs *hvs;
struct vc4_v3d *v3d; struct vc4_v3d *v3d;
...@@ -234,7 +235,7 @@ struct vc4_dev { ...@@ -234,7 +235,7 @@ struct vc4_dev {
static inline struct vc4_dev * static inline struct vc4_dev *
to_vc4_dev(struct drm_device *dev) to_vc4_dev(struct drm_device *dev)
{ {
return (struct vc4_dev *)dev->dev_private; return container_of(dev, struct vc4_dev, base);
} }
struct vc4_bo { struct vc4_bo {
...@@ -809,7 +810,6 @@ struct drm_gem_object *vc4_prime_import_sg_table(struct drm_device *dev, ...@@ -809,7 +810,6 @@ struct drm_gem_object *vc4_prime_import_sg_table(struct drm_device *dev,
struct sg_table *sgt); struct sg_table *sgt);
void *vc4_prime_vmap(struct drm_gem_object *obj); void *vc4_prime_vmap(struct drm_gem_object *obj);
int vc4_bo_cache_init(struct drm_device *dev); int vc4_bo_cache_init(struct drm_device *dev);
void vc4_bo_cache_destroy(struct drm_device *dev);
int vc4_bo_inc_usecnt(struct vc4_bo *bo); int vc4_bo_inc_usecnt(struct vc4_bo *bo);
void vc4_bo_dec_usecnt(struct vc4_bo *bo); void vc4_bo_dec_usecnt(struct vc4_bo *bo);
void vc4_bo_add_to_purgeable_pool(struct vc4_bo *bo); void vc4_bo_add_to_purgeable_pool(struct vc4_bo *bo);
...@@ -874,8 +874,7 @@ extern struct platform_driver vc4_dsi_driver; ...@@ -874,8 +874,7 @@ extern struct platform_driver vc4_dsi_driver;
extern const struct dma_fence_ops vc4_fence_ops; extern const struct dma_fence_ops vc4_fence_ops;
/* vc4_gem.c */ /* vc4_gem.c */
void vc4_gem_init(struct drm_device *dev); int vc4_gem_init(struct drm_device *dev);
void vc4_gem_destroy(struct drm_device *dev);
int vc4_submit_cl_ioctl(struct drm_device *dev, void *data, int vc4_submit_cl_ioctl(struct drm_device *dev, void *data,
struct drm_file *file_priv); struct drm_file *file_priv);
int vc4_wait_seqno_ioctl(struct drm_device *dev, void *data, int vc4_wait_seqno_ioctl(struct drm_device *dev, void *data,
......
...@@ -314,16 +314,16 @@ vc4_reset_work(struct work_struct *work) ...@@ -314,16 +314,16 @@ vc4_reset_work(struct work_struct *work)
struct vc4_dev *vc4 = struct vc4_dev *vc4 =
container_of(work, struct vc4_dev, hangcheck.reset_work); container_of(work, struct vc4_dev, hangcheck.reset_work);
vc4_save_hang_state(vc4->dev); vc4_save_hang_state(&vc4->base);
vc4_reset(vc4->dev); vc4_reset(&vc4->base);
} }
static void static void
vc4_hangcheck_elapsed(struct timer_list *t) vc4_hangcheck_elapsed(struct timer_list *t)
{ {
struct vc4_dev *vc4 = from_timer(vc4, t, hangcheck.timer); struct vc4_dev *vc4 = from_timer(vc4, t, hangcheck.timer);
struct drm_device *dev = vc4->dev; struct drm_device *dev = &vc4->base;
uint32_t ct0ca, ct1ca; uint32_t ct0ca, ct1ca;
unsigned long irqflags; unsigned long irqflags;
struct vc4_exec_info *bin_exec, *render_exec; struct vc4_exec_info *bin_exec, *render_exec;
...@@ -1000,7 +1000,7 @@ vc4_job_handle_completed(struct vc4_dev *vc4) ...@@ -1000,7 +1000,7 @@ vc4_job_handle_completed(struct vc4_dev *vc4)
list_del(&exec->head); list_del(&exec->head);
spin_unlock_irqrestore(&vc4->job_lock, irqflags); spin_unlock_irqrestore(&vc4->job_lock, irqflags);
vc4_complete_exec(vc4->dev, exec); vc4_complete_exec(&vc4->base, exec);
spin_lock_irqsave(&vc4->job_lock, irqflags); spin_lock_irqsave(&vc4->job_lock, irqflags);
} }
...@@ -1258,13 +1258,13 @@ vc4_submit_cl_ioctl(struct drm_device *dev, void *data, ...@@ -1258,13 +1258,13 @@ vc4_submit_cl_ioctl(struct drm_device *dev, void *data,
return 0; return 0;
fail: fail:
vc4_complete_exec(vc4->dev, exec); vc4_complete_exec(&vc4->base, exec);
return ret; return ret;
} }
void static void vc4_gem_destroy(struct drm_device *dev, void *unused);
vc4_gem_init(struct drm_device *dev) int vc4_gem_init(struct drm_device *dev)
{ {
struct vc4_dev *vc4 = to_vc4_dev(dev); struct vc4_dev *vc4 = to_vc4_dev(dev);
...@@ -1285,10 +1285,11 @@ vc4_gem_init(struct drm_device *dev) ...@@ -1285,10 +1285,11 @@ vc4_gem_init(struct drm_device *dev)
INIT_LIST_HEAD(&vc4->purgeable.list); INIT_LIST_HEAD(&vc4->purgeable.list);
mutex_init(&vc4->purgeable.lock); mutex_init(&vc4->purgeable.lock);
return drmm_add_action_or_reset(dev, vc4_gem_destroy, NULL);
} }
void static void vc4_gem_destroy(struct drm_device *dev, void *unused)
vc4_gem_destroy(struct drm_device *dev)
{ {
struct vc4_dev *vc4 = to_vc4_dev(dev); struct vc4_dev *vc4 = to_vc4_dev(dev);
......
...@@ -560,7 +560,7 @@ static int vc4_hvs_bind(struct device *dev, struct device *master, void *data) ...@@ -560,7 +560,7 @@ static int vc4_hvs_bind(struct device *dev, struct device *master, void *data)
{ {
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct drm_device *drm = dev_get_drvdata(master); struct drm_device *drm = dev_get_drvdata(master);
struct vc4_dev *vc4 = drm->dev_private; struct vc4_dev *vc4 = to_vc4_dev(drm);
struct vc4_hvs *hvs = NULL; struct vc4_hvs *hvs = NULL;
int ret; int ret;
u32 dispctrl; u32 dispctrl;
...@@ -679,7 +679,7 @@ static void vc4_hvs_unbind(struct device *dev, struct device *master, ...@@ -679,7 +679,7 @@ static void vc4_hvs_unbind(struct device *dev, struct device *master,
void *data) void *data)
{ {
struct drm_device *drm = dev_get_drvdata(master); struct drm_device *drm = dev_get_drvdata(master);
struct vc4_dev *vc4 = drm->dev_private; struct vc4_dev *vc4 = to_vc4_dev(drm);
struct vc4_hvs *hvs = vc4->hvs; struct vc4_hvs *hvs = vc4->hvs;
if (drm_mm_node_allocated(&vc4->hvs->mitchell_netravali_filter)) if (drm_mm_node_allocated(&vc4->hvs->mitchell_netravali_filter))
......
...@@ -51,7 +51,7 @@ static struct vc4_ctm_state *vc4_get_ctm_state(struct drm_atomic_state *state, ...@@ -51,7 +51,7 @@ static struct vc4_ctm_state *vc4_get_ctm_state(struct drm_atomic_state *state,
struct drm_private_obj *manager) struct drm_private_obj *manager)
{ {
struct drm_device *dev = state->dev; struct drm_device *dev = state->dev;
struct vc4_dev *vc4 = dev->dev_private; struct vc4_dev *vc4 = to_vc4_dev(dev);
struct drm_private_state *priv_state; struct drm_private_state *priv_state;
int ret; int ret;
...@@ -93,6 +93,29 @@ static const struct drm_private_state_funcs vc4_ctm_state_funcs = { ...@@ -93,6 +93,29 @@ static const struct drm_private_state_funcs vc4_ctm_state_funcs = {
.atomic_destroy_state = vc4_ctm_destroy_state, .atomic_destroy_state = vc4_ctm_destroy_state,
}; };
static void vc4_ctm_obj_fini(struct drm_device *dev, void *unused)
{
struct vc4_dev *vc4 = to_vc4_dev(dev);
drm_atomic_private_obj_fini(&vc4->ctm_manager);
}
static int vc4_ctm_obj_init(struct vc4_dev *vc4)
{
struct vc4_ctm_state *ctm_state;
drm_modeset_lock_init(&vc4->ctm_state_lock);
ctm_state = kzalloc(sizeof(*ctm_state), GFP_KERNEL);
if (!ctm_state)
return -ENOMEM;
drm_atomic_private_obj_init(&vc4->base, &vc4->ctm_manager, &ctm_state->base,
&vc4_ctm_state_funcs);
return drmm_add_action(&vc4->base, vc4_ctm_obj_fini, NULL);
}
/* Converts a DRM S31.32 value to the HW S0.9 format. */ /* Converts a DRM S31.32 value to the HW S0.9 format. */
static u16 vc4_ctm_s31_32_to_s0_9(u64 in) static u16 vc4_ctm_s31_32_to_s0_9(u64 in)
{ {
...@@ -609,6 +632,34 @@ static const struct drm_private_state_funcs vc4_load_tracker_state_funcs = { ...@@ -609,6 +632,34 @@ static const struct drm_private_state_funcs vc4_load_tracker_state_funcs = {
.atomic_destroy_state = vc4_load_tracker_destroy_state, .atomic_destroy_state = vc4_load_tracker_destroy_state,
}; };
static void vc4_load_tracker_obj_fini(struct drm_device *dev, void *unused)
{
struct vc4_dev *vc4 = to_vc4_dev(dev);
if (!vc4->load_tracker_available)
return;
drm_atomic_private_obj_fini(&vc4->load_tracker);
}
static int vc4_load_tracker_obj_init(struct vc4_dev *vc4)
{
struct vc4_load_tracker_state *load_state;
if (!vc4->load_tracker_available)
return 0;
load_state = kzalloc(sizeof(*load_state), GFP_KERNEL);
if (!load_state)
return -ENOMEM;
drm_atomic_private_obj_init(&vc4->base, &vc4->load_tracker,
&load_state->base,
&vc4_load_tracker_state_funcs);
return drmm_add_action(&vc4->base, vc4_load_tracker_obj_fini, NULL);
}
#define NUM_OUTPUTS 6 #define NUM_OUTPUTS 6
#define NUM_CHANNELS 3 #define NUM_CHANNELS 3
...@@ -711,8 +762,6 @@ static const struct drm_mode_config_funcs vc4_mode_funcs = { ...@@ -711,8 +762,6 @@ static const struct drm_mode_config_funcs vc4_mode_funcs = {
int vc4_kms_load(struct drm_device *dev) int vc4_kms_load(struct drm_device *dev)
{ {
struct vc4_dev *vc4 = to_vc4_dev(dev); struct vc4_dev *vc4 = to_vc4_dev(dev);
struct vc4_ctm_state *ctm_state;
struct vc4_load_tracker_state *load_state;
bool is_vc5 = of_device_is_compatible(dev->dev->of_node, bool is_vc5 = of_device_is_compatible(dev->dev->of_node,
"brcm,bcm2711-vc5"); "brcm,bcm2711-vc5");
int ret; int ret;
...@@ -751,26 +800,13 @@ int vc4_kms_load(struct drm_device *dev) ...@@ -751,26 +800,13 @@ int vc4_kms_load(struct drm_device *dev)
dev->mode_config.async_page_flip = true; dev->mode_config.async_page_flip = true;
dev->mode_config.allow_fb_modifiers = true; dev->mode_config.allow_fb_modifiers = true;
drm_modeset_lock_init(&vc4->ctm_state_lock); ret = vc4_ctm_obj_init(vc4);
if (ret)
ctm_state = kzalloc(sizeof(*ctm_state), GFP_KERNEL); return ret;
if (!ctm_state)
return -ENOMEM;
drm_atomic_private_obj_init(dev, &vc4->ctm_manager, &ctm_state->base,
&vc4_ctm_state_funcs);
if (vc4->load_tracker_available) {
load_state = kzalloc(sizeof(*load_state), GFP_KERNEL);
if (!load_state) {
drm_atomic_private_obj_fini(&vc4->ctm_manager);
return -ENOMEM;
}
drm_atomic_private_obj_init(dev, &vc4->load_tracker, ret = vc4_load_tracker_obj_init(vc4);
&load_state->base, if (ret)
&vc4_load_tracker_state_funcs); return ret;
}
drm_mode_config_reset(dev); drm_mode_config_reset(dev);
......
...@@ -168,7 +168,7 @@ static void vc4_v3d_init_hw(struct drm_device *dev) ...@@ -168,7 +168,7 @@ static void vc4_v3d_init_hw(struct drm_device *dev)
int vc4_v3d_get_bin_slot(struct vc4_dev *vc4) int vc4_v3d_get_bin_slot(struct vc4_dev *vc4)
{ {
struct drm_device *dev = vc4->dev; struct drm_device *dev = &vc4->base;
unsigned long irqflags; unsigned long irqflags;
int slot; int slot;
uint64_t seqno = 0; uint64_t seqno = 0;
...@@ -246,7 +246,7 @@ static int bin_bo_alloc(struct vc4_dev *vc4) ...@@ -246,7 +246,7 @@ static int bin_bo_alloc(struct vc4_dev *vc4)
INIT_LIST_HEAD(&list); INIT_LIST_HEAD(&list);
while (true) { while (true) {
struct vc4_bo *bo = vc4_bo_create(vc4->dev, size, true, struct vc4_bo *bo = vc4_bo_create(&vc4->base, size, true,
VC4_BO_TYPE_BIN); VC4_BO_TYPE_BIN);
if (IS_ERR(bo)) { if (IS_ERR(bo)) {
...@@ -361,7 +361,7 @@ static int vc4_v3d_runtime_suspend(struct device *dev) ...@@ -361,7 +361,7 @@ static int vc4_v3d_runtime_suspend(struct device *dev)
struct vc4_v3d *v3d = dev_get_drvdata(dev); struct vc4_v3d *v3d = dev_get_drvdata(dev);
struct vc4_dev *vc4 = v3d->vc4; struct vc4_dev *vc4 = v3d->vc4;
vc4_irq_uninstall(vc4->dev); vc4_irq_uninstall(&vc4->base);
clk_disable_unprepare(v3d->clk); clk_disable_unprepare(v3d->clk);
...@@ -378,11 +378,11 @@ static int vc4_v3d_runtime_resume(struct device *dev) ...@@ -378,11 +378,11 @@ static int vc4_v3d_runtime_resume(struct device *dev)
if (ret != 0) if (ret != 0)
return ret; return ret;
vc4_v3d_init_hw(vc4->dev); vc4_v3d_init_hw(&vc4->base);
/* We disabled the IRQ as part of vc4_irq_uninstall in suspend. */ /* We disabled the IRQ as part of vc4_irq_uninstall in suspend. */
enable_irq(vc4->dev->irq); enable_irq(vc4->base.irq);
vc4_irq_postinstall(vc4->dev); vc4_irq_postinstall(&vc4->base);
return 0; return 0;
} }
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
#define FONTDATAMAX 9216 #define FONTDATAMAX 9216
static struct font_data fontdata_10x18 = { static const struct font_data fontdata_10x18 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, 0x00, /* 0000000000 */ 0x00, 0x00, /* 0000000000 */
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
#define FONTDATAMAX 2560 #define FONTDATAMAX 2560
static struct font_data fontdata_6x10 = { static const struct font_data fontdata_6x10 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 00000000 */ 0x00, /* 00000000 */
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#define FONTDATAMAX (11*256) #define FONTDATAMAX (11*256)
static struct font_data fontdata_6x11 = { static const struct font_data fontdata_6x11 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 00000000 */ 0x00, /* 00000000 */
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
#define FONTDATAMAX 2048 #define FONTDATAMAX 2048
static struct font_data fontdata_6x8 = { static const struct font_data fontdata_6x8 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 000000 */ 0x00, /* 000000 */
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
#define FONTDATAMAX 3584 #define FONTDATAMAX 3584
static struct font_data fontdata_7x14 = { static const struct font_data fontdata_7x14 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 0000000 */ 0x00, /* 0000000 */
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
#define FONTDATAMAX 4096 #define FONTDATAMAX 4096
static struct font_data fontdata_8x16 = { static const struct font_data fontdata_8x16 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 00000000 */ 0x00, /* 00000000 */
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#define FONTDATAMAX 2048 #define FONTDATAMAX 2048
static struct font_data fontdata_8x8 = { static const struct font_data fontdata_8x8 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 00000000 */ 0x00, /* 00000000 */
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
#define FONTDATAMAX 2048 #define FONTDATAMAX 2048
static struct font_data acorndata_8x8 = { static const struct font_data acorndata_8x8 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 00 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* ^@ */ /* 00 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* ^@ */
/* 01 */ 0x7e, 0x81, 0xa5, 0x81, 0xbd, 0x99, 0x81, 0x7e, /* ^A */ /* 01 */ 0x7e, 0x81, 0xa5, 0x81, 0xbd, 0x99, 0x81, 0x7e, /* ^A */
......
...@@ -43,7 +43,7 @@ __END__; ...@@ -43,7 +43,7 @@ __END__;
#define FONTDATAMAX 1536 #define FONTDATAMAX 1536
static struct font_data fontdata_mini_4x6 = { static const struct font_data fontdata_mini_4x6 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/*{*/ /*{*/
/* Char 0: ' ' */ /* Char 0: ' ' */
......
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
#define FONTDATAMAX 2048 #define FONTDATAMAX 2048
static struct font_data fontdata_pearl8x8 = { static const struct font_data fontdata_pearl8x8 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, /* 00000000 */ 0x00, /* 00000000 */
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
#define FONTDATAMAX 11264 #define FONTDATAMAX 11264
static struct font_data fontdata_sun12x22 = { static const struct font_data fontdata_sun12x22 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* 0 0x00 '^@' */ /* 0 0x00 '^@' */
0x00, 0x00, /* 000000000000 */ 0x00, 0x00, /* 000000000000 */
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
#define FONTDATAMAX 4096 #define FONTDATAMAX 4096
static struct font_data fontdata_sun8x16 = { static const struct font_data fontdata_sun8x16 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
/* */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, /* */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
/* */ 0x00,0x00,0x7e,0x81,0xa5,0x81,0x81,0xbd,0x99,0x81,0x81,0x7e,0x00,0x00,0x00,0x00, /* */ 0x00,0x00,0x7e,0x81,0xa5,0x81,0x81,0xbd,0x99,0x81,0x81,0x7e,0x00,0x00,0x00,0x00,
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
#define FONTDATAMAX 16384 #define FONTDATAMAX 16384
static struct font_data fontdata_ter16x32 = { static const struct font_data fontdata_ter16x32 = {
{ 0, 0, FONTDATAMAX, 0 }, { { 0, 0, FONTDATAMAX, 0 }, {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x7f, 0xfc, 0x7f, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x7f, 0xfc, 0x7f, 0xfc,
......
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