Buildroot Archive on lore.kernel.org
 help / color / mirror / Atom feed
* [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
@ 2024-07-22 13:11 Woodrow Douglass via buildroot
  2024-07-22 13:41 ` Thomas Petazzoni via buildroot
  2024-07-22 14:30 ` Woodrow Douglass via buildroot
  0 siblings, 2 replies; 10+ messages in thread
From: Woodrow Douglass via buildroot @ 2024-07-22 13:11 UTC (permalink / raw)
  To: buildroot; +Cc: Woodrow Douglass

Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
---
 .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
 package/chicken/chicken.mk                    |  3 +-
 2 files changed, 31 insertions(+), 2 deletions(-)
 create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch

diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
new file mode 100644
index 0000000000..b93aaf9e21
--- /dev/null
+++ b/package/chicken/0001-xtensa-text-section-literals.patch
@@ -0,0 +1,30 @@
+From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
+From: Woodrow Douglass <wdouglass@carnegierobotics.com>
+Date: Mon, 22 Jul 2024 08:50:37 -0400
+Subject: [PATCH] Move literals into text section for xtensa architecture
+
+Upstream: https://bugs.call-cc.org/ticket/1840
+Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
+---
+ Makefile.linux | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/Makefile.linux b/Makefile.linux
+index b628cda4..e97c2b94 100644
+--- a/Makefile.linux
++++ b/Makefile.linux
+@@ -52,6 +52,11 @@ USES_SONAME = yes
+ 
+ # architectures
+ 
++ifeq ($(ARCH),xtensa)
++C_COMPILER_OPTIONS += -mtext-section-literals
++LINKER_OPTIONS += -mtext-section-literals
++endif
++
+ ifeq ($(ARCH),x32)
+ C_COMPILER_OPTIONS += -mx32
+ LINKER_OPTIONS += -mx32
+-- 
+2.39.2
+
diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
index 2667f7823d..8c7c1c4d8a 100644
--- a/package/chicken/chicken.mk
+++ b/package/chicken/chicken.mk
@@ -11,9 +11,8 @@ CHICKEN_LICENSE_FILES = LICENSE
 CHICKEN_CPE_ID_VENDOR = call-cc
 CHICKEN_INSTALL_STAGING = YES
 
-# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
 CHICKEN_MAKE_OPTS = \
-	ARCH=unused \
+	ARCH=$(BR2_NORMALIZED_ARCH) \
 	C_COMPILER="$(TARGET_CC)" \
 	CXX_COMPILER="$(TARGET_CXX)" \
 	PREFIX=/usr \
-- 
2.39.2

_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 13:11 [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture Woodrow Douglass via buildroot
@ 2024-07-22 13:41 ` Thomas Petazzoni via buildroot
  2024-07-22 14:30 ` Woodrow Douglass via buildroot
  1 sibling, 0 replies; 10+ messages in thread
From: Thomas Petazzoni via buildroot @ 2024-07-22 13:41 UTC (permalink / raw)
  To: Woodrow Douglass via buildroot; +Cc: Woodrow Douglass

Hello Woodrow,

On Mon, 22 Jul 2024 09:11:16 -0400
Woodrow Douglass via buildroot <buildroot@buildroot.org> wrote:

> Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>

Thanks for the patch. Would be good to have a non-empty commit message.

> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
>  CHICKEN_MAKE_OPTS = \
> -	ARCH=unused \
> +	ARCH=$(BR2_NORMALIZED_ARCH) \

Are you sure that all values of BR2_NORMALIZED_ARCH are supported by
the chicken build system? What happens when the value passed is unknown
to the chicken build system?

Best regards,

Thomas
-- 
Thomas Petazzoni, co-owner and CEO, Bootlin
Embedded Linux and Kernel engineering and training
https://bootlin.com
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 13:11 [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture Woodrow Douglass via buildroot
  2024-07-22 13:41 ` Thomas Petazzoni via buildroot
@ 2024-07-22 14:30 ` Woodrow Douglass via buildroot
  2024-07-22 14:57   ` Baruch Siach via buildroot
  2024-07-22 15:08   ` Woodrow Douglass via buildroot
  1 sibling, 2 replies; 10+ messages in thread
From: Woodrow Douglass via buildroot @ 2024-07-22 14:30 UTC (permalink / raw)
  To: buildroot; +Cc: Woodrow Douglass

This solves a build problem -- by default xtensa-gcc puts literals in a
different section of memory then the program text, and chicken is a very
literal-heavy program, so they don't all fit there. This avoids that problem.

Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
---
 .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
 package/chicken/chicken.mk                    | 14 +++++++--
 2 files changed, 42 insertions(+), 2 deletions(-)
 create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch

diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
new file mode 100644
index 0000000000..b93aaf9e21
--- /dev/null
+++ b/package/chicken/0001-xtensa-text-section-literals.patch
@@ -0,0 +1,30 @@
+From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
+From: Woodrow Douglass <wdouglass@carnegierobotics.com>
+Date: Mon, 22 Jul 2024 08:50:37 -0400
+Subject: [PATCH] Move literals into text section for xtensa architecture
+
+Upstream: https://bugs.call-cc.org/ticket/1840
+Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
+---
+ Makefile.linux | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/Makefile.linux b/Makefile.linux
+index b628cda4..e97c2b94 100644
+--- a/Makefile.linux
++++ b/Makefile.linux
+@@ -52,6 +52,11 @@ USES_SONAME = yes
+ 
+ # architectures
+ 
++ifeq ($(ARCH),xtensa)
++C_COMPILER_OPTIONS += -mtext-section-literals
++LINKER_OPTIONS += -mtext-section-literals
++endif
++
+ ifeq ($(ARCH),x32)
+ C_COMPILER_OPTIONS += -mx32
+ LINKER_OPTIONS += -mx32
+-- 
+2.39.2
+
diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
index 2667f7823d..d0e456f92a 100644
--- a/package/chicken/chicken.mk
+++ b/package/chicken/chicken.mk
@@ -11,9 +11,19 @@ CHICKEN_LICENSE_FILES = LICENSE
 CHICKEN_CPE_ID_VENDOR = call-cc
 CHICKEN_INSTALL_STAGING = YES
 
-# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
+#Chicken only uses the "arch" variable for some special-case compile arguments
+#If it's empty, it tries to detect the arch host
+#Handle some cases, but in most cases the normalized arch is fine here
+ifeq ($(BR2_NORMALIZED_ARCH),"i386")
+CHICKEN_ARCH="x32"
+else ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")
+CHICKEN_ARCH="x86-64"
+else
+CHICKEN_ARCH=$(BR2_NORMALIZED_ARCH)
+endif
+
 CHICKEN_MAKE_OPTS = \
-	ARCH=unused \
+	ARCH=$(CHICKEN_ARCH) \
 	C_COMPILER="$(TARGET_CC)" \
 	CXX_COMPILER="$(TARGET_CXX)" \
 	PREFIX=/usr \
-- 
2.39.2

_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 14:30 ` Woodrow Douglass via buildroot
@ 2024-07-22 14:57   ` Baruch Siach via buildroot
  2024-07-22 15:07     ` Woody Douglass via buildroot
  2024-07-22 15:08   ` Woodrow Douglass via buildroot
  1 sibling, 1 reply; 10+ messages in thread
From: Baruch Siach via buildroot @ 2024-07-22 14:57 UTC (permalink / raw)
  To: Woodrow Douglass via buildroot; +Cc: Woodrow Douglass

Hi Woodrow,

On Mon, Jul 22 2024, Woodrow Douglass via buildroot wrote:
> This solves a build problem -- by default xtensa-gcc puts literals in a
> different section of memory then the program text, and chicken is a very
> literal-heavy program, so they don't all fit there. This avoids that problem.
>
> Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
> ---
>  .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
>  package/chicken/chicken.mk                    | 14 +++++++--
>  2 files changed, 42 insertions(+), 2 deletions(-)
>  create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch
>
> diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
> new file mode 100644
> index 0000000000..b93aaf9e21
> --- /dev/null
> +++ b/package/chicken/0001-xtensa-text-section-literals.patch
> @@ -0,0 +1,30 @@
> +From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
> +From: Woodrow Douglass <wdouglass@carnegierobotics.com>
> +Date: Mon, 22 Jul 2024 08:50:37 -0400
> +Subject: [PATCH] Move literals into text section for xtensa architecture
> +
> +Upstream: https://bugs.call-cc.org/ticket/1840
> +Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
> +---
> + Makefile.linux | 5 +++++
> + 1 file changed, 5 insertions(+)
> +
> +diff --git a/Makefile.linux b/Makefile.linux
> +index b628cda4..e97c2b94 100644
> +--- a/Makefile.linux
> ++++ b/Makefile.linux
> +@@ -52,6 +52,11 @@ USES_SONAME = yes
> + 
> + # architectures
> + 
> ++ifeq ($(ARCH),xtensa)
> ++C_COMPILER_OPTIONS += -mtext-section-literals
> ++LINKER_OPTIONS += -mtext-section-literals
> ++endif
> ++
> + ifeq ($(ARCH),x32)
> + C_COMPILER_OPTIONS += -mx32
> + LINKER_OPTIONS += -mx32
> +-- 
> +2.39.2
> +
> diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
> index 2667f7823d..d0e456f92a 100644
> --- a/package/chicken/chicken.mk
> +++ b/package/chicken/chicken.mk
> @@ -11,9 +11,19 @@ CHICKEN_LICENSE_FILES = LICENSE
>  CHICKEN_CPE_ID_VENDOR = call-cc
>  CHICKEN_INSTALL_STAGING = YES
>  
> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
> +#Chicken only uses the "arch" variable for some special-case compile arguments
> +#If it's empty, it tries to detect the arch host
> +#Handle some cases, but in most cases the normalized arch is fine here
> +ifeq ($(BR2_NORMALIZED_ARCH),"i386")
> +CHICKEN_ARCH="x32"

Are you sure about that? x32 requires the 64-bit extension for x86
processors (https://en.wikipedia.org/wiki/X32_ABI). i386 is for 32-bit
capable processors.

baruch

> +else ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")
> +CHICKEN_ARCH="x86-64"
> +else
> +CHICKEN_ARCH=$(BR2_NORMALIZED_ARCH)
> +endif
> +
>  CHICKEN_MAKE_OPTS = \
> -	ARCH=unused \
> +	ARCH=$(CHICKEN_ARCH) \
>  	C_COMPILER="$(TARGET_CC)" \
>  	CXX_COMPILER="$(TARGET_CXX)" \
>  	PREFIX=/usr \

-- 
                                                     ~. .~   Tk Open Systems
=}------------------------------------------------ooO--U--Ooo------------{=
   - baruch@tkos.co.il - tel: +972.52.368.4656, http://www.tkos.co.il -
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 14:57   ` Baruch Siach via buildroot
@ 2024-07-22 15:07     ` Woody Douglass via buildroot
  0 siblings, 0 replies; 10+ messages in thread
From: Woody Douglass via buildroot @ 2024-07-22 15:07 UTC (permalink / raw)
  To: Baruch Siach, Woodrow Douglass via buildroot

Baruch,

Thank you for pointing this out! I incorrectly assumed this was a 
different spelling -- I'll revise and resubmit in a few minutes.

Thanks,
Woodrow Douglass

On 7/22/24 10:57, Baruch Siach wrote:
> CAUTION: This email originated from outside of the organization. Do not click links or open attachments unless you recognize the sender.
>
>
> Hi Woodrow,
>
> On Mon, Jul 22 2024, Woodrow Douglass via buildroot wrote:
>> This solves a build problem -- by default xtensa-gcc puts literals in a
>> different section of memory then the program text, and chicken is a very
>> literal-heavy program, so they don't all fit there. This avoids that problem.
>>
>> Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
>> ---
>>   .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
>>   package/chicken/chicken.mk                    | 14 +++++++--
>>   2 files changed, 42 insertions(+), 2 deletions(-)
>>   create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch
>>
>> diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
>> new file mode 100644
>> index 0000000000..b93aaf9e21
>> --- /dev/null
>> +++ b/package/chicken/0001-xtensa-text-section-literals.patch
>> @@ -0,0 +1,30 @@
>> +From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
>> +From: Woodrow Douglass <wdouglass@carnegierobotics.com>
>> +Date: Mon, 22 Jul 2024 08:50:37 -0400
>> +Subject: [PATCH] Move literals into text section for xtensa architecture
>> +
>> +Upstream: https://bugs.call-cc.org/ticket/1840
>> +Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
>> +---
>> + Makefile.linux | 5 +++++
>> + 1 file changed, 5 insertions(+)
>> +
>> +diff --git a/Makefile.linux b/Makefile.linux
>> +index b628cda4..e97c2b94 100644
>> +--- a/Makefile.linux
>> ++++ b/Makefile.linux
>> +@@ -52,6 +52,11 @@ USES_SONAME = yes
>> +
>> + # architectures
>> +
>> ++ifeq ($(ARCH),xtensa)
>> ++C_COMPILER_OPTIONS += -mtext-section-literals
>> ++LINKER_OPTIONS += -mtext-section-literals
>> ++endif
>> ++
>> + ifeq ($(ARCH),x32)
>> + C_COMPILER_OPTIONS += -mx32
>> + LINKER_OPTIONS += -mx32
>> +--
>> +2.39.2
>> +
>> diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
>> index 2667f7823d..d0e456f92a 100644
>> --- a/package/chicken/chicken.mk
>> +++ b/package/chicken/chicken.mk
>> @@ -11,9 +11,19 @@ CHICKEN_LICENSE_FILES = LICENSE
>>   CHICKEN_CPE_ID_VENDOR = call-cc
>>   CHICKEN_INSTALL_STAGING = YES
>>
>> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
>> +#Chicken only uses the "arch" variable for some special-case compile arguments
>> +#If it's empty, it tries to detect the arch host
>> +#Handle some cases, but in most cases the normalized arch is fine here
>> +ifeq ($(BR2_NORMALIZED_ARCH),"i386")
>> +CHICKEN_ARCH="x32"
> Are you sure about that? x32 requires the 64-bit extension for x86
> processors (https://en.wikipedia.org/wiki/X32_ABI). i386 is for 32-bit
> capable processors.
>
> baruch
>
>> +else ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")
>> +CHICKEN_ARCH="x86-64"
>> +else
>> +CHICKEN_ARCH=$(BR2_NORMALIZED_ARCH)
>> +endif
>> +
>>   CHICKEN_MAKE_OPTS = \
>> -     ARCH=unused \
>> +     ARCH=$(CHICKEN_ARCH) \
>>        C_COMPILER="$(TARGET_CC)" \
>>        CXX_COMPILER="$(TARGET_CXX)" \
>>        PREFIX=/usr \
> --
>                                                       ~. .~   Tk Open Systems
> =}------------------------------------------------ooO--U--Ooo------------{=
>     - baruch@tkos.co.il - tel: +972.52.368.4656, http://www.tkos.co.il -


_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 14:30 ` Woodrow Douglass via buildroot
  2024-07-22 14:57   ` Baruch Siach via buildroot
@ 2024-07-22 15:08   ` Woodrow Douglass via buildroot
  2024-07-22 16:15     ` Thomas Petazzoni via buildroot
  1 sibling, 1 reply; 10+ messages in thread
From: Woodrow Douglass via buildroot @ 2024-07-22 15:08 UTC (permalink / raw)
  To: buildroot; +Cc: Woodrow Douglass

This solves a build problem -- by default xtensa-gcc puts literals in a
different section of memory then the program text, and chicken is a very
literal-heavy program, so they don't all fit there. This avoids that problem.

Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
---
 .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
 package/chicken/chicken.mk                    | 12 ++++++--
 2 files changed, 40 insertions(+), 2 deletions(-)
 create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch

diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
new file mode 100644
index 0000000000..b93aaf9e21
--- /dev/null
+++ b/package/chicken/0001-xtensa-text-section-literals.patch
@@ -0,0 +1,30 @@
+From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
+From: Woodrow Douglass <wdouglass@carnegierobotics.com>
+Date: Mon, 22 Jul 2024 08:50:37 -0400
+Subject: [PATCH] Move literals into text section for xtensa architecture
+
+Upstream: https://bugs.call-cc.org/ticket/1840
+Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
+---
+ Makefile.linux | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/Makefile.linux b/Makefile.linux
+index b628cda4..e97c2b94 100644
+--- a/Makefile.linux
++++ b/Makefile.linux
+@@ -52,6 +52,11 @@ USES_SONAME = yes
+ 
+ # architectures
+ 
++ifeq ($(ARCH),xtensa)
++C_COMPILER_OPTIONS += -mtext-section-literals
++LINKER_OPTIONS += -mtext-section-literals
++endif
++
+ ifeq ($(ARCH),x32)
+ C_COMPILER_OPTIONS += -mx32
+ LINKER_OPTIONS += -mx32
+-- 
+2.39.2
+
diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
index 2667f7823d..3679a8afe2 100644
--- a/package/chicken/chicken.mk
+++ b/package/chicken/chicken.mk
@@ -11,9 +11,17 @@ CHICKEN_LICENSE_FILES = LICENSE
 CHICKEN_CPE_ID_VENDOR = call-cc
 CHICKEN_INSTALL_STAGING = YES
 
-# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
+#Chicken only uses the "arch" variable for some special-case compile arguments
+#If it's empty, it tries to detect the arch host
+#x86-64 is spelled differently, but in most cases the normalized arch is fine here
+ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")
+CHICKEN_ARCH="x86-64"
+else
+CHICKEN_ARCH=$(BR2_NORMALIZED_ARCH)
+endif
+
 CHICKEN_MAKE_OPTS = \
-	ARCH=unused \
+	ARCH=$(CHICKEN_ARCH) \
 	C_COMPILER="$(TARGET_CC)" \
 	CXX_COMPILER="$(TARGET_CXX)" \
 	PREFIX=/usr \
-- 
2.39.2

_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 15:08   ` Woodrow Douglass via buildroot
@ 2024-07-22 16:15     ` Thomas Petazzoni via buildroot
  2024-07-22 17:24       ` Woody Douglass via buildroot
  2024-07-22 17:31       ` Woodrow Douglass via buildroot
  0 siblings, 2 replies; 10+ messages in thread
From: Thomas Petazzoni via buildroot @ 2024-07-22 16:15 UTC (permalink / raw)
  To: Woodrow Douglass via buildroot; +Cc: Woodrow Douglass

Hello Woodrow,

On Mon, 22 Jul 2024 11:08:33 -0400
Woodrow Douglass via buildroot <buildroot@buildroot.org> wrote:

> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
> +#Chicken only uses the "arch" variable for some special-case compile arguments
> +#If it's empty, it tries to detect the arch host
> +#x86-64 is spelled differently, but in most cases the normalized arch is fine here

You did not reply to my e-mail on an earlier version in which I asked
some questions. I would prefer if we were not blindly passing
$(BR2_NORMALIZED_ARCH) here, can we instead handle only the cases for
which chicken does something specific based on ARCH=, and for all other
cases, pass ARCH=unused, as we used to do?

Thanks,

Thomas
-- 
Thomas Petazzoni, co-owner and CEO, Bootlin
Embedded Linux and Kernel engineering and training
https://bootlin.com
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 16:15     ` Thomas Petazzoni via buildroot
@ 2024-07-22 17:24       ` Woody Douglass via buildroot
  2024-07-22 17:31       ` Woodrow Douglass via buildroot
  1 sibling, 0 replies; 10+ messages in thread
From: Woody Douglass via buildroot @ 2024-07-22 17:24 UTC (permalink / raw)
  To: Thomas Petazzoni, Woodrow Douglass via buildroot

Thomas,

Sorry about that, i was replying with `git send-email`, and it didn't 
work the way that I expected. I'll update to filter back to `unused` and 
attempt to reply to this email.

Thank you for your patience, and all your work maintaining buildroot!
Woodrow Douglass

On 7/22/24 12:15, Thomas Petazzoni wrote:
> CAUTION: This email originated from outside of the organization. Do not click links or open attachments unless you recognize the sender.
>
>
> Hello Woodrow,
>
> On Mon, 22 Jul 2024 11:08:33 -0400
> Woodrow Douglass via buildroot <buildroot@buildroot.org> wrote:
>
>> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
>> +#Chicken only uses the "arch" variable for some special-case compile arguments
>> +#If it's empty, it tries to detect the arch host
>> +#x86-64 is spelled differently, but in most cases the normalized arch is fine here
> You did not reply to my e-mail on an earlier version in which I asked
> some questions. I would prefer if we were not blindly passing
> $(BR2_NORMALIZED_ARCH) here, can we instead handle only the cases for
> which chicken does something specific based on ARCH=, and for all other
> cases, pass ARCH=unused, as we used to do?
>
> Thanks,
>
> Thomas
> --
> Thomas Petazzoni, co-owner and CEO, Bootlin
> Embedded Linux and Kernel engineering and training
> https://bootlin.com


_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 16:15     ` Thomas Petazzoni via buildroot
  2024-07-22 17:24       ` Woody Douglass via buildroot
@ 2024-07-22 17:31       ` Woodrow Douglass via buildroot
  2024-08-02 17:10         ` Thomas Petazzoni via buildroot
  1 sibling, 1 reply; 10+ messages in thread
From: Woodrow Douglass via buildroot @ 2024-07-22 17:31 UTC (permalink / raw)
  To: buildroot; +Cc: Woodrow Douglass

This solves a build problem -- by default xtensa-gcc puts literals in a
different section of memory then the program text, and chicken is a very
literal-heavy program, so they don't all fit there. This avoids that problem.

Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
---
 .../0001-xtensa-text-section-literals.patch   | 30 +++++++++++++++++++
 package/chicken/chicken.mk                    | 14 +++++++--
 2 files changed, 42 insertions(+), 2 deletions(-)
 create mode 100644 package/chicken/0001-xtensa-text-section-literals.patch

diff --git a/package/chicken/0001-xtensa-text-section-literals.patch b/package/chicken/0001-xtensa-text-section-literals.patch
new file mode 100644
index 0000000000..b93aaf9e21
--- /dev/null
+++ b/package/chicken/0001-xtensa-text-section-literals.patch
@@ -0,0 +1,30 @@
+From e8d177f4d4e1c6bc41787ea1621e323ff4ad493e Mon Sep 17 00:00:00 2001
+From: Woodrow Douglass <wdouglass@carnegierobotics.com>
+Date: Mon, 22 Jul 2024 08:50:37 -0400
+Subject: [PATCH] Move literals into text section for xtensa architecture
+
+Upstream: https://bugs.call-cc.org/ticket/1840
+Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>
+---
+ Makefile.linux | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/Makefile.linux b/Makefile.linux
+index b628cda4..e97c2b94 100644
+--- a/Makefile.linux
++++ b/Makefile.linux
+@@ -52,6 +52,11 @@ USES_SONAME = yes
+ 
+ # architectures
+ 
++ifeq ($(ARCH),xtensa)
++C_COMPILER_OPTIONS += -mtext-section-literals
++LINKER_OPTIONS += -mtext-section-literals
++endif
++
+ ifeq ($(ARCH),x32)
+ C_COMPILER_OPTIONS += -mx32
+ LINKER_OPTIONS += -mx32
+-- 
+2.39.2
+
diff --git a/package/chicken/chicken.mk b/package/chicken/chicken.mk
index 2667f7823d..72d203b9bd 100644
--- a/package/chicken/chicken.mk
+++ b/package/chicken/chicken.mk
@@ -11,9 +11,19 @@ CHICKEN_LICENSE_FILES = LICENSE
 CHICKEN_CPE_ID_VENDOR = call-cc
 CHICKEN_INSTALL_STAGING = YES
 
-# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
+#Chicken only uses the "arch" variable for some special-case compile arguments
+#If it's empty, it tries to detect the arch host
+#Filter out values that have an effect, or pass "unused" here
+ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")
+CHICKEN_ARCH="x86-64"
+else ifeq ($(BR2_NORMALIZED_ARCH),"xtensa")
+CHICKEN_ARCH="xtensa"
+else
+CHICKEN_ARCH="unused"
+endif
+
 CHICKEN_MAKE_OPTS = \
-	ARCH=unused \
+	ARCH=$(CHICKEN_ARCH) \
 	C_COMPILER="$(TARGET_CC)" \
 	CXX_COMPILER="$(TARGET_CXX)" \
 	PREFIX=/usr \
-- 
2.39.2

_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

* Re: [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture
  2024-07-22 17:31       ` Woodrow Douglass via buildroot
@ 2024-08-02 17:10         ` Thomas Petazzoni via buildroot
  0 siblings, 0 replies; 10+ messages in thread
From: Thomas Petazzoni via buildroot @ 2024-08-02 17:10 UTC (permalink / raw)
  To: Woodrow Douglass via buildroot; +Cc: Woodrow Douglass

Hello Woodrow,

On Mon, 22 Jul 2024 13:31:36 -0400
Woodrow Douglass via buildroot <buildroot@buildroot.org> wrote:

> This solves a build problem -- by default xtensa-gcc puts literals in a
> different section of memory then the program text, and chicken is a very
> literal-heavy program, so they don't all fit there. This avoids that problem.
> 
> Signed-off-by: Woodrow Douglass <wdouglass@carnegierobotics.com>

Thanks, I have applied your patch, with a few fixes.

First, I've added a reference to an autobuilder failure fixed by this
patch, as follows:

"""
    Fixes:
    
      http://autobuild.buildroot.net/results/ce36170d67c4702f34bee025d8a46e5269c4573e/
  
"""

> -# If ARCH is not set, it attempts to autodiscover. But it is anyway not used.
> +#Chicken only uses the "arch" variable for some special-case compile arguments
> +#If it's empty, it tries to detect the arch host
> +#Filter out values that have an effect, or pass "unused" here

We always put a space after the # sign starting a comment.

> +ifeq ($(BR2_NORMALIZED_ARCH),"x86_64")

I've used $(NORMALIZED_ARCH) instead, which already has double quotes
stripped, so instead of "x86_64" we can use just x86_64.

> +CHICKEN_ARCH="x86-64"

Spaces around = sign, no double quotes around x86-64.

> +else ifeq ($(BR2_NORMALIZED_ARCH),"xtensa")
> +CHICKEN_ARCH="xtensa"
> +else
> +CHICKEN_ARCH="unused"
> +endif
> +
>  CHICKEN_MAKE_OPTS = \
> -	ARCH=unused \
> +	ARCH=$(CHICKEN_ARCH) \

and instead, used ARCH="$(CHICKEN_ARCH)" here

Thanks a lot!

Thomas
-- 
Thomas Petazzoni, co-owner and CEO, Bootlin
Embedded Linux and Kernel engineering and training
https://bootlin.com
_______________________________________________
buildroot mailing list
buildroot@buildroot.org
https://lists.buildroot.org/mailman/listinfo/buildroot

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

end of thread, other threads:[~2024-08-02 17:11 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-07-22 13:11 [Buildroot] [PATCH] package/chicken: move literals into text section for xtensa architecture Woodrow Douglass via buildroot
2024-07-22 13:41 ` Thomas Petazzoni via buildroot
2024-07-22 14:30 ` Woodrow Douglass via buildroot
2024-07-22 14:57   ` Baruch Siach via buildroot
2024-07-22 15:07     ` Woody Douglass via buildroot
2024-07-22 15:08   ` Woodrow Douglass via buildroot
2024-07-22 16:15     ` Thomas Petazzoni via buildroot
2024-07-22 17:24       ` Woody Douglass via buildroot
2024-07-22 17:31       ` Woodrow Douglass via buildroot
2024-08-02 17:10         ` Thomas Petazzoni via buildroot

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox