xen-devel.lists.xenproject.org archive mirror
 help / color / mirror / Atom feed
From: Paul Durrant <Paul.Durrant@citrix.com>
To: 'Juergen Gross' <jgross@suse.com>,
	"xen-devel@lists.xen.org" <xen-devel@lists.xen.org>
Cc: "sstabellini@kernel.org" <sstabellini@kernel.org>,
	Wei Liu <wei.liu2@citrix.com>,
	Andrew Cooper <Andrew.Cooper3@citrix.com>,
	"Tim (Xen.org)" <tim@xen.org>,
	George Dunlap <George.Dunlap@citrix.com>,
	"jbeulich@suse.com" <jbeulich@suse.com>,
	Ian Jackson <Ian.Jackson@citrix.com>
Subject: Re: [PATCH v2 2/8] xen: clean up grant_table.h
Date: Wed, 6 Sep 2017 08:37:39 +0000	[thread overview]
Message-ID: <684c7acdb6094e33832bba27a83f01b4@AMSPEX02CL03.citrite.net> (raw)
In-Reply-To: <20170906082632.6494-3-jgross@suse.com>

> -----Original Message-----
> From: Xen-devel [mailto:xen-devel-bounces@lists.xen.org] On Behalf Of
> Juergen Gross
> Sent: 06 September 2017 09:26
> To: xen-devel@lists.xen.org
> Cc: Juergen Gross <jgross@suse.com>; sstabellini@kernel.org; Wei Liu
> <wei.liu2@citrix.com>; George Dunlap <George.Dunlap@citrix.com>;
> Andrew Cooper <Andrew.Cooper3@citrix.com>; Ian Jackson
> <Ian.Jackson@citrix.com>; Tim (Xen.org) <tim@xen.org>;
> jbeulich@suse.com
> Subject: [Xen-devel] [PATCH v2 2/8] xen: clean up grant_table.h
> 
> Many definitions can be moved from xen/grant_table.h to
> common/grant_table.c now, as they are no longer used in other sources.
> 
> Signed-off-by: Juergen Gross <jgross@suse.com>

Reviewed-by: Paul Durrant <paul.durrant@citrix.com>

