* [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
@ 2021-05-17  0:46 Piotr Kubaj
  2021-05-18 20:42 ` David Christensen
  0 siblings, 1 reply; 6+ messages in thread
From: Piotr Kubaj @ 2021-05-17  0:46 UTC (permalink / raw)
  To: drc; +Cc: dev, Piotr Kubaj
__ppc_get_timebase() is only present when glibc is used.
Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
---
 lib/eal/ppc/include/rte_altivec.h |  3 +++
 lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
 lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
 3 files changed, 31 insertions(+)
diff --git a/lib/eal/ppc/include/rte_altivec.h b/lib/eal/ppc/include/rte_altivec.h
index 1551a94544..3fcc819c11 100644
--- a/lib/eal/ppc/include/rte_altivec.h
+++ b/lib/eal/ppc/include/rte_altivec.h
@@ -7,6 +7,9 @@
 #define _RTE_ALTIVEC_H_
 
 /* To include altivec.h, GCC version must be >= 4.8 */
+#ifdef __clang__
+#define vector __vector
+#endif
 #include <altivec.h>
 
 /*
diff --git a/lib/eal/ppc/include/rte_cycles.h b/lib/eal/ppc/include/rte_cycles.h
index 5585f9273c..a8307ceaff 100644
--- a/lib/eal/ppc/include/rte_cycles.h
+++ b/lib/eal/ppc/include/rte_cycles.h
@@ -10,7 +10,13 @@
 extern "C" {
 #endif
 
+#ifdef linux
+#include <features.h>
+#endif
+
+#ifdef __GLIBC__
 #include <sys/platform/ppc.h>
+#endif
 
 #include "generic/rte_cycles.h"
 
@@ -26,7 +32,13 @@ extern "C" {
 static inline uint64_t
 rte_rdtsc(void)
 {
+#ifdef __GLIBC__
 	return __ppc_get_timebase();
+#else
+	uint64_t __tb;
+	__asm__ volatile ("mfspr %0, 268" : "=r" (__tb));
+	return __tb;
+#endif
 }
 
 static inline uint64_t
diff --git a/lib/eal/ppc/rte_cycles.c b/lib/eal/ppc/rte_cycles.c
index 3180adb0ff..48545c4d67 100644
--- a/lib/eal/ppc/rte_cycles.c
+++ b/lib/eal/ppc/rte_cycles.c
@@ -2,12 +2,28 @@
  * Copyright (C) IBM Corporation 2019.
  */
 
+#ifdef linux
+#include <features.h>
+#elif defined(__FreeBSD__)
+#include <sys/types.h>
+#include <sys/sysctl.h>
+#endif
+
+#ifdef __GLIBC__
 #include <sys/platform/ppc.h>
+#endif
 
 #include "eal_private.h"
 
 uint64_t
 get_tsc_freq_arch(void)
 {
+#ifdef __GLIBC__
 	return __ppc_get_timebase_freq();
+#elif defined(__FreeBSD__)
+	uint64_t freq;
+	size_t length = sizeof(freq);
+	sysctlbyname("kern.timecounter.tc.timebase.frequency", &freq, &length, NULL, 0);
+	return freq;
+#endif
 }
-- 
2.31.1
^ permalink raw reply related	[flat|nested] 6+ messages in thread- * Re: [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
  2021-05-17  0:46 [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang Piotr Kubaj
@ 2021-05-18 20:42 ` David Christensen
  2021-05-19  7:53   ` Thomas Monjalon
  0 siblings, 1 reply; 6+ messages in thread
From: David Christensen @ 2021-05-18 20:42 UTC (permalink / raw)
  To: Piotr Kubaj; +Cc: dev
On 5/16/21 5:46 PM, Piotr Kubaj wrote:
> __ppc_get_timebase() is only present when glibc is used.
> 
> Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
> ---
>   lib/eal/ppc/include/rte_altivec.h |  3 +++
>   lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
>   lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
>   3 files changed, 31 insertions(+)
> 
> diff --git a/lib/eal/ppc/include/rte_altivec.h b/lib/eal/ppc/include/rte_altivec.h
> index 1551a94544..3fcc819c11 100644
> --- a/lib/eal/ppc/include/rte_altivec.h
> +++ b/lib/eal/ppc/include/rte_altivec.h
> @@ -7,6 +7,9 @@
>   #define _RTE_ALTIVEC_H_
> 
>   /* To include altivec.h, GCC version must be >= 4.8 */
> +#ifdef __clang__
> +#define vector __vector
> +#endif
>   #include <altivec.h>
> 
>   /*
> diff --git a/lib/eal/ppc/include/rte_cycles.h b/lib/eal/ppc/include/rte_cycles.h
> index 5585f9273c..a8307ceaff 100644
> --- a/lib/eal/ppc/include/rte_cycles.h
> +++ b/lib/eal/ppc/include/rte_cycles.h
> @@ -10,7 +10,13 @@
>   extern "C" {
>   #endif
> 
> +#ifdef linux
> +#include <features.h>
> +#endif
> +
> +#ifdef __GLIBC__
>   #include <sys/platform/ppc.h>
> +#endif
> 
>   #include "generic/rte_cycles.h"
> 
> @@ -26,7 +32,13 @@ extern "C" {
>   static inline uint64_t
>   rte_rdtsc(void)
>   {
> +#ifdef __GLIBC__
>   	return __ppc_get_timebase();
> +#else
> +	uint64_t __tb;
> +	__asm__ volatile ("mfspr %0, 268" : "=r" (__tb));
> +	return __tb;
> +#endif
>   }
> 
>   static inline uint64_t
> diff --git a/lib/eal/ppc/rte_cycles.c b/lib/eal/ppc/rte_cycles.c
> index 3180adb0ff..48545c4d67 100644
> --- a/lib/eal/ppc/rte_cycles.c
> +++ b/lib/eal/ppc/rte_cycles.c
> @@ -2,12 +2,28 @@
>    * Copyright (C) IBM Corporation 2019.
>    */
> 
> +#ifdef linux
> +#include <features.h>
> +#elif defined(__FreeBSD__)
> +#include <sys/types.h>
> +#include <sys/sysctl.h>
> +#endif
> +
> +#ifdef __GLIBC__
>   #include <sys/platform/ppc.h>
> +#endif
> 
>   #include "eal_private.h"
> 
>   uint64_t
>   get_tsc_freq_arch(void)
>   {
> +#ifdef __GLIBC__
>   	return __ppc_get_timebase_freq();
> +#elif defined(__FreeBSD__)
> +	uint64_t freq;
> +	size_t length = sizeof(freq);
> +	sysctlbyname("kern.timecounter.tc.timebase.frequency", &freq, &length, NULL, 0);
> +	return freq;
> +#endif
>   }
> 
Reviewed-by: David Christensen <drc@linux.vnet.ibm.com>
^ permalink raw reply	[flat|nested] 6+ messages in thread
- * Re: [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
  2021-05-18 20:42 ` David Christensen
@ 2021-05-19  7:53   ` Thomas Monjalon
  2021-05-19  9:57     ` Piotr Kubaj
  0 siblings, 1 reply; 6+ messages in thread
From: Thomas Monjalon @ 2021-05-19  7:53 UTC (permalink / raw)
  To: Piotr Kubaj; +Cc: dev, David Christensen
18/05/2021 22:42, David Christensen:
> On 5/16/21 5:46 PM, Piotr Kubaj wrote:
> > __ppc_get_timebase() is only present when glibc is used.
> > 
> > Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
> > ---
> >   lib/eal/ppc/include/rte_altivec.h |  3 +++
> >   lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
> >   lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
> >   3 files changed, 31 insertions(+)
> 
> Reviewed-by: David Christensen <drc@linux.vnet.ibm.com>
This patch does a lot more than what is described.
It seems adding support for FreeBSD.
For testing OS, please use #ifdef RTE_EXEC_ENV_*
^ permalink raw reply	[flat|nested] 6+ messages in thread 
- * Re: [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
  2021-05-19  7:53   ` Thomas Monjalon
@ 2021-05-19  9:57     ` Piotr Kubaj
  2021-05-19  9:59       ` Thomas Monjalon
  0 siblings, 1 reply; 6+ messages in thread
From: Piotr Kubaj @ 2021-05-19  9:57 UTC (permalink / raw)
  To: Thomas Monjalon; +Cc: dev, David Christensen
[-- Attachment #1: Type: text/plain, Size: 815 bytes --]
Well, isn't FreeBSD already supported?
Even https://www.dpdk.org/ mentions supporting FreeBSD.
On 21-05-19 09:53:16, Thomas Monjalon wrote:
> 18/05/2021 22:42, David Christensen:
> > On 5/16/21 5:46 PM, Piotr Kubaj wrote:
> > > __ppc_get_timebase() is only present when glibc is used.
> > > 
> > > Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
> > > ---
> > >   lib/eal/ppc/include/rte_altivec.h |  3 +++
> > >   lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
> > >   lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
> > >   3 files changed, 31 insertions(+)
> > 
> > Reviewed-by: David Christensen <drc@linux.vnet.ibm.com>
> 
> This patch does a lot more than what is described.
> It seems adding support for FreeBSD.
> For testing OS, please use #ifdef RTE_EXEC_ENV_*
> 
> 
^ permalink raw reply	[flat|nested] 6+ messages in thread 
- * Re: [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
  2021-05-19  9:57     ` Piotr Kubaj
@ 2021-05-19  9:59       ` Thomas Monjalon
  2021-05-19 12:07         ` Piotr Kubaj
  0 siblings, 1 reply; 6+ messages in thread
From: Thomas Monjalon @ 2021-05-19  9:59 UTC (permalink / raw)
  To: Piotr Kubaj; +Cc: dev, David Christensen
19/05/2021 11:57, Piotr Kubaj:
> Well, isn't FreeBSD already supported?
> 
> Even https://www.dpdk.org/ mentions supporting FreeBSD.
Yes it is supposed to be supported.
But why are you adding all this code for PPC?
It doesn't seem to be all related to clang only.
PS: please do not top-post.
> On 21-05-19 09:53:16, Thomas Monjalon wrote:
> > 18/05/2021 22:42, David Christensen:
> > > On 5/16/21 5:46 PM, Piotr Kubaj wrote:
> > > > __ppc_get_timebase() is only present when glibc is used.
> > > > 
> > > > Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
> > > > ---
> > > >   lib/eal/ppc/include/rte_altivec.h |  3 +++
> > > >   lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
> > > >   lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
> > > >   3 files changed, 31 insertions(+)
> > > 
> > > Reviewed-by: David Christensen <drc@linux.vnet.ibm.com>
> > 
> > This patch does a lot more than what is described.
> > It seems adding support for FreeBSD.
> > For testing OS, please use #ifdef RTE_EXEC_ENV_*
^ permalink raw reply	[flat|nested] 6+ messages in thread 
- * Re: [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang
  2021-05-19  9:59       ` Thomas Monjalon
@ 2021-05-19 12:07         ` Piotr Kubaj
  0 siblings, 0 replies; 6+ messages in thread
From: Piotr Kubaj @ 2021-05-19 12:07 UTC (permalink / raw)
  To: Thomas Monjalon; +Cc: dev, David Christensen
[-- Attachment #1: Type: text/plain, Size: 1279 bytes --]
On 21-05-19 11:59:35, Thomas Monjalon wrote:
> 19/05/2021 11:57, Piotr Kubaj:
> > Well, isn't FreeBSD already supported?
> > 
> > Even https://www.dpdk.org/ mentions supporting FreeBSD.
> 
> Yes it is supposed to be supported.
> But why are you adding all this code for PPC?
> It doesn't seem to be all related to clang only.
> 
> PS: please do not top-post.
> 
> 
> > On 21-05-19 09:53:16, Thomas Monjalon wrote:
> > > 18/05/2021 22:42, David Christensen:
> > > > On 5/16/21 5:46 PM, Piotr Kubaj wrote:
> > > > > __ppc_get_timebase() is only present when glibc is used.
> > > > > 
> > > > > Signed-off-by: Piotr Kubaj <pkubaj@FreeBSD.org>
> > > > > ---
> > > > >   lib/eal/ppc/include/rte_altivec.h |  3 +++
> > > > >   lib/eal/ppc/include/rte_cycles.h  | 12 ++++++++++++
> > > > >   lib/eal/ppc/rte_cycles.c          | 16 ++++++++++++++++
> > > > >   3 files changed, 31 insertions(+)
> > > > 
> > > > Reviewed-by: David Christensen <drc@linux.vnet.ibm.com>
> > > 
> > > This patch does a lot more than what is described.
> > > It seems adding support for FreeBSD.
> > > For testing OS, please use #ifdef RTE_EXEC_ENV_*
> 
> 
> 
> 
Well, I'm adding this code for PPC, because there are build issues on powerpc64le machines running FreeBSD.
^ permalink raw reply	[flat|nested] 6+ messages in thread 
 
 
 
 
end of thread, other threads:[~2021-05-20  8:01 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-05-17  0:46 [dpdk-dev] [PATCH] ppc64le: fix build without glibc and using Clang Piotr Kubaj
2021-05-18 20:42 ` David Christensen
2021-05-19  7:53   ` Thomas Monjalon
2021-05-19  9:57     ` Piotr Kubaj
2021-05-19  9:59       ` Thomas Monjalon
2021-05-19 12:07         ` Piotr Kubaj
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).