public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* [PATCH 1/4] Fix typo in config/sparc/sol2.h
  2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 2/4] Add a branch cost for SPARC T4 Sheldon Lobo
@ 2017-05-17 19:36 ` Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 4/4] Set function alignment for M7 to 8 bytes Sheldon Lobo
                   ` (2 subsequent siblings)
  4 siblings, 0 replies; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 19:36 UTC (permalink / raw)
  To: gcc-patches

	* config/sparc/sol2.h: Fix a ASM_CPU32_DEFAULT_SPEC typo.
---
 gcc/config/sparc/sol2.h |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gcc/config/sparc/sol2.h b/gcc/config/sparc/sol2.h
index db24ca3..8a50bfe 100644
--- a/gcc/config/sparc/sol2.h
+++ b/gcc/config/sparc/sol2.h
@@ -169,7 +169,7 @@ along with GCC; see the file COPYING3.  If not see
 #undef CPP_CPU64_DEFAULT_SPEC
 #define CPP_CPU64_DEFAULT_SPEC ""
 #undef ASM_CPU32_DEFAULT_SPEC
-#define ASM_CPU32_DEFAUILT_SPEC AS_SPARC32_FLAG AS_NIAGARA7_FLAG
+#define ASM_CPU32_DEFAULT_SPEC AS_SPARC32_FLAG AS_NIAGARA7_FLAG
 #undef ASM_CPU64_DEFAULT_SPEC
 #define ASM_CPU64_DEFAULT_SPEC AS_SPARC64_FLAG AS_NIAGARA7_FLAG
 #endif
-- 
1.7.1

^ permalink raw reply	[flat|nested] 12+ messages in thread

* [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions
@ 2017-05-17 19:36 Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 2/4] Add a branch cost for SPARC T4 Sheldon Lobo
                   ` (4 more replies)
  0 siblings, 5 replies; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 19:36 UTC (permalink / raw)
  To: gcc-patches

This patch series contains small fixes and updates for the SPARC 
platform.

Patch 1 fixes a small typo in sol2.h

Patch 2 sets a branch cost for the SPARC T4 processor.

Patch 3 sets a branch cost for the SPARC M7 processor.

Patch 4 changes the function alignment for the M7 processor from 4 to 8 bytes.

Thanks!

Sheldon Lobo (4):
  Fix typo in config/sparc/sol2.h
  Add a branch cost for SPARC T4.
  Add a branch cost for SPARC M7.
  Set function alignment for M7 to 8 bytes.

 gcc/config/sparc/sol2.h                         |    2 +-
 gcc/config/sparc/sparc.c                        |   13 ++++++++-----
 gcc/config/sparc/sparc.h                        |   11 +++++++++--
 gcc/testsuite/gcc.target/sparc/niagara7-align.c |    4 ++++
 4 files changed, 22 insertions(+), 8 deletions(-)
 create mode 100644 gcc/testsuite/gcc.target/sparc/niagara7-align.c

^ permalink raw reply	[flat|nested] 12+ messages in thread

* [PATCH 2/4] Add a branch cost for SPARC T4.
  2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
@ 2017-05-17 19:36 ` Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 1/4] Fix typo in config/sparc/sol2.h Sheldon Lobo
                   ` (3 subsequent siblings)
  4 siblings, 0 replies; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 19:36 UTC (permalink / raw)
  To: gcc-patches

	* config/sparc/sparc.h (BRANCH_COST): Set the SPARC T4 branch
	latency to 2.
---
 gcc/config/sparc/sparc.h |    8 ++++++--
 1 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/gcc/config/sparc/sparc.h b/gcc/config/sparc/sparc.h
index 590a5f4..6277738 100644
--- a/gcc/config/sparc/sparc.h
+++ b/gcc/config/sparc/sparc.h
@@ -1566,7 +1566,9 @@ do {									   \
    and annulled branches insert 4 bubbles.
 
    On Niagara-2 and Niagara-3, a not-taken branch costs 1 cycle whereas
-   a taken branch costs 6 cycles.  */
+   a taken branch costs 6 cycles.
+
+   The T4 Supplement specifies the branch latency at 2 cycles. */
 
 #define BRANCH_COST(speed_p, predictable_p) \
 	((sparc_cpu == PROCESSOR_V9 \
@@ -1579,7 +1581,9 @@ do {									   \
 	 : ((sparc_cpu == PROCESSOR_NIAGARA2 \
 	     || sparc_cpu == PROCESSOR_NIAGARA3) \
 	    ? 5 \
-	 : 3))))
+	 : (sparc_cpu == PROCESSOR_NIAGARA4 \
+	    ? 2 \
+	 : 3)))))
 \f
 /* Control the assembler format that we output.  */
 
-- 
1.7.1

^ permalink raw reply	[flat|nested] 12+ messages in thread

* [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 2/4] Add a branch cost for SPARC T4 Sheldon Lobo
  2017-05-17 19:36 ` [PATCH 1/4] Fix typo in config/sparc/sol2.h Sheldon Lobo
