[PATCH 02/13] drm/exynos: separated subdrv->probe call and encoder/connector creation.

Joonyoung Shim jy0922.shim at samsung.com
Sun Aug 19 18:59:23 PDT 2012


On 08/20/2012 10:52 AM, InKi Dae wrote:
> 2012/8/20 Joonyoung Shim <jy0922.shim at samsung.com>:
>> On 08/17/2012 06:50 PM, Inki Dae wrote:
>>> this patch separates sub driver's probe call and encoder/connector
>>> creation
>>> so that exynos drm core module can take exception when some operation was
>>> failed properly.
>>
>> Which exceptions? I don't know this patch gives any benefit to us.
>>
> previous code didn't take exception when exynos_drm_encoder_create()
> is falied.

No, it is considered.

> and for now, exynos_drm_encoder/connector_create functions
> was called at exynos_drm_subdrv_probe() so know that this patch is for
> code clean by separating them into two parts also.

It's ok, but it just splitting.

>
>>> Signed-off-by: Inki Dae <inki.dae at samsung.com>
>>> Signed-off-by: Kyungmin Park <kyungmin.park at samsung.com>
>>> ---
>>>    drivers/gpu/drm/exynos/exynos_drm_core.c |   93
>>> +++++++++++++++++++++---------
>>>    1 files changed, 65 insertions(+), 28 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_core.c
>>> b/drivers/gpu/drm/exynos/exynos_drm_core.c
>>> index 84dd099..1c8d5fe 100644
>>> --- a/drivers/gpu/drm/exynos/exynos_drm_core.c
>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_core.c
>>> @@ -34,30 +34,15 @@
>>>      static LIST_HEAD(exynos_drm_subdrv_list);
>>>    -static int exynos_drm_subdrv_probe(struct drm_device *dev,
>>> +static int exynos_drm_create_enc_conn(struct drm_device *dev,
>>>                                          struct exynos_drm_subdrv *subdrv)
>>>    {
>>>          struct drm_encoder *encoder;
>>>          struct drm_connector *connector;
>>> +       int ret;
>>>          DRM_DEBUG_DRIVER("%s\n", __FILE__);
>>>    -     if (subdrv->probe) {
>>> -               int ret;
>>> -
>>> -               /*
>>> -                * this probe callback would be called by sub driver
>>> -                * after setting of all resources to this sub driver,
>>> -                * such as clock, irq and register map are done or by
>>> load()
>>> -                * of exynos drm driver.
>>> -                *
>>> -                * P.S. note that this driver is considered for
>>> modularization.
>>> -                */
>>> -               ret = subdrv->probe(dev, subdrv->dev);
>>> -               if (ret)
>>> -                       return ret;
>>> -       }
>>> -
>>>          if (!subdrv->manager)
>>>                  return 0;
>>>    @@ -78,24 +63,22 @@ static int exynos_drm_subdrv_probe(struct drm_device
>>> *dev,
>>>          connector = exynos_drm_connector_create(dev, encoder);
>>>          if (!connector) {
>>>                  DRM_ERROR("failed to create connector\n");
>>> -               encoder->funcs->destroy(encoder);
>>> -               return -EFAULT;
>>> +               ret = -EFAULT;
>>> +               goto err_destroy_encoder;
>>>          }
>>>          subdrv->encoder = encoder;
>>>          subdrv->connector = connector;
>>>          return 0;
>>> +
>>> +err_destroy_encoder:
>>> +       encoder->funcs->destroy(encoder);
>>> +       return ret;
>>>    }
>>>    -static void exynos_drm_subdrv_remove(struct drm_device *dev,
>>> -                                     struct exynos_drm_subdrv *subdrv)
>>> +static void exynos_drm_destroy_enc_conn(struct exynos_drm_subdrv *subdrv)
>>>    {
>>> -       DRM_DEBUG_DRIVER("%s\n", __FILE__);
>>> -
>>> -       if (subdrv->remove)
>>> -               subdrv->remove(dev);
>>> -
>>>          if (subdrv->encoder) {
>>>                  struct drm_encoder *encoder = subdrv->encoder;
>>>                  encoder->funcs->destroy(encoder);
>>> @@ -109,9 +92,48 @@ static void exynos_drm_subdrv_remove(struct drm_device
>>> *dev,
>>>          }
>>>    }
>>>    +static int exynos_drm_subdrv_probe(struct drm_device *dev,
>>> +                                       struct exynos_drm_subdrv *subdrv)
>>> +{
>>> +       if (subdrv->probe) {
>>> +               int ret;
>>> +
>>> +               subdrv->drm_dev = dev;
>>> +
>>> +               /*
>>> +                * this probe callback would be called by sub driver
>>> +                * after setting of all resources to this sub driver,
>>> +                * such as clock, irq and register map are done or by
>>> load()
>>> +                * of exynos drm driver.
>>> +                *
>>> +                * P.S. note that this driver is considered for
>>> modularization.
>>> +                */
>>> +               ret = subdrv->probe(dev, subdrv->dev);
>>> +               if (ret)
>>> +                       return ret;
>>> +       }
>>> +
>>> +       if (!subdrv->manager)
>>> +               return -EINVAL;
>>> +
>>> +       subdrv->manager->dev = subdrv->dev;
>>> +
>>> +       return 0;
>>> +}
>>> +
>>> +static void exynos_drm_subdrv_remove(struct drm_device *dev,
>>> +                                     struct exynos_drm_subdrv *subdrv)
>>> +{
>>> +       DRM_DEBUG_DRIVER("%s\n", __FILE__);
>>> +
>>> +       if (subdrv->remove)
>>> +               subdrv->remove(dev, subdrv->dev);
>>> +}
>>> +
>>>    int exynos_drm_device_register(struct drm_device *dev)
>>>    {
>>>          struct exynos_drm_subdrv *subdrv, *n;
>>> +       unsigned int fine_cnt = 0;
>>>          int err;
>>>          DRM_DEBUG_DRIVER("%s\n", __FILE__);
>>> @@ -120,14 +142,27 @@ int exynos_drm_device_register(struct drm_device
>>> *dev)
>>>                  return -EINVAL;
>>>          list_for_each_entry_safe(subdrv, n, &exynos_drm_subdrv_list, list)
>>> {
>>> -               subdrv->drm_dev = dev;
>>>                  err = exynos_drm_subdrv_probe(dev, subdrv);
>>>                  if (err) {
>>>                          DRM_DEBUG("exynos drm subdrv probe failed.\n");
>>>                          list_del(&subdrv->list);
>>> +                       continue;
>>>                  }
>>> +
>>> +               err = exynos_drm_create_enc_conn(dev, subdrv);
>>> +               if (err) {
>>> +                       DRM_DEBUG("failed to create encoder and
>>> connector.\n");
>>> +                       exynos_drm_subdrv_remove(dev, subdrv);
>>> +                       list_del(&subdrv->list);
>>> +                       continue;
>>> +               }
>>> +
>>> +               fine_cnt++;
>>>          }
>>>    +     if (!fine_cnt)
>>> +               return -EINVAL;
>>> +
>>>          return 0;
>>>    }
>>>    EXPORT_SYMBOL_GPL(exynos_drm_device_register);
>>> @@ -143,8 +178,10 @@ int exynos_drm_device_unregister(struct drm_device
>>> *dev)
>>>                  return -EINVAL;
>>>          }
>>>    -     list_for_each_entry(subdrv, &exynos_drm_subdrv_list, list)
>>> +       list_for_each_entry(subdrv, &exynos_drm_subdrv_list, list) {
>>>                  exynos_drm_subdrv_remove(dev, subdrv);
>>> +               exynos_drm_destroy_enc_conn(subdrv);
>>> +       }
>>>          return 0;
>>>    }
>>
>> _______________________________________________
>> dri-devel mailing list
>> dri-devel at lists.freedesktop.org
>> http://lists.freedesktop.org/mailman/listinfo/dri-devel



More information about the dri-devel mailing list