From: Daniel Vetter <daniel@ffwll.ch>
To: Chris Wilson <chris@chris-wilson.co.uk>
Cc: intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org
Subject: Re: [PATCH v4 34/38] drm: Wrap drm_mm_node.hole_follows
Date: Wed, 28 Dec 2016 14:02:27 +0100 [thread overview]
Message-ID: <20161228130227.GL347@dvetter-linux.ger.corp.intel.com> (raw)
In-Reply-To: <20161222083641.2691-35-chris@chris-wilson.co.uk>
On Thu, Dec 22, 2016 at 08:36:37AM +0000, Chris Wilson wrote:
> Insulate users from changes to the internal hole tracking within
> struct drm_mm_node by using an accessor for hole_follows.
>
> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
> Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
> ---
> drivers/gpu/drm/drm_mm.c | 12 ++++++------
> drivers/gpu/drm/i915/i915_vma.c | 4 ++--
This required some wragling in i915_vma.c to make it apply to drm-misc,
and then resolving the conflict in drm-tip. Please double-check when
rebasing that I didn't botch it up.
Thanks, Daniel
> drivers/gpu/drm/selftests/test-drm_mm.c | 18 ++++++++++--------
> include/drm/drm_mm.h | 22 +++++++++++++++++++---
> 4 files changed, 37 insertions(+), 19 deletions(-)
>
> diff --git a/drivers/gpu/drm/drm_mm.c b/drivers/gpu/drm/drm_mm.c
> index b59978fe4c6e..c0024719f32b 100644
> --- a/drivers/gpu/drm/drm_mm.c
> +++ b/drivers/gpu/drm/drm_mm.c
> @@ -323,7 +323,7 @@ int drm_mm_reserve_node(struct drm_mm *mm, struct drm_mm_node *node)
> }
>
> hole = list_last_entry(&hole->node_list, typeof(*hole), node_list);
> - if (!hole->hole_follows)
> + if (!drm_mm_hole_follows(hole))
> return -ENOSPC;
>
> adj_start = hole_start = __drm_mm_hole_node_start(hole);
> @@ -408,7 +408,7 @@ static void drm_mm_insert_helper_range(struct drm_mm_node *hole_node,
> u64 adj_start = hole_start;
> u64 adj_end = hole_end;
>
> - DRM_MM_BUG_ON(!hole_node->hole_follows || node->allocated);
> + DRM_MM_BUG_ON(!drm_mm_hole_follows(hole_node) || node->allocated);
>
> if (adj_start < start)
> adj_start = start;
> @@ -523,16 +523,16 @@ void drm_mm_remove_node(struct drm_mm_node *node)
> prev_node =
> list_entry(node->node_list.prev, struct drm_mm_node, node_list);
>
> - if (node->hole_follows) {
> + if (drm_mm_hole_follows(node)) {
> DRM_MM_BUG_ON(__drm_mm_hole_node_start(node) ==
> __drm_mm_hole_node_end(node));
> list_del(&node->hole_stack);
> - } else
> + } else {
> DRM_MM_BUG_ON(__drm_mm_hole_node_start(node) !=
> __drm_mm_hole_node_end(node));
> + }
>
> -
> - if (!prev_node->hole_follows) {
> + if (!drm_mm_hole_follows(prev_node)) {
> prev_node->hole_follows = 1;
> list_add(&prev_node->hole_stack, &mm->hole_stack);
> } else
> diff --git a/drivers/gpu/drm/i915/i915_vma.c b/drivers/gpu/drm/i915/i915_vma.c
> index 608008d2d999..cfec4222b04e 100644
> --- a/drivers/gpu/drm/i915/i915_vma.c
> +++ b/drivers/gpu/drm/i915/i915_vma.c
> @@ -327,11 +327,11 @@ bool i915_gem_valid_gtt_space(struct i915_vma *vma, unsigned long cache_level)
> GEM_BUG_ON(list_empty(&node->node_list));
>
> other = list_prev_entry(node, node_list);
> - if (color_differs(other, cache_level) && !other->hole_follows)
> + if (color_differs(other, cache_level) && !drm_mm_hole_follows(other))
> return false;
>
> other = list_next_entry(node, node_list);
> - if (color_differs(other, cache_level) && !node->hole_follows)
> + if (color_differs(other, cache_level) && !drm_mm_hole_follows(node))
> return false;
>
> return true;
> diff --git a/drivers/gpu/drm/selftests/test-drm_mm.c b/drivers/gpu/drm/selftests/test-drm_mm.c
> index f609e4f1eeaf..2ce92f4dcfc7 100644
> --- a/drivers/gpu/drm/selftests/test-drm_mm.c
> +++ b/drivers/gpu/drm/selftests/test-drm_mm.c
> @@ -63,7 +63,7 @@ static bool assert_no_holes(const struct drm_mm *mm)
> }
>
> drm_mm_for_each_node(hole, mm) {
> - if (hole->hole_follows) {
> + if (drm_mm_hole_follows(hole)) {
> pr_err("Hole follows node, expected none!\n");
> return false;
> }
> @@ -125,7 +125,7 @@ static bool assert_continuous(const struct drm_mm *mm, u64 size)
> return false;
> }
>
> - if (node->hole_follows) {
> + if (drm_mm_hole_follows(node)) {
> pr_err("node[%ld] is followed by a hole!\n", n);
> return false;
> }
> @@ -828,7 +828,8 @@ static bool assert_contiguous_in_range(struct drm_mm *mm,
> return false;
> }
>
> - if (node->hole_follows && drm_mm_hole_node_end(node) < end) {
> + if (drm_mm_hole_follows(node) &&
> + drm_mm_hole_node_end(node) < end) {
> pr_err("node %d is followed by a hole!\n", n);
> return false;
> }
> @@ -1337,11 +1338,12 @@ static int evict_something(struct drm_mm *mm,
> err = -EINVAL;
> }
>
> - if (!assert_node(&tmp, mm, size, alignment, 0) || tmp.hole_follows) {
> + if (!assert_node(&tmp, mm, size, alignment, 0) ||
> + drm_mm_hole_follows(&tmp)) {
> pr_err("Inserted did not fill the eviction hole: size=%lld [%d], align=%d [rem=%lld], start=%llx, hole-follows?=%d\n",
> tmp.size, size,
> alignment, misalignment(&tmp, alignment),
> - tmp.start, tmp.hole_follows);
> + tmp.start, drm_mm_hole_follows(&tmp));
> err = -EINVAL;
> }
>
> @@ -1618,7 +1620,7 @@ static int igt_topdown(void *ignored)
> goto out;
> }
>
> - if (nodes[n].hole_follows) {
> + if (drm_mm_hole_follows(&nodes[n])) {
> pr_err("hole after topdown insert %d, start=%llx\n, size=%u",
> n, nodes[n].start, size);
> goto out;
> @@ -1650,7 +1652,7 @@ static int igt_topdown(void *ignored)
> goto out;
> }
>
> - if (node->hole_follows) {
> + if (drm_mm_hole_follows(node)) {
> pr_err("hole after topdown insert %d/%d, start=%llx\n",
> m, n, node->start);
> goto out;
> @@ -1705,7 +1707,7 @@ static void separate_adjacent_colors(const struct drm_mm_node *node,
>
> static bool colors_abutt(const struct drm_mm_node *node)
> {
> - if (!node->hole_follows &&
> + if (!drm_mm_hole_follows(node) &&
> list_next_entry(node, node_list)->allocated) {
> pr_err("colors abutt; %ld [%llx + %llx] is next to %ld [%llx + %llx]!\n",
> node->color, node->start, node->size,
> diff --git a/include/drm/drm_mm.h b/include/drm/drm_mm.h
> index aed93cbc4bde..7da7a171d6d5 100644
> --- a/include/drm/drm_mm.h
> +++ b/include/drm/drm_mm.h
> @@ -155,6 +155,22 @@ static inline bool drm_mm_initialized(const struct drm_mm *mm)
> return mm->hole_stack.next;
> }
>
> +/**
> + * drm_mm_hole_follows - checks whether a hole follows this node
> + * @node: drm_mm_node to check
> + *
> + * Holes are embedded into the drm_mm using the tail of a drm_mm_node.
> + * If you wish to know whether a hole follows this particular node,
> + * query this function.
> + *
> + * Returns:
> + * True if a hole follows the @node.
> + */
> +static inline bool drm_mm_hole_follows(const struct drm_mm_node *node)
> +{
> + return node->hole_follows;
> +}
> +
> static inline u64 __drm_mm_hole_node_start(const struct drm_mm_node *hole_node)
> {
> return hole_node->start + hole_node->size;
> @@ -166,14 +182,14 @@ static inline u64 __drm_mm_hole_node_start(const struct drm_mm_node *hole_node)
> *
> * This is useful for driver-specific debug dumpers. Otherwise drivers should
> * not inspect holes themselves. Drivers must check first whether a hole indeed
> - * follows by looking at node->hole_follows.
> + * follows by looking at drm_mm_hole_follows()
> *
> * Returns:
> * Start of the subsequent hole.
> */
> static inline u64 drm_mm_hole_node_start(const struct drm_mm_node *hole_node)
> {
> - DRM_MM_BUG_ON(!hole_node->hole_follows);
> + DRM_MM_BUG_ON(!drm_mm_hole_follows(hole_node));
> return __drm_mm_hole_node_start(hole_node);
> }
>
> @@ -188,7 +204,7 @@ static inline u64 __drm_mm_hole_node_end(const struct drm_mm_node *hole_node)
> *
> * This is useful for driver-specific debug dumpers. Otherwise drivers should
> * not inspect holes themselves. Drivers must check first whether a hole indeed
> - * follows by looking at node->hole_follows.
> + * follows by looking at drm_mm_hole_follows().
> *
> * Returns:
> * End of the subsequent hole.
> --
> 2.11.0
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gfx
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx
next prev parent reply other threads:[~2016-12-28 13:02 UTC|newest]
Thread overview: 61+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-22 8:36 drm_mm fixes, take 4? Chris Wilson
2016-12-22 8:36 ` [PATCH v4 01/38] drm/i915: Use the MRU stack search after evicting Chris Wilson
2016-12-27 11:30 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 02/38] drm: Use drm_mm_nodes() as shorthand for the list of nodes under struct drm_mm Chris Wilson
2016-12-22 8:36 ` [PATCH v4 03/38] drm: Compile time enabling for asserts in drm_mm Chris Wilson
2016-12-22 8:36 ` [PATCH v4 04/38] lib: Add a simple prime number generator Chris Wilson
2016-12-22 9:52 ` Joonas Lahtinen
2016-12-22 10:00 ` [Intel-gfx] " Chris Wilson
2016-12-22 14:45 ` [PATCH v10] " Chris Wilson
2016-12-27 11:31 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 05/38] drm: Add a simple generator of random permutations Chris Wilson
2016-12-27 11:33 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 06/38] drm: Add some kselftests for the DRM range manager (struct drm_mm) Chris Wilson
2016-12-27 11:36 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 07/38] drm: kselftest for drm_mm_init() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 08/38] drm: kselftest for drm_mm_debug() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 09/38] drm: kselftest for drm_mm_reserve_node() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 10/38] drm: kselftest for drm_mm_insert_node() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 11/38] drm: kselftest for drm_mm_replace_node() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 12/38] drm: kselftest for drm_mm_insert_node_in_range() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 13/38] drm: kselftest for drm_mm and alignment Chris Wilson
2016-12-22 8:36 ` [PATCH v4 14/38] drm: kselftest for drm_mm and eviction Chris Wilson
2016-12-22 8:36 ` [PATCH v4 15/38] drm: kselftest for drm_mm and range restricted eviction Chris Wilson
2016-12-22 8:36 ` [PATCH v4 16/38] drm: kselftest for drm_mm and top-down allocation Chris Wilson
2016-12-22 8:36 ` [PATCH v4 17/38] drm: kselftest for drm_mm and color adjustment Chris Wilson
2016-12-22 8:36 ` [PATCH v4 18/38] drm: kselftest for drm_mm and color eviction Chris Wilson
2016-12-22 8:36 ` [PATCH v4 19/38] drm: kselftest for drm_mm and restricted " Chris Wilson
2016-12-22 8:36 ` [PATCH v4 20/38] drm/i915: Build DRM range manager selftests for CI Chris Wilson
2016-12-27 13:03 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 21/38] drm: Promote drm_mm alignment to u64 Chris Wilson
2016-12-22 8:36 ` [PATCH v4 22/38] drm: Fix kerneldoc for drm_mm_scan_remove_block() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 23/38] drm: Detect overflow in drm_mm_reserve_node() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 24/38] drm: Simplify drm_mm_clean() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 25/38] drm: Add asserts to catch overflow in drm_mm_init() and drm_mm_init_scan() Chris Wilson
2016-12-27 13:12 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 26/38] drm: Extract struct drm_mm_scan from struct drm_mm Chris Wilson
2016-12-27 15:48 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 27/38] drm: Rename prev_node to hole in drm_mm_scan_add_block() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 28/38] drm: Unconditionally do the range check " Chris Wilson
2016-12-22 8:36 ` [PATCH v4 29/38] drm: Fix application of color vs range restriction when scanning drm_mm Chris Wilson
2016-12-22 8:36 ` [PATCH v4 30/38] drm: Compute tight evictions for drm_mm_scan Chris Wilson
2016-12-28 13:01 ` [Intel-gfx] " Daniel Vetter
2016-12-28 14:36 ` Chris Wilson
2016-12-22 8:36 ` [PATCH v4 31/38] drm: Optimise power-of-two alignments in drm_mm_scan_add_block() Chris Wilson
2016-12-22 8:36 ` [PATCH v4 32/38] drm: Simplify drm_mm scan-list manipulation Chris Wilson
2016-12-22 8:36 ` [PATCH v4 33/38] drm: Apply tight eviction scanning to color_adjust Chris Wilson
2016-12-22 8:36 ` [PATCH v4 34/38] drm: Wrap drm_mm_node.hole_follows Chris Wilson
2016-12-28 13:02 ` Daniel Vetter [this message]
2016-12-28 13:31 ` Chris Wilson
2016-12-28 14:31 ` Daniel Vetter
2016-12-28 18:47 ` Chris Wilson
2016-12-22 8:36 ` [PATCH v4 35/38] drm: Apply range restriction after color adjustment when allocation Chris Wilson
2016-12-22 8:36 ` [PATCH v4 36/38] drm: Use drm_mm_insert_node_in_range_generic() for everyone Chris Wilson
2016-12-22 8:36 ` [PATCH v4 37/38] drm: Improve drm_mm search (and fix topdown allocation) with rbtrees Chris Wilson
2016-12-28 11:08 ` Chris Wilson
2016-12-28 13:48 ` Daniel Vetter
2016-12-28 14:34 ` Daniel Vetter
2016-12-22 8:36 ` [PATCH v4 38/38] drm: kselftest for drm_mm and bottom-up allocation Chris Wilson
2016-12-22 9:15 ` ✗ Fi.CI.BAT: warning for series starting with [v4,01/38] drm/i915: Use the MRU stack search after evicting Patchwork
2016-12-22 9:47 ` Imre Deak
2016-12-22 20:53 ` ✓ Fi.CI.BAT: success for series starting with [v4,01/38] drm/i915: Use the MRU stack search after evicting (rev2) Patchwork
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=20161228130227.GL347@dvetter-linux.ger.corp.intel.com \
--to=daniel@ffwll.ch \
--cc=chris@chris-wilson.co.uk \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.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