@ 2017-05-17 19:36 ` Sheldon Lobo
  2017-05-17 20:16   ` Eric Botcazou
  2017-05-17 20:10 ` [PATCH 3/4] Add a branch cost for SPARC M7 Sheldon Lobo
  2017-05-17 20:11 ` [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Eric Botcazou
  4 siblings, 1 reply; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 19:36 UTC (permalink / raw)
  To: gcc-patches

	* config/sparc/sparc.c (sparc_option_override): Set function
	alignment for -mcpu=niagara7 to 64 to match the I$ line.
	* testsuite/gcc.target/sparc/niagara7-align.c: Test case with
	-mcpu=niagara7 -falign-functions.
---
 gcc/config/sparc/sparc.c                        |   13 ++++++++-----
 gcc/testsuite/gcc.target/sparc/niagara7-align.c |    4 ++++
 2 files changed, 12 insertions(+), 5 deletions(-)
 create mode 100644 gcc/testsuite/gcc.target/sparc/niagara7-align.c

diff --git a/gcc/config/sparc/sparc.c b/gcc/config/sparc/sparc.c
index 8277496..6dfb269 100644
--- a/gcc/config/sparc/sparc.c
+++ b/gcc/config/sparc/sparc.c
@@ -1528,15 +1528,18 @@ sparc_option_override (void)
     target_flags |= MASK_LRA;
 
   /* Supply a default value for align_functions.  */
-  if (align_functions == 0
-      && (sparc_cpu == PROCESSOR_ULTRASPARC
+  if (align_functions == 0)
+    {
+      if (sparc_cpu == PROCESSOR_ULTRASPARC
 	  || sparc_cpu == PROCESSOR_ULTRASPARC3
 	  || sparc_cpu == PROCESSOR_NIAGARA
 	  || sparc_cpu == PROCESSOR_NIAGARA2
 	  || sparc_cpu == PROCESSOR_NIAGARA3
-	  || sparc_cpu == PROCESSOR_NIAGARA4
-	  || sparc_cpu == PROCESSOR_NIAGARA7))
-    align_functions = 32;
+	  || sparc_cpu == PROCESSOR_NIAGARA4)
+	align_functions = 32;
+      else if (sparc_cpu == PROCESSOR_NIAGARA7)
+	align_functions = 64;
+    }
 
   /* Validate PCC_STRUCT_RETURN.  */
   if (flag_pcc_struct_return == DEFAULT_PCC_STRUCT_RETURN)
diff --git a/gcc/testsuite/gcc.target/sparc/niagara7-align.c b/gcc/testsuite/gcc.target/sparc/niagara7-align.c
new file mode 100644
index 0000000..a46aac1
--- /dev/null
+++ b/gcc/testsuite/gcc.target/sparc/niagara7-align.c
@@ -0,0 +1,4 @@
+/* { dg-do compile } */
+/* { dg-options "-falign-functions -mcpu=niagara7" } */
+/* { dg-final { scan-assembler "\.align 64" } } */
+void foo(void) {}
-- 
1.7.1

^ permalink raw reply	[flat|nested] 12+ messages in thread

* [PATCH 3/4] Add a branch cost for SPARC M7.
  2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
                   ` (2 preceding siblings ...)
  2017-05-17 19:36 ` [PATCH 4/4] Set function alignment for M7 to 8 bytes Sheldon Lobo
@ 2017-05-17 20:10 ` Sheldon Lobo
  2017-05-17 20:11 ` [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Eric Botcazou
  4 siblings, 0 replies; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 20:10 UTC (permalink / raw)
  To: gcc-patches

	* config/sparc/sparc.h (BRANCH_COST): Set the SPARC M7 branch
	latency to 1.
---
 gcc/config/sparc/sparc.h |    7 +++++--
 1 files changed, 5 insertions(+), 2 deletions(-)

diff --git a/gcc/config/sparc/sparc.h b/gcc/config/sparc/sparc.h
index 6277738..686a3d5 100644
--- a/gcc/config/sparc/sparc.h
+++ b/gcc/config/sparc/sparc.h
@@ -1568,7 +1568,8 @@ do {									   \
    On Niagara-2 and Niagara-3, a not-taken branch costs 1 cycle whereas
    a taken branch costs 6 cycles.
 
-   The T4 Supplement specifies the branch latency at 2 cycles. */
+   The T4 Supplement specifies the branch latency at 2 cycles.
+   The M7 Supplement specifies the branch latency at 1 cycle. */
 
 #define BRANCH_COST(speed_p, predictable_p) \
 	((sparc_cpu == PROCESSOR_V9 \
@@ -1583,7 +1584,9 @@ do {									   \
 	    ? 5 \
 	 : (sparc_cpu == PROCESSOR_NIAGARA4 \
 	    ? 2 \
-	 : 3)))))
+	 : (sparc_cpu == PROCESSOR_NIAGARA7 \
+	    ? 1 \
+	 : 3))))))
 \f
 /* Control the assembler format that we output.  */
 
