[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH 3 of 8] Tools: Update memshr tool to use new sharing API



On Fri, 2011-12-09 at 23:15 +0000, Andres Lagar-Cavilla wrote:
> tools/blktap2/drivers/Makefile        |   2 +-
>  tools/blktap2/drivers/tapdisk-image.c |   2 +-
>  tools/blktap2/drivers/tapdisk-vbd.c   |   6 +++---
>  tools/blktap2/drivers/tapdisk.h       |   6 +++++-
>  tools/memshr/bidir-daemon.c           |  34 
> ++++++++++++++++++++++++----------
>  tools/memshr/bidir-hash.h             |  13 ++++++++-----
>  tools/memshr/interface.c              |  30 ++++++++++++++++++------------
>  tools/memshr/memshr.h                 |  11 +++++++++--
>  8 files changed, 69 insertions(+), 35 deletions(-)
> 
> 
> The only (in-tree, that we know of) consumer of the mem sharing API
> is the memshr tool (conditionally linked into blktap2). Update it to
> use the new API.

At least some of this must happen in the previous 2 patches so that the
build is not broken.

Is there any benefit to conditionally linking this stuff? Is it lots of
code or does it have some other undesirable impact when built even when
it is quiescent? Seems like a recipe for bit rot to not build it, plus
it makes it harder for people to consume via distro packages etc.

> Signed-off-by: Andres Lagar-Cavilla <andres@xxxxxxxxxxxxxxxx>
> 
> diff -r 892049dfc1c9 -r e16f5d2643c9 tools/blktap2/drivers/Makefile
> --- a/tools/blktap2/drivers/Makefile
> +++ b/tools/blktap2/drivers/Makefile
> @@ -43,7 +43,7 @@ MEMSHR_DIR = $(XEN_ROOT)/tools/memshr
>  MEMSHRLIBS :=
>  ifeq ($(CONFIG_Linux), __fixme__)
>  CFLAGS += -DMEMSHR
> -MEMSHRLIBS += $(MEMSHR_DIR)/libmemshr.a
> +MEMSHRLIBS += -L$(XEN_ROOT)/tools/libxc -lxenctrl $(MEMSHR_DIR)/libmemshr.a

Please use $(LDLIBS_libxenctrl).

Is there a reason libmemshr is not a shared library?

