summaryrefslogtreecommitdiffstats
path: root/bsps
diff options
context:
space:
mode:
authorJoel Sherrill <joel@rtems.org>2021-05-21 16:29:42 -0500
committerJoel Sherrill <joel@rtems.org>2021-05-25 08:33:04 -0500
commit402a206a1b1ff984b14c3321f0bc1340c4873147 (patch)
tree29754efd673069c0a235bbea81262df708414709 /bsps
parentppc-irq-legacy.c: Use rtems_malloc() instead of malloc(). (diff)
downloadrtems-402a206a1b1ff984b14c3321f0bc1340c4873147.tar.bz2
powerpc/.../sbrk.c: Do not reference errno.
Closes #4r37.
Diffstat (limited to 'bsps')
-rw-r--r--bsps/powerpc/shared/start/sbrk.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/bsps/powerpc/shared/start/sbrk.c b/bsps/powerpc/shared/start/sbrk.c
index 95104ba9c8..d7507b3997 100644
--- a/bsps/powerpc/shared/start/sbrk.c
+++ b/bsps/powerpc/shared/start/sbrk.c
@@ -150,9 +150,19 @@ void *sbrk(ptrdiff_t incr)
remaining_size-=incr;
rval = (void *) remaining_start;
remaining_start += incr;
- } else {
- errno = ENOMEM;
}
+
+ /*
+ * sbrk() is a Legacy POSIX method which means it is no longer part of the
+ * POSIX standard. Historically, it was required to set errno to ENOMEM if
+ * the extension failed. This implementation does not do that for two
+ * reasons. First, this method is only called from the RTEMS malloc()
+ * implementation and does not expect errno to be set when -1 is returned.
+ * Second, setting errno implicitly pulls in some of the newlib reentrancy
+ * support. Not setting errno avoids this method forcing that support
+ * into every application for every BSP that uses this method.
+ */
+
#ifdef DEBUG
printk("************* SBRK 0x%08x (ret 0x%08x) **********\n", incr, rval);
#endif