* [PATCH] S390: Add support for HP_TIMING_NOW.
@ 2019-09-10 9:13 Stefan Liebler
2019-09-18 14:16 ` Stefan Liebler
2019-09-18 14:24 ` Adhemerval Zanella
0 siblings, 2 replies; 4+ messages in thread
From: Stefan Liebler @ 2019-09-10 9:13 UTC (permalink / raw)
To: GNU C Library
[-- Attachment #1: Type: text/plain, Size: 213 bytes --]
Hi,
this patch adds support for HP_TIMING_NOW if we build at least
with -march=z10 -mzarch. Otherwise we are still using the
generic hp-timing.h.
Bye,
Stefan
ChangeLog:
* sysdeps/s390/hp-timing.h: New file.
[-- Attachment #2: 20190905_hptiming.patch --]
[-- Type: text/x-patch, Size: 2119 bytes --]
commit 9a0d12c72043f54b7a810a5d7ee0fabdec574bb6
Author: Stefan Liebler <stli@linux.ibm.com>
Date: Thu Sep 5 13:37:45 2019 +0200
S390: Add support for HP_TIMING_NOW.
This patch adds support for HP_TIMING_NOW if we build at least
with -march=z10 -mzarch. Otherwise we are still using the
generic hp-timing.h.
ChangeLog:
* sysdeps/s390/hp-timing.h: New file.
diff --git a/sysdeps/s390/hp-timing.h b/sysdeps/s390/hp-timing.h
new file mode 100644
index 0000000000..b54b8dda9b
--- /dev/null
+++ b/sysdeps/s390/hp-timing.h
@@ -0,0 +1,42 @@
+/* High precision, low overhead timing functions. s390 version.
+ Copyright (C) 2019 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library. If not, see
+ <http://www.gnu.org/licenses/>. */
+
+#ifndef _HP_TIMING_H
+
+/* The stckf instruction is available starting with z9-109 zarch CPUs.
+ As there is no extra configure check for z9-109, the z10 one is used. */
+#ifdef HAVE_S390_MIN_Z10_ZARCH_ASM_SUPPORT
+# define _HP_TIMING_H 1
+# include <hp-timing-common.h>
+
+/* We use 64 bit values for the times.
+ Note: Bit 51 is incremented every 0.000 001s = 1us. */
+typedef unsigned long long int hp_timing_t;
+
+# define HP_TIMING_INLINE (1)
+
+# define HP_TIMING_NOW(VAR) \
+ do { \
+ __asm__ __volatile__ ("stckf %0" : "=Q" (VAR) : : "cc"); \
+ } while (0)
+
+#else
+# include_next <hp-timing.h>
+#endif
+
+#endif /* hp-timing.h */
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] S390: Add support for HP_TIMING_NOW.
2019-09-10 9:13 [PATCH] S390: Add support for HP_TIMING_NOW Stefan Liebler
@ 2019-09-18 14:16 ` Stefan Liebler
2019-09-18 14:24 ` Adhemerval Zanella
1 sibling, 0 replies; 4+ messages in thread
From: Stefan Liebler @ 2019-09-18 14:16 UTC (permalink / raw)
To: libc-alpha
On 9/10/19 11:13 AM, Stefan Liebler wrote:
> Hi,
>
> this patch adds support for HP_TIMING_NOW if we build at least
> with -march=z10 -mzarch. Otherwise we are still using the
> generic hp-timing.h.
>
> Bye,
> Stefan
>
> ChangeLog:
>
> * sysdeps/s390/hp-timing.h: New file.
Committed
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] S390: Add support for HP_TIMING_NOW.
2019-09-10 9:13 [PATCH] S390: Add support for HP_TIMING_NOW Stefan Liebler
2019-09-18 14:16 ` Stefan Liebler
@ 2019-09-18 14:24 ` Adhemerval Zanella
2019-09-19 10:28 ` Stefan Liebler
1 sibling, 1 reply; 4+ messages in thread
From: Adhemerval Zanella @ 2019-09-18 14:24 UTC (permalink / raw)
To: libc-alpha
On 10/09/2019 06:13, Stefan Liebler wrote:
> +
> +#ifndef _HP_TIMING_H
> +
> +/* The stckf instruction is available starting with z9-109 zarch CPUs.
> + As there is no extra configure check for z9-109, the z10 one is used. */
> +#ifdef HAVE_S390_MIN_Z10_ZARCH_ASM_SUPPORT
> +# define _HP_TIMING_H 1
> +# include <hp-timing-common.h>
Wouldn't be simple to define _HP_TIMING_S390_H instead?
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] S390: Add support for HP_TIMING_NOW.
2019-09-18 14:24 ` Adhemerval Zanella
@ 2019-09-19 10:28 ` Stefan Liebler
0 siblings, 0 replies; 4+ messages in thread
From: Stefan Liebler @ 2019-09-19 10:28 UTC (permalink / raw)
To: libc-alpha
[-- Attachment #1: Type: text/plain, Size: 524 bytes --]
On 9/18/19 4:24 PM, Adhemerval Zanella wrote:
>
>
> On 10/09/2019 06:13, Stefan Liebler wrote:
>> +
>> +#ifndef _HP_TIMING_H
>> +
>> +/* The stckf instruction is available starting with z9-109 zarch CPUs.
>> + As there is no extra configure check for z9-109, the z10 one is used. */
>> +#ifdef HAVE_S390_MIN_Z10_ZARCH_ASM_SUPPORT
>> +# define _HP_TIMING_H 1
>> +# include <hp-timing-common.h>
>
> Wouldn't be simple to define _HP_TIMING_S390_H instead?
>
Sure. I've just committed the attached patch.
Thanks.
Stefan
[-- Attachment #2: 20190919_hptiming_fix.patch --]
[-- Type: text/x-patch, Size: 1069 bytes --]
commit ce89dc9649b789e85948d5da11145e34cafa2bcf
Author: Stefan Liebler <stli@linux.ibm.com>
Date: Thu Sep 19 11:17:20 2019 +0200
S390: Use _HP_TIMING_S390_H instead of _HP_TIMING_H.
Use macro _HP_TIMING_S390_H instead of _HP_TIMING_H
in s390 specific hp-timing.h
ChangeLog:
* sysdeps/s390/hp-timing.h (_HP_TIMING_H): Undefine.
(_HP_TIMING_S390_H): Define.
diff --git a/sysdeps/s390/hp-timing.h b/sysdeps/s390/hp-timing.h
index 793fb66a4d..c5c605c937 100644
--- a/sysdeps/s390/hp-timing.h
+++ b/sysdeps/s390/hp-timing.h
@@ -16,12 +16,12 @@
License along with the GNU C Library. If not, see
<https://www.gnu.org/licenses/>. */
-#ifndef _HP_TIMING_H
+#ifndef _HP_TIMING_S390_H
+#define _HP_TIMING_S390_H 1
/* The stckf instruction is available starting with z9-109 zarch CPUs.
As there is no extra configure check for z9-109, the z10 one is used. */
#ifdef HAVE_S390_MIN_Z10_ZARCH_ASM_SUPPORT
-# define _HP_TIMING_H 1
# include <hp-timing-common.h>
/* We use 64 bit values for the times.
^ permalink raw reply related [flat|nested] 4+ messages in thread
end of thread, other threads:[~2019-09-19 10:28 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-09-10 9:13 [PATCH] S390: Add support for HP_TIMING_NOW Stefan Liebler
2019-09-18 14:16 ` Stefan Liebler
2019-09-18 14:24 ` Adhemerval Zanella
2019-09-19 10:28 ` Stefan Liebler
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 read-only IMAP folder(s) and NNTP newsgroup(s).