From: Tom Rini Date: Fri, 10 Nov 2023 16:55:28 +0000 (-0500) Subject: Merge branch '2023-11-10-improve-semihosting-armv6' into next X-Git-Tag: v2025.01-rc5-pxa1908~582^2~34 X-Git-Url: http://git.dujemihanovic.xyz/html/static/%7B%7B%20%24.Site.BaseURL%20%7D%7Dposts/%7B%7B%20%24.Site.BaseURL%20%7D%7Dposts/index.xml?a=commitdiff_plain;h=3b6db6901ff5babbb9d21f0fca750996e29d85e0;p=u-boot.git Merge branch '2023-11-10-improve-semihosting-armv6' into next To quote the author: This series has a few fixes for semihosting on ARMv6 and older CPUs. The first two patches address problems regarding the stack pointer and link register. U-Boot runs in supervisor mode, so taking a software interrupt will clobber sp/lr. I think we really should run in system mode, since it has separate sp/lr registers. To quote ARM DDI 0100I: > The remaining mode is System mode, which is not entered by any > exception and has exactly the same registers available as User mode. > However, it is a privileged mode and is therefore not subject to the > User mode restrictions. It is intended for use by operating system > tasks that need access to system resources, but wish to avoid using > the additional registers associated with the exception modes. Avoiding > such use ensures that the task state is not corrupted by the > occurrence of any exception. However, the processor mode has been supervisor for such a long time (since relocation got introduced) that I would rather not touch it. --- 3b6db6901ff5babbb9d21f0fca750996e29d85e0