unofficial mirror of libc-alpha@sourceware.org
 help / color / mirror / Atom feed
* [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).