> ---
>  xen/common/grant_table.c      | 81
> +++++++++++++++++++++++++++++++++++++++--
>  xen/include/xen/grant_table.h | 84 -------------------------------------------
>  2 files changed, 79 insertions(+), 86 deletions(-)
> 
> diff --git a/xen/common/grant_table.c b/xen/common/grant_table.c
> index 4c2e9e40a5..a94dfdda7b 100644
> --- a/xen/common/grant_table.c
> +++ b/xen/common/grant_table.c
> @@ -40,6 +40,42 @@
>  #include <xsm/xsm.h>
>  #include <asm/flushtlb.h>
> 
> +/* Per-domain grant information. */
> +struct grant_table {
> +    /*
> +     * Lock protecting updates to grant table state (version, active
> +     * entry list, etc.)
> +     */
> +    percpu_rwlock_t       lock;
> +    /* Table size. Number of frames shared with guest */
> +    unsigned int          nr_grant_frames;
> +    /* Shared grant table (see include/public/grant_table.h). */
> +    union {
> +        void **shared_raw;
> +        struct grant_entry_v1 **shared_v1;
> +        union grant_entry_v2 **shared_v2;
> +    };
> +    /* Number of grant status frames shared with guest (for version 2) */
> +    unsigned int          nr_status_frames;
> +    /* State grant table (see include/public/grant_table.h). */
> +    grant_status_t       **status;
> +    /* Active grant table. */
> +    struct active_grant_entry **active;
> +    /* Mapping tracking table per vcpu. */
> +    struct grant_mapping **maptrack;
> +    unsigned int          maptrack_limit;
> +    /* Lock protecting the maptrack limit */
> +    spinlock_t            maptrack_lock;
> +    /* The defined versions are 1 and 2.  Set to 0 if we don't know
> +       what version to use yet. */
> +    unsigned              gt_version;
> +};
> +
> +#ifndef DEFAULT_MAX_NR_GRANT_FRAMES /* to allow arch to override
> */
> +/* Default maximum size of a grant table. [POLICY] */
> +#define DEFAULT_MAX_NR_GRANT_FRAMES   32
> +#endif
> +
>  unsigned int __read_mostly max_grant_frames;
>  integer_param("gnttab_max_frames", max_grant_frames);
> 
> @@ -118,6 +154,18 @@ struct grant_mapping {
>      uint32_t pad;           /* round size to a power of 2 */
>  };
> 
> +/* Number of grant table frames. Caller must hold d's grant table lock. */
> +static inline unsigned int nr_grant_frames(const struct grant_table *gt)
> +{
> +    return gt->nr_grant_frames;
> +}
> +
> +/* Number of status grant table frames. Caller must hold d's gr. table lock.*/
> +static inline unsigned int nr_status_frames(const struct grant_table *gt)
> +{
> +    return gt->nr_status_frames;
> +}
> +
>  #define MAPTRACK_PER_PAGE (PAGE_SIZE / sizeof(struct grant_mapping))
>  #define maptrack_entry(t, e) \
>      ((t)->maptrack[(e)/MAPTRACK_PER_PAGE][(e)%MAPTRACK_PER_PAGE])
> @@ -197,7 +245,27 @@ static inline void act_set_gfn(struct
> active_grant_entry *act, gfn_t gfn)
>  #endif
>  }
> 
> -DEFINE_PERCPU_RWLOCK_GLOBAL(grant_rwlock);
> +static DEFINE_PERCPU_RWLOCK_GLOBAL(grant_rwlock);
> +
> +static inline void grant_read_lock(struct grant_table *gt)
> +{
> +    percpu_read_lock(grant_rwlock, &gt->lock);
> +}
> +
> +static inline void grant_read_unlock(struct grant_table *gt)
> +{
> +    percpu_read_unlock(grant_rwlock, &gt->lock);
> +}
> +
> +static inline void grant_write_lock(struct grant_table *gt)
> +{
> +    percpu_write_lock(grant_rwlock, &gt->lock);
> +}
> +
> +static inline void grant_write_unlock(struct grant_table *gt)
> +{
> +    percpu_write_unlock(grant_rwlock, &gt->lock);
> +}
> 
>  static inline void gnttab_flush_tlb(const struct domain *d)
>  {
> @@ -250,6 +318,15 @@ static inline void active_entry_release(struct
> active_grant_entry *act)
>      spin_unlock(&act->lock);
>  }
> 
> +#define GRANT_STATUS_PER_PAGE (PAGE_SIZE / sizeof(grant_status_t))
> +#define GRANT_PER_PAGE (PAGE_SIZE / sizeof(grant_entry_v2_t))
> +/* Number of grant table status entries. Caller must hold d's gr. table lock.*/
> +static inline unsigned int grant_to_status_frames(unsigned int
> grant_frames)
> +{
> +    return (grant_frames * GRANT_PER_PAGE + GRANT_STATUS_PER_PAGE
> - 1) /
> +        GRANT_STATUS_PER_PAGE;
> +}
> +
>  /* Check if the page has been paged out, or needs unsharing.
>     If rc == GNTST_okay, *page contains the page struct with a ref taken.
>     Caller must do put_page(*page).
> @@ -1580,7 +1657,7 @@ gnttab_unpopulate_status_frames(struct domain
> *d, struct grant_table *gt)
>   * Grow the grant table. The caller must hold the grant table's
>   * write lock before calling this function.
>   */
> -int
> +static int
>  gnttab_grow_table(struct domain *d, unsigned int req_nr_frames)
>  {
>      struct grant_table *gt = d->grant_table;
> diff --git a/xen/include/xen/grant_table.h b/xen/include/xen/grant_table.h
> index 43ec6c4d80..43b07e60c5 100644
> --- a/xen/include/xen/grant_table.h
> +++ b/xen/include/xen/grant_table.h
> @@ -29,66 +29,9 @@
>  #include <asm/page.h>
>  #include <asm/grant_table.h>
> 
> -#ifndef DEFAULT_MAX_NR_GRANT_FRAMES /* to allow arch to override */
> -/* Default maximum size of a grant table. [POLICY] */
> -#define DEFAULT_MAX_NR_GRANT_FRAMES   32
> -#endif
>  /* The maximum size of a grant table. */
>  extern unsigned int max_grant_frames;
> 
> -DECLARE_PERCPU_RWLOCK_GLOBAL(grant_rwlock);
> -
> -/* Per-domain grant information. */
> -struct grant_table {
> -    /*
> -     * Lock protecting updates to grant table state (version, active
> -     * entry list, etc.)
> -     */
> -    percpu_rwlock_t       lock;
> -    /* Table size. Number of frames shared with guest */
> -    unsigned int          nr_grant_frames;
> -    /* Shared grant table (see include/public/grant_table.h). */
> -    union {
> -        void **shared_raw;
> -        struct grant_entry_v1 **shared_v1;
> -        union grant_entry_v2 **shared_v2;
> -    };
> -    /* Number of grant status frames shared with guest (for version 2) */
> -    unsigned int          nr_status_frames;
> -    /* State grant table (see include/public/grant_table.h). */
> -    grant_status_t       **status;
> -    /* Active grant table. */
> -    struct active_grant_entry **active;
> -    /* Mapping tracking table per vcpu. */
> -    struct grant_mapping **maptrack;
> -    unsigned int          maptrack_limit;
> -    /* Lock protecting the maptrack limit */
> -    spinlock_t            maptrack_lock;
> -    /* The defined versions are 1 and 2.  Set to 0 if we don't know
> -       what version to use yet. */
> -    unsigned              gt_version;
> -};
> -
> -static inline void grant_read_lock(struct grant_table *gt)
> -{
> -    percpu_read_lock(grant_rwlock, &gt->lock);
> -}
> -
> -static inline void grant_read_unlock(struct grant_table *gt)
> -{
> -    percpu_read_unlock(grant_rwlock, &gt->lock);
> -}
> -
> -static inline void grant_write_lock(struct grant_table *gt)
> -{
> -    percpu_write_lock(grant_rwlock, &gt->lock);
> -}
> -
> -static inline void grant_write_unlock(struct grant_table *gt)
> -{
> -    percpu_write_unlock(grant_rwlock, &gt->lock);
> -}
> -
>  /* Create/destroy per-domain grant table context. */
>  int grant_table_create(
>      struct domain *d);
> @@ -106,33 +49,6 @@ void
>  gnttab_release_mappings(
>      struct domain *d);
> 
> -/* Increase the size of a domain's grant table.
> - * Caller must hold d's grant table write lock.
> - */
> -int
> -gnttab_grow_table(struct domain *d, unsigned int req_nr_frames);
> -
> -/* Number of grant table frames. Caller must hold d's grant table lock. */
> -static inline unsigned int nr_grant_frames(struct grant_table *gt)
> -{
> -    return gt->nr_grant_frames;
> -}
> -
> -/* Number of status grant table frames. Caller must hold d's gr. table lock.*/
> -static inline unsigned int nr_status_frames(struct grant_table *gt)
> -{
> -    return gt->nr_status_frames;
> -}
> -
> -#define GRANT_STATUS_PER_PAGE (PAGE_SIZE / sizeof(grant_status_t))
> -#define GRANT_PER_PAGE (PAGE_SIZE / sizeof(grant_entry_v2_t))
> -/* Number of grant table status entries. Caller must hold d's gr. table lock.*/
> -static inline unsigned int grant_to_status_frames(int grant_frames)
> -{
> -    return (grant_frames * GRANT_PER_PAGE + GRANT_STATUS_PER_PAGE
> - 1) /
> -        GRANT_STATUS_PER_PAGE;
> -}
> -
>  int mem_sharing_gref_to_gfn(struct grant_table *gt, grant_ref_t ref,
>                              gfn_t *gfn, uint16_t *status);
> 
> --
> 2.12.3
> 
> 
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@lists.xen.org
> https://lists.xen.org/xen-devel
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xen.org
https://lists.xen.org/xen-devel

  reply	other threads:[~2017-09-06  8:37 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-09-06  8:26 [PATCH v2 0/8] xen: better grant v2 support Juergen Gross
2017-09-06  8:26 ` [PATCH v2 1/8] xen: move XENMAPSPACE_grant_table code into grant_table.c Juergen Gross
2017-09-06  8:34   ` Paul Durrant
2017-09-06  9:31     ` Juergen Gross
2017-09-06 10:04   ` Wei Liu
2017-09-06  8:26 ` [PATCH v2 2/8] xen: clean up grant_table.h Juergen Gross
2017-09-06  8:37   ` Paul Durrant [this message]
2017-09-06 10:11   ` Wei Liu
2017-09-06 10:12     ` Juergen Gross
2017-09-06  8:26 ` [PATCH v2 3/8] xen: delay allocation of grant table sub structures Juergen Gross
2017-09-06  8:44   ` Paul Durrant
2017-09-06  9:42     ` Juergen Gross
2017-09-06  9:43       ` Paul Durrant
2017-09-06  8:26 ` [PATCH v2 4/8] xen: make grant resource limits per domain Juergen Gross
2017-09-06  9:10   ` Paul Durrant
2017-09-06  9:42     ` Juergen Gross
2017-09-06  8:26 ` [PATCH v2 5/8] xen: double default grant frame limit for huge hosts Juergen Gross
2017-09-06  9:12   ` Paul Durrant
2017-09-06  8:26 ` [PATCH v2 6/8] xen: add new domctl hypercall to set grant table resource limits Juergen Gross
2017-09-06  9:17   ` Paul Durrant
2017-09-06  9:43     ` Juergen Gross
2017-09-06  8:26 ` [PATCH v2 7/8] libxc: add libxc support for setting " Juergen Gross
2017-09-06  8:26 ` [PATCH v2 8/8] libxl: add libxl " Juergen Gross

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=684c7acdb6094e33832bba27a83f01b4@AMSPEX02CL03.citrite.net \
    --to=paul.durrant@citrix.com \
    --cc=Andrew.Cooper3@citrix.com \
    --cc=George.Dunlap@citrix.com \
    --cc=Ian.Jackson@citrix.com \
    --cc=jbeulich@suse.com \
    --cc=jgross@suse.com \
    --cc=sstabellini@kernel.org \
    --cc=tim@xen.org \
    --cc=wei.liu2@citrix.com \
    --cc=xen-devel@lists.xen.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).