All of lore.kernel.org
 help / color / mirror / Atom feed
From: Oleksandr Andrushchenko <andr2000@gmail.com>
To: Juergen Gross <jgross@suse.com>,
	xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org,
	dri-devel@lists.freedesktop.org, daniel.vetter@intel.com,
	boris.ostrovsky@oracle.com
Cc: Oleksandr Andrushchenko <oleksandr_andrushchenko@epam.com>
Subject: Re: [PATCH] drm/xen-front: fix pointer casts
Date: Wed, 23 May 2018 14:27:43 +0300	[thread overview]
Message-ID: <78259eca-6321-883b-7c1b-8443e24662ad__15744.1945550547$1527074799$gmane$org@gmail.com> (raw)
In-Reply-To: <11421e59-3219-b9df-7869-0b249041125b@suse.com>

On 05/23/2018 02:06 PM, Juergen Gross wrote:
> On 23/05/18 12:00, Oleksandr Andrushchenko wrote:
>> On 05/23/2018 12:19 PM, Juergen Gross wrote:
>>> On 21/05/18 09:39, Oleksandr Andrushchenko wrote:
>>>> From: Oleksandr Andrushchenko <oleksandr_andrushchenko@epam.com>
>>>>
>>>> Building for a 32-bit target results in warnings from casting
>>>> between a 32-bit pointer and a 64-bit integer. Fix the warnings
>>>> by casting those pointers to uintptr_t first.
>>>>
>>>> Signed-off-by: Oleksandr Andrushchenko
>>>> <oleksandr_andrushchenko@epam.com>
>>>> ---
>>>>    drivers/gpu/drm/xen/xen_drm_front.h       | 4 ++--
>>>>    drivers/gpu/drm/xen/xen_drm_front_shbuf.c | 2 +-
>>>>    2 files changed, 3 insertions(+), 3 deletions(-)
>>>>
>>>> diff --git a/drivers/gpu/drm/xen/xen_drm_front.h
>>>> b/drivers/gpu/drm/xen/xen_drm_front.h
>>>> index 2c2479b571ae..8e15dbebc4ba 100644
>>>> --- a/drivers/gpu/drm/xen/xen_drm_front.h
>>>> +++ b/drivers/gpu/drm/xen/xen_drm_front.h
>>>> @@ -126,12 +126,12 @@ struct xen_drm_front_drm_info {
>>>>      static inline u64 xen_drm_front_fb_to_cookie(struct
>>>> drm_framebuffer *fb)
>>>>    {
>>>> -    return (u64)fb;
>>>> +    return (u64)(uintptr_t)fb;
>>> Do you really still need the cast to u64?
>> Indeed, I can remove (u64) now, thank you
>>>>    }
>>>>      static inline u64 xen_drm_front_dbuf_to_cookie(struct
>>>> drm_gem_object *gem_obj)
>>>>    {
>>>> -    return (u64)gem_obj;
>>>> +    return (u64)(uintptr_t)gem_obj;
>>>>    }
>>>>      int xen_drm_front_mode_set(struct xen_drm_front_drm_pipeline
>>>> *pipeline,
>>>> diff --git a/drivers/gpu/drm/xen/xen_drm_front_shbuf.c
>>>> b/drivers/gpu/drm/xen/xen_drm_front_shbuf.c
>>>> index 8099cb343ae3..47fc93847765 100644
>>>> --- a/drivers/gpu/drm/xen/xen_drm_front_shbuf.c
>>>> +++ b/drivers/gpu/drm/xen/xen_drm_front_shbuf.c
>>>> @@ -122,7 +122,7 @@ static void guest_calc_num_grefs(struct
>>>> xen_drm_front_shbuf *buf)
>>>>    }
>>>>      #define xen_page_to_vaddr(page) \
>>>> -        ((phys_addr_t)pfn_to_kaddr(page_to_xen_pfn(page)))
>>>> +        ((phys_addr_t)(uintptr_t)pfn_to_kaddr(page_to_xen_pfn(page)))
>>> phys_addr_t for a virtual address?
>> This is because the resulting value is then passed to gnttab_set_map_op/
>> gnttab_set_unmap_op which expects host address to be passed as
>> phys_addr_t addr :(
> Okay, but this means the compiler should do the necessary cast when
> you drop the cast to phys_addr_t in xen_page_to_vaddr(), as the cast
> to uintptr_t is already producing an unsigned integer value which can
> easily be promoted to more bits, right?
Right, so I can safely use:
  #define xen_page_to_vaddr(page) \
- ((phys_addr_t)(uintptr_t)pfn_to_kaddr(page_to_xen_pfn(page)))
+               ((uintptr_t)pfn_to_kaddr(page_to_xen_pfn(page)))

>
> Juergen
Thank you for your time and comments,
Oleksandr

_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xenproject.org
https://lists.xenproject.org/mailman/listinfo/xen-devel

  reply	other threads:[~2018-05-23 11:27 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-21  7:39 [PATCH] drm/xen-front: fix pointer casts Oleksandr Andrushchenko
2018-05-21  7:39 ` Oleksandr Andrushchenko
2018-05-23  9:19 ` Juergen Gross
2018-05-23 10:00   ` Oleksandr Andrushchenko
2018-05-23 10:00     ` Oleksandr Andrushchenko
2018-05-23 11:06     ` Juergen Gross
2018-05-23 11:27       ` Oleksandr Andrushchenko [this message]
2018-05-23 11:27       ` Oleksandr Andrushchenko
2018-05-23 11:06     ` Juergen Gross
2018-05-23 10:00   ` Oleksandr Andrushchenko
2018-05-23  9:19 ` Juergen Gross
2018-05-21  7:39 Oleksandr Andrushchenko

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='78259eca-6321-883b-7c1b-8443e24662ad__15744.1945550547$1527074799$gmane$org@gmail.com' \
    --to=andr2000@gmail.com \
    --cc=boris.ostrovsky@oracle.com \
    --cc=daniel.vetter@intel.com \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=jgross@suse.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=oleksandr_andrushchenko@epam.com \
    --cc=xen-devel@lists.xenproject.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.