-- 
1.7.1

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions
  2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
                   ` (3 preceding siblings ...)
  2017-05-17 20:10 ` [PATCH 3/4] Add a branch cost for SPARC M7 Sheldon Lobo
@ 2017-05-17 20:11 ` Eric Botcazou
  4 siblings, 0 replies; 12+ messages in thread
From: Eric Botcazou @ 2017-05-17 20:11 UTC (permalink / raw)
  To: Sheldon Lobo; +Cc: gcc-patches

> This patch series contains small fixes and updates for the SPARC
> platform.
> 
> Patch 1 fixes a small typo in sol2.h
> 
> Patch 2 sets a branch cost for the SPARC T4 processor.
> 
> Patch 3 sets a branch cost for the SPARC M7 processor.
> 
> Patch 4 changes the function alignment for the M7 processor from 4 to 8
> bytes.

Thanks, the whole series looks good to me and can probably be applied to every 
branch supporting the M7 processor.

Do you plan to contribute more patches?  If so, are you interested in having 
write access to the repository?  In that case, you can request it by means of 
the form linked to from https://gcc.gnu.org/svnwrite.html with me as sponsor.

-- 
Eric Botcazou

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-17 19:36 ` [PATCH 4/4] Set function alignment for M7 to 8 bytes Sheldon Lobo
@ 2017-05-17 20:16   ` Eric Botcazou
  2017-05-17 20:56     ` Sheldon Lobo
  0 siblings, 1 reply; 12+ messages in thread
From: Eric Botcazou @ 2017-05-17 20:16 UTC (permalink / raw)
  To: Sheldon Lobo; +Cc: gcc-patches

> 	* config/sparc/sparc.c (sparc_option_override): Set function
> 	alignment for -mcpu=niagara7 to 64 to match the I$ line.
> 	* testsuite/gcc.target/sparc/niagara7-align.c: Test case with
> 	-mcpu=niagara7 -falign-functions.

The testsuite directory has its own ChangeLog file so the second item must go 
there without the testsuite/ prefix (and "New test" is enough in this case):

	* gcc.target/sparc/niagara7-align.c: New test.

-- 
Eric Botcazou

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-17 20:16   ` Eric Botcazou
@ 2017-05-17 20:56     ` Sheldon Lobo
  2017-05-19 18:47       ` Eric Botcazou
  0 siblings, 1 reply; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-17 20:56 UTC (permalink / raw)
  To: Eric Botcazou; +Cc: gcc-patches


On 05/17/2017 04:11 PM, Eric Botcazou wrote:
>> 	* config/sparc/sparc.c (sparc_option_override): Set function
>> 	alignment for -mcpu=niagara7 to 64 to match the I$ line.
>> 	* testsuite/gcc.target/sparc/niagara7-align.c: Test case with
>> 	-mcpu=niagara7 -falign-functions.
>
> The testsuite directory has its own ChangeLog file so the second item must go
> there without the testsuite/ prefix (and "New test" is enough in this case):
>
> 	* gcc.target/sparc/niagara7-align.c: New test.
>

Thanks for the feedback!

Just so I am clear, gcc/testsuite/ChangeLog needs to be
checked into the patch (but gcc/ChangeLog is not)?

Sorry for the newbie question,
Sheldon

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-17 20:56     ` Sheldon Lobo
@ 2017-05-19 18:47       ` Eric Botcazou
  2017-05-19 18:53         ` Eric Botcazou
  2017-05-19 19:07         ` Sheldon Lobo
  0 siblings, 2 replies; 12+ messages in thread
From: Eric Botcazou @ 2017-05-19 18:47 UTC (permalink / raw)
  To: Sheldon Lobo; +Cc: gcc-patches

> Just so I am clear, gcc/testsuite/ChangeLog needs to be
> checked into the patch (but gcc/ChangeLog is not)?

This 4/4 commit needs to contain gcc/config/sparc/sparc.c, gcc/ChangeLog, 
gcc/testsuite/gcc.target/sparc/niagara7-align.c and gcc/testsuite/ChangeLog.

The rule is that you put the ChangeLog entry into the ChangeLog file of the 
directory where the change is made, or that of the parent directory if there 
is none, recursively.  The filename in that ChangeLog file must be relative to 
the directory when the ChangeLog file is.

-- 
Eric Botcazou

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-19 18:47       ` Eric Botcazou
@ 2017-05-19 18:53         ` Eric Botcazou
  2017-05-19 19:07         ` Sheldon Lobo
  1 sibling, 0 replies; 12+ messages in thread
