From: Tvrtko Ursulin <tursulin@ursulin.net>
To: Intel-gfx@lists.freedesktop.org
Cc: Jani Nikula <jani.nikula@intel.com>
Subject: [PATCH 1/3] drm/i915: Introduct i915_platforms.h
Date: Thu, 8 Dec 2016 09:49:57 +0000 [thread overview]
Message-ID: <1481190599-1217-2-git-send-email-tvrtko.ursulin@linux.intel.com> (raw)
In-Reply-To: <1481190599-1217-1-git-send-email-tvrtko.ursulin@linux.intel.com>
From: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Inspired by the same approach used by Chris Wilson in the self
test patches.
We add a separate header file containing the list of our
platforms and then use the pre-processor to generate all
other places which use that list. This avoids having to
list them multiple times and avoids the maintenance
burden.
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Jani Nikula <jani.nikula@intel.com>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
---
drivers/gpu/drm/i915/i915_drv.h | 30 +++-------------------------
drivers/gpu/drm/i915/i915_platforms.h | 34 ++++++++++++++++++++++++++++++++
drivers/gpu/drm/i915/intel_device_info.c | 30 +++-------------------------
3 files changed, 40 insertions(+), 54 deletions(-)
create mode 100644 drivers/gpu/drm/i915/i915_platforms.h
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h
index 1480e733312a..ea06d3ff59da 100644
--- a/drivers/gpu/drm/i915/i915_drv.h
+++ b/drivers/gpu/drm/i915/i915_drv.h
@@ -825,34 +825,10 @@ static inline unsigned int sseu_subslice_total(const struct sseu_dev_info *sseu)
return hweight8(sseu->slice_mask) * hweight8(sseu->subslice_mask);
}
-/* Keep in gen based order, and chronological order within a gen */
enum intel_platform {
- INTEL_PLATFORM_UNINITIALIZED = 0,
- INTEL_I830,
- INTEL_I845G,
- INTEL_I85X,
- INTEL_I865G,
- INTEL_I915G,
- INTEL_I915GM,
- INTEL_I945G,
- INTEL_I945GM,
- INTEL_G33,
- INTEL_PINEVIEW,
- INTEL_I965G,
- INTEL_I965GM,
- INTEL_G45,
- INTEL_GM45,
- INTEL_IRONLAKE,
- INTEL_SANDYBRIDGE,
- INTEL_IVYBRIDGE,
- INTEL_VALLEYVIEW,
- INTEL_HASWELL,
- INTEL_BROADWELL,
- INTEL_CHERRYVIEW,
- INTEL_SKYLAKE,
- INTEL_BROXTON,
- INTEL_KABYLAKE,
- INTEL_GEMINILAKE,
+#define i915_platform(name, value) INTEL_##name = value,
+#include "i915_platforms.h"
+#undef i915_platform
};
struct intel_device_info {
diff --git a/drivers/gpu/drm/i915/i915_platforms.h b/drivers/gpu/drm/i915/i915_platforms.h
new file mode 100644
index 000000000000..b44ea1dd9c15
--- /dev/null
+++ b/drivers/gpu/drm/i915/i915_platforms.h
@@ -0,0 +1,34 @@
+/*
+ * List each platform as i915_platform(name, id).
+ *
+ * Names must be legal C identifiers and the ids must be unique integers.
+ *
+ * Keep in gen based order, and chronological order within a gen.
+ */
+
+i915_platform(UNINITIALIZED, 0)
+i915_platform(I830, 1)
+i915_platform(I845G, 2)
+i915_platform(I85X, 3)
+i915_platform(I865G, 4)
+i915_platform(I915G, 5)
+i915_platform(I915GM, 6)
+i915_platform(I945G, 7)
+i915_platform(I945GM, 8)
+i915_platform(G33, 9)
+i915_platform(PINEVIEW, 10)
+i915_platform(I965G, 11)
+i915_platform(I965GM, 12)
+i915_platform(G45, 13)
+i915_platform(GM45, 14)
+i915_platform(IRONLAKE, 15)
+i915_platform(SANDYBRIDGE, 16)
+i915_platform(IVYBRIDGE, 17)
+i915_platform(VALLEYVIEW, 18)
+i915_platform(HASWELL, 19)
+i915_platform(BROADWELL, 20)
+i915_platform(CHERRYVIEW, 21)
+i915_platform(SKYLAKE, 22)
+i915_platform(BROXTON, 23)
+i915_platform(KABYLAKE, 24)
+i915_platform(GEMINILAKE, 25)
diff --git a/drivers/gpu/drm/i915/intel_device_info.c b/drivers/gpu/drm/i915/intel_device_info.c
index c46415b8c1b9..5192d388d10e 100644
--- a/drivers/gpu/drm/i915/intel_device_info.c
+++ b/drivers/gpu/drm/i915/intel_device_info.c
@@ -24,35 +24,11 @@
#include "i915_drv.h"
-#define PLATFORM_NAME(x) [INTEL_##x] = #x
static const char * const platform_names[] = {
- PLATFORM_NAME(I830),
- PLATFORM_NAME(I845G),
- PLATFORM_NAME(I85X),
- PLATFORM_NAME(I865G),
- PLATFORM_NAME(I915G),
- PLATFORM_NAME(I915GM),
- PLATFORM_NAME(I945G),
- PLATFORM_NAME(I945GM),
- PLATFORM_NAME(G33),
- PLATFORM_NAME(PINEVIEW),
- PLATFORM_NAME(I965G),
- PLATFORM_NAME(I965GM),
- PLATFORM_NAME(G45),
- PLATFORM_NAME(GM45),
- PLATFORM_NAME(IRONLAKE),
- PLATFORM_NAME(SANDYBRIDGE),
- PLATFORM_NAME(IVYBRIDGE),
- PLATFORM_NAME(VALLEYVIEW),
- PLATFORM_NAME(HASWELL),
- PLATFORM_NAME(BROADWELL),
- PLATFORM_NAME(CHERRYVIEW),
- PLATFORM_NAME(SKYLAKE),
- PLATFORM_NAME(BROXTON),
- PLATFORM_NAME(KABYLAKE),
- PLATFORM_NAME(GEMINILAKE),
+#define i915_platform(name, id) [id] = #name,
+#include "i915_platforms.h"
+#undef i915_platform
};
-#undef PLATFORM_NAME
const char *intel_platform_name(enum intel_platform platform)
{
--
2.7.4
_______________________________________________
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-08 9:50 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-08 9:49 [PATCH 0/3] Claw back the IS_<platform> optimisation Tvrtko Ursulin
2016-12-08 9:49 ` Tvrtko Ursulin [this message]
2016-12-08 10:41 ` [PATCH 1/3] drm/i915: Introduct i915_platforms.h Jani Nikula
2016-12-08 13:16 ` Joonas Lahtinen
2016-12-08 13:21 ` Tvrtko Ursulin
2016-12-08 9:49 ` [PATCH 2/3] drm/i915: Generate all IS_<platform> macros Tvrtko Ursulin
2016-12-08 10:46 ` Jani Nikula
2016-12-08 13:26 ` Tvrtko Ursulin
2016-12-08 13:37 ` Jani Nikula
2016-12-08 13:40 ` Jani Nikula
2016-12-08 13:42 ` Tvrtko Ursulin
2016-12-08 14:00 ` Jani Nikula
2016-12-08 14:10 ` Tvrtko Ursulin
2016-12-08 9:49 ` [PATCH 3/3] drm/i915: Number the platform enum strategically Tvrtko Ursulin
2016-12-08 10:04 ` Chris Wilson
2016-12-08 13:38 ` [PATCH v2] " Tvrtko Ursulin
2016-12-08 11:54 ` ✓ Fi.CI.BAT: success for Claw back the IS_<platform> optimisation Patchwork
2016-12-08 15:15 ` ✗ Fi.CI.BAT: warning for Claw back the IS_<platform> optimisation (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=1481190599-1217-2-git-send-email-tvrtko.ursulin@linux.intel.com \
--to=tursulin@ursulin.net \
--cc=Intel-gfx@lists.freedesktop.org \
--cc=jani.nikula@intel.com \
/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