[PATCH 09/13] drm/exynos: check NV12M format specific to Exynos properly

InKi Dae inki.dae at samsung.com
Sun Aug 19 22:15:24 PDT 2012


sorry, again.

2012/8/20 InKi Dae <inki.dae at samsung.com>:
> 2012/8/20 Joonyoung Shim <jy0922.shim at samsung.com>:
>> On 08/20/2012 11:23 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 adds buf_cnt variable in exynos_drm_fb structure and
>>>>> that means a buffer count to drm framebuffer and also adds two
>>>>> functions to get/set the buffer count from/to exynos_drm_fb structure.
>>>>> if pixel format is not DRM_FORMAT_NV12MT then it gets a buffer count
>>>>> to drm framebuffer refering to mode_cmd->handles and offsets.
>>>>> but when booted, the buffer count will always be 1 because pixel
>>>>> format of console framebuffer is RGB format.
>>>>>
>>>>> 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_fb.c    |   65
>>>>> +++++++++++++++++++++++++++-
>>>>>    drivers/gpu/drm/exynos/exynos_drm_fb.h    |   20 +++------
>>>>>    drivers/gpu/drm/exynos/exynos_drm_fbdev.c |    3 +
>>>>>    drivers/gpu/drm/exynos/exynos_drm_plane.c |    2 +-
>>>>>    4 files changed, 73 insertions(+), 17 deletions(-)
>>>>>
>>>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fb.c
>>>>> b/drivers/gpu/drm/exynos/exynos_drm_fb.c
>>>>> index 4ccfe43..2d1bc3a 100644
>>>>> --- a/drivers/gpu/drm/exynos/exynos_drm_fb.c
>>>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_fb.c
>>>>> @@ -41,10 +41,12 @@
>>>>>     * exynos specific framebuffer structure.
>>>>>     *
>>>>>     * @fb: drm framebuffer obejct.
>>>>> + * @buf_cnt: a buffer count to drm framebuffer.
>>>>>     * @exynos_gem_obj: array of exynos specific gem object containing a
>>>>> gem
>>>>> object.
>>>>>     */
>>>>>    struct exynos_drm_fb {
>>>>>          struct drm_framebuffer          fb;
>>>>> +       unsigned int                    buf_cnt;
>>>>>          struct exynos_drm_gem_obj       *exynos_gem_obj[MAX_FB_BUFFER];
>>>>>    };
>>>>>    @@ -101,6 +103,25 @@ static struct drm_framebuffer_funcs
>>>>> exynos_drm_fb_funcs = {
>>>>>          .dirty          = exynos_drm_fb_dirty,
>>>>>    };
>>>>>    +void exynos_drm_fb_set_buf_cnt(struct drm_framebuffer *fb,
>>>>> +                                               unsigned int cnt)
>>>>> +{
>>>>> +       struct exynos_drm_fb *exynos_fb;
>>>>> +
>>>>> +       exynos_fb = to_exynos_fb(fb);
>>>>> +
>>>>> +       exynos_fb->buf_cnt = cnt;
>>>>> +}
>>>>> +
>>>>> +unsigned int exynos_drm_fb_get_buf_cnt(struct drm_framebuffer *fb)
>>>>> +{
>>>>> +       struct exynos_drm_fb *exynos_fb;
>>>>> +
>>>>> +       exynos_fb = to_exynos_fb(fb);
>>>>> +
>>>>> +       return exynos_fb->buf_cnt;
>>>>> +}
>>>>> +
>>>>>    struct drm_framebuffer *
>>>>>    exynos_drm_framebuffer_init(struct drm_device *dev,
>>>>>                              struct drm_mode_fb_cmd2 *mode_cmd,
>>>>> @@ -127,6 +148,43 @@ exynos_drm_framebuffer_init(struct drm_device *dev,
>>>>>          return &exynos_fb->fb;
>>>>>    }
>>>>>    +static u32 exynos_drm_format_num_buffers(struct drm_mode_fb_cmd2
>>>>> *mode_cmd)
>>>>> +{
>>>>> +       unsigned int cnt = 0;
>>>>> +
>>>>> +       if (mode_cmd->pixel_format == DRM_FORMAT_NV12MT)
>>>>> +               return 2;
>>>>> +
>>>>> +       while (cnt != MAX_FB_BUFFER) {
>>>>> +               if (!mode_cmd->handles[cnt])
>>>>> +                       break;
>>>>> +               cnt++;
>>>>> +       }
>>>>> +
>>>>> +       /*
>>>>> +        * check if NV12 or NV12M.
>>>>> +        *
>>>>> +        * NV12
>>>>> +        * handles[0] = base1, offsets[0] = 0
>>>>> +        * handles[1] = base1, offsets[1] = Y_size
>>>>> +        *
>>>>> +        * NV12M
>>>>> +        * handles[0] = base1, offsets[0] = 0
>>>>> +        * handles[1] = base2, offsets[1] = 0
>>>>> +        */
>>>>> +       if (cnt == 2) {
>>>>> +               /*
>>>>> +                * in case of NV12 format, offsets[1] is not 0 and
>>>>> +                * handles[0] is same as handles[1].
>>>>> +                */
>>>>> +               if (mode_cmd->offsets[1] &&
>>>>> +                       mode_cmd->handles[0] == mode_cmd->handles[1])
>>>>> +                       cnt = 1;
>>>>> +       }
>>>>> +
>>>>> +       return cnt;
>>>>> +}
>>>>
>>>>
>>>> No, please don't add specific function. There is already
>>>> drm_format_num_planes() function
>>>>
>>>>
>>> I know that, but NV12M format is specific to Exynos. for this, we
>>> already had a discussion and you can refer to below link,
>>> http://web.archiveorange.com/archive/v/hhSc5JAv767vo7fKZLPf
>>
>>
>> Yes, but this implementation is not clear, just get plane number using
>> drm_format_num_planes()
>> and check handle and offset argument when format is NV12.
>>
>
> drm_format_num_planes() doesn't include NV12MT format type so first
> that format should be added and then we can get plane count using
> drm_format_num_planes if not NV12. but if not,
> exynos_drm_format_num_buffers() like below,
>
> if (mode_cmd == DRM_FORMAT_NV12)
>

if (mode_cmd->pixel_format == DRM_FORMAT_NV12)
        exynos_fb->buf_cnt = exynos_drm_format_num_buffers(dev, ...);
else
        exynos_fb->buf_cnt = drm_format_num_planes(....);

>
>>
>>>>> +
>>>>>    static struct drm_framebuffer *
>>>>>    exynos_user_fb_create(struct drm_device *dev, struct drm_file
>>>>> *file_priv,
>>>>>                        struct drm_mode_fb_cmd2 *mode_cmd)
>>>>> @@ -134,7 +192,6 @@ exynos_user_fb_create(struct drm_device *dev, struct
>>>>> drm_file *file_priv,
>>>>>          struct drm_gem_object *obj;
>>>>>          struct drm_framebuffer *fb;
>>>>>          struct exynos_drm_fb *exynos_fb;
>>>>> -       int nr;
>>>>>          int i;
>>>>>          DRM_DEBUG_KMS("%s\n", __FILE__);
>>>>> @@ -152,9 +209,11 @@ exynos_user_fb_create(struct drm_device *dev,
>>>>> struct
>>>>> drm_file *file_priv,
>>>>>          }
>>>>>          exynos_fb = to_exynos_fb(fb);
>>>>> -       nr = exynos_drm_format_num_buffers(fb->pixel_format);
>>>>> +       exynos_fb->buf_cnt = exynos_drm_format_num_buffers(mode_cmd);
>>>>> +
>>>>> +       DRM_DEBUG_KMS("buf_cnt = %d\n", exynos_fb->buf_cnt);
>>>>>    -     for (i = 1; i < nr; i++) {
>>>>> +       for (i = 1; i < exynos_fb->buf_cnt; i++) {
>>>>>                  obj = drm_gem_object_lookup(dev, file_priv,
>>>>>                                  mode_cmd->handles[i]);
>>>>>                  if (!obj) {
>>>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fb.h
>>>>> b/drivers/gpu/drm/exynos/exynos_drm_fb.h
>>>>> index 5082375..96262e5 100644
>>>>> --- a/drivers/gpu/drm/exynos/exynos_drm_fb.h
>>>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_fb.h
>>>>> @@ -28,19 +28,6 @@
>>>>>    #ifndef _EXYNOS_DRM_FB_H_
>>>>>    #define _EXYNOS_DRM_FB_H
>>>>>    -static inline int exynos_drm_format_num_buffers(uint32_t format)
>>>>> -{
>>>>> -       switch (format) {
>>>>> -       case DRM_FORMAT_NV12:
>>>>> -       case DRM_FORMAT_NV12MT:
>>>>> -               return 2;
>>>>> -       case DRM_FORMAT_YUV420:
>>>>> -               return 3;
>>>>> -       default:
>>>>> -               return 1;
>>>>> -       }
>>>>> -}
>>>>> -
>>>>>    struct drm_framebuffer *
>>>>>    exynos_drm_framebuffer_init(struct drm_device *dev,
>>>>>                              struct drm_mode_fb_cmd2 *mode_cmd,
>>>>> @@ -52,4 +39,11 @@ struct exynos_drm_gem_buf
>>>>> *exynos_drm_fb_buffer(struct
>>>>> drm_framebuffer *fb,
>>>>>      void exynos_drm_mode_config_init(struct drm_device *dev);
>>>>>    +/* set a buffer count to drm framebuffer. */
>>>>> +void exynos_drm_fb_set_buf_cnt(struct drm_framebuffer *fb,
>>>>> +                                               unsigned int cnt);
>>>>> +
>>>>> +/* get a buffer count to drm framebuffer. */
>>>>> +unsigned int exynos_drm_fb_get_buf_cnt(struct drm_framebuffer *fb);
>>>>> +
>>>>>    #endif
>>>>> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
>>>>> b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
>>>>> index d5586cc..5b125fe 100644
>>>>> --- a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
>>>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
>>>>> @@ -79,6 +79,9 @@ static int exynos_drm_fbdev_update(struct
>>>>> drm_fb_helper
>>>>> *helper,
>>>>>                  return -EFAULT;
>>>>>          }
>>>>>    +     /* buffer count to framebuffer always is 1 at booting time. */
>>>>> +       exynos_drm_fb_set_buf_cnt(fb, 1);
>>>>> +
>>>>>          offset = fbi->var.xoffset * (fb->bits_per_pixel >> 3);
>>>>>          offset += fbi->var.yoffset * fb->pitches[0];
>>>>>    diff --git a/drivers/gpu/drm/exynos/exynos_drm_plane.c
>>>>> b/drivers/gpu/drm/exynos/exynos_drm_plane.c
>>>>> index b89829e..777e142 100644
>>>>> --- a/drivers/gpu/drm/exynos/exynos_drm_plane.c
>>>>> +++ b/drivers/gpu/drm/exynos/exynos_drm_plane.c
>>>>> @@ -48,7 +48,7 @@ int exynos_plane_mode_set(struct drm_plane *plane,
>>>>> struct drm_crtc *crtc,
>>>>>          DRM_DEBUG_KMS("[%d] %s\n", __LINE__, __func__);
>>>>>    -     nr = exynos_drm_format_num_buffers(fb->pixel_format);
>>>>> +       nr = exynos_drm_fb_get_buf_cnt(fb);
>>>>>          for (i = 0; i < nr; i++) {
>>>>>                  struct exynos_drm_gem_buf *buffer =
>>>>> exynos_drm_fb_buffer(fb, i);
>>>>>
>>>>
>>>> _______________________________________________
>>>> dri-devel mailing list
>>>> dri-devel at lists.freedesktop.org
>>>> http://lists.freedesktop.org/mailman/listinfo/dri-devel
>>
>>
>> _______________________________________________
>> 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