From: Eric Botcazou @ 2017-05-19 18:53 UTC (permalink / raw)
  To: Sheldon Lobo; +Cc: gcc-patches

> The rule is that you put the ChangeLog entry into the ChangeLog file of the
> directory where the change is made, or that of the parent directory if there
> is none, recursively.  The filename in that ChangeLog file must be relative
> to the directory when the ChangeLog file is.

...where...

-- 
Eric Botcazou

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-19 18:47       ` Eric Botcazou
  2017-05-19 18:53         ` Eric Botcazou
@ 2017-05-19 19:07         ` Sheldon Lobo
  2017-05-22  7:11           ` Eric Botcazou
  1 sibling, 1 reply; 12+ messages in thread
From: Sheldon Lobo @ 2017-05-19 19:07 UTC (permalink / raw)
  To: Eric Botcazou; +Cc: gcc-patches


On 05/19/2017 02:45 PM, Eric Botcazou wrote:
>
> This 4/4 commit needs to contain gcc/config/sparc/sparc.c, gcc/ChangeLog,
> gcc/testsuite/gcc.target/sparc/niagara7-align.c and gcc/testsuite/ChangeLog.
>
> The rule is that you put the ChangeLog entry into the ChangeLog file of the
> directory where the change is made, or that of the parent directory if there
> is none, recursively.  The filename in that ChangeLog file must be relative to
> the directory when the ChangeLog file is.
>

Thanks, Eric. I did do that when I went ahead with the
'svn commit' yesterday. That is, gcc/ChangeLog and
gcc/testsuite/ChangeLog have the correct information.

The gcc source tree is as desired, but I may have made
2 inadvertent process mistakes:
* did not send a revised PATCH to gcc-patches
* made the 4 changes with 1 commit

Apologies,
Sheldon

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: [PATCH 4/4] Set function alignment for M7 to 8 bytes.
  2017-05-19 19:07         ` Sheldon Lobo
@ 2017-05-22  7:11           ` Eric Botcazou
  0 siblings, 0 replies; 12+ messages in thread
From: Eric Botcazou @ 2017-05-22  7:11 UTC (permalink / raw)
  To: Sheldon Lobo; +Cc: gcc-patches

> The gcc source tree is as desired, but I may have made
> 2 inadvertent process mistakes:
> * did not send a revised PATCH to gcc-patches

That's OK since only a minor correction was requested.

> * made the 4 changes with 1 commit

That's as expected.

-- 
Eric Botcazou

^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2017-05-22  6:07 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-05-17 19:36 [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Sheldon Lobo
2017-05-17 19:36 ` [PATCH 2/4] Add a branch cost for SPARC T4 Sheldon Lobo
2017-05-17 19:36 ` [PATCH 1/4] Fix typo in config/sparc/sol2.h Sheldon Lobo
2017-05-17 19:36 ` [PATCH 4/4] Set function alignment for M7 to 8 bytes Sheldon Lobo
2017-05-17 20:16   ` Eric Botcazou
2017-05-17 20:56     ` Sheldon Lobo
2017-05-19 18:47       ` Eric Botcazou
2017-05-19 18:53         ` Eric Botcazou
2017-05-19 19:07         ` Sheldon Lobo
2017-05-22  7:11           ` Eric Botcazou
2017-05-17 20:10 ` [PATCH 3/4] Add a branch cost for SPARC M7 Sheldon Lobo
2017-05-17 20:11 ` [PATCH 0/4] Minor SPARC T4 and M7 fixes and additions Eric Botcazou

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).