>  endif
> 
>  ifeq ($(VHD_STATIC),y)
> diff -r 892049dfc1c9 -r e16f5d2643c9 tools/blktap2/drivers/tapdisk-image.c
> --- a/tools/blktap2/drivers/tapdisk-image.c
> +++ b/tools/blktap2/drivers/tapdisk-image.c
> @@ -60,7 +60,7 @@ tapdisk_image_allocate(const char *file,
>         image->storage   = storage;
>         image->private   = private;
>  #ifdef MEMSHR
> -       image->memshr_id = memshr_vbd_image_get(file);
> +       image->memshr_id = memshr_vbd_image_get((char *)file);

Casting away the const here raises a big red flag. Why is this
necessary? You should either fix the API of memshr_vbd_image_get or
tapdisk_image_allocate IMHO and propagate the change as necessary.
AFAICT there is no reason not to push the const'ness down into the
memshr API.

>  #endif
>         INIT_LIST_HEAD(&image->next);
> 
[...]

> diff -r 892049dfc1c9 -r e16f5d2643c9 tools/memshr/bidir-hash.h
> --- a/tools/memshr/bidir-hash.h
> +++ b/tools/memshr/bidir-hash.h
> @@ -81,15 +81,16 @@ static int fgprtshr_mfn_cmp(uint32_t m1,
>  #undef BIDIR_VALUE
>  #undef BIDIR_KEY_T
>  #undef BIDIR_VALUE_T
> +
>  /* TODO better hashes! */
>  static inline uint32_t blockshr_block_hash(vbdblk_t block)
>  {
>      return (uint32_t)(block.sec) ^ (uint32_t)(block.disk_id);
>  }
> 
> -static inline uint32_t blockshr_shrhnd_hash(uint64_t shrhnd)
> +static inline uint32_t blockshr_shrhnd_hash(share_tuple_t shrhnd)
>  {
> -    return (uint32_t)shrhnd;
> +    return ((uint32_t) shrhnd.handle);
>  }
> 
>  static inline int blockshr_block_cmp(vbdblk_t b1, vbdblk_t b2)
> @@ -97,15 +98,17 @@ static inline int blockshr_block_cmp(vbd
>      return (b1.sec == b2.sec) && (b1.disk_id == b2.disk_id);
>  }
> 
> -static inline int blockshr_shrhnd_cmp(uint64_t h1, uint64_t h2)
> +static inline int blockshr_shrhnd_cmp(share_tuple_t h1, share_tuple_t h2)
>  {
> -    return (h1 == h2);
> +    return ( (h1.domain == h2.domain) &&
> +             (h1.frame  == h2.frame) &&
> +             (h1.handle == h2.handle) );

memcmp?

>  }
>  #define BIDIR_NAME_PREFIX       blockshr
>  #define BIDIR_KEY               block
>  #define BIDIR_VALUE             shrhnd
>  #define BIDIR_KEY_T             vbdblk_t
> -#define BIDIR_VALUE_T           uint64_t
> +#define BIDIR_VALUE_T           share_tuple_t
>  #include "bidir-namedefs.h"
> 
>  #endif /* BLOCK_MAP */
> diff -r 892049dfc1c9 -r e16f5d2643c9 tools/memshr/interface.c
> --- a/tools/memshr/interface.c
> +++ b/tools/memshr/interface.c
> @@ -145,16 +145,17 @@ void memshr_vbd_image_put(uint16_t memsh
> 
>  int memshr_vbd_issue_ro_request(char *buf,
>                                  grant_ref_t gref,
> -                                uint16_t file_id,
> +                                uint16_t file_id,
>                                  uint64_t sec,
>                                  int secs,
> -                                uint64_t *hnd)
> +                                share_tuple_t *hnd)
>  {
>      vbdblk_t blk;
> -    uint64_t s_hnd, c_hnd;
> +    share_tuple_t source_st, client_st;
> +    uint64_t c_hnd;
>      int ret;
> 
> -    *hnd = 0;
> +    *hnd = (share_tuple_t){ 0, 0, 0 };
>      if(!vbd_info.enabled)
>          return -1;
> 
> @@ -169,26 +170,31 @@ int memshr_vbd_issue_ro_request(char *bu
>      /* If page couldn't be made sharable, we cannot do anything about it */
>      if(ret != 0)
>          return -3;
> -    *hnd = c_hnd;
> +
> +    *(&client_st) = (share_tuple_t){ vbd_info.domid, gref, c_hnd };

Is "*(&thing)" somehow different to "thing"?

> +    *hnd = client_st;
> 
>      /* Check if we've read matching disk block previously */
>      blk.sec     = sec;
>      blk.disk_id = file_id;
> -    if(blockshr_block_lookup(memshr.blks, blk, &s_hnd) > 0)
> +    if(blockshr_block_lookup(memshr.blks, blk, &source_st) > 0)
>      {
> -        ret = xc_memshr_share(vbd_info.xc_handle, s_hnd, c_hnd);
> +        ret = xc_memshr_share(vbd_info.xc_handle, source_st.domain, 
> source_st.frame,
> +                                source_st.handle, 1, vbd_info.domid, gref, 
> c_hnd, 1);

These 1's == is a gref but I only know that because I was just reading
that patch. If you decide you do need to keep the flag separate then
this would be better as a flags argument with named values
XC_MEMSHR_SOURCE_IS_GREF etc.

> diff -r 892049dfc1c9 -r e16f5d2643c9 tools/memshr/memshr.h
> --- a/tools/memshr/memshr.h
> +++ b/tools/memshr/memshr.h
> @@ -25,6 +25,13 @@
> 
>  typedef uint64_t xen_mfn_t;
> 
> +typedef struct share_tuple
> +{
> +    uint32_t domain;
> +    uint64_t frame;
> +    uint64_t handle;
> +} share_tuple_t;

Didn't you just add these as three separate parameters to
xc_memshr_share? Seems like this could be xc_memshr_tuple (or some
better name with more meaning than "tuple") and used throughout.

Ian.



_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.