diff --git a/recipes/bash/10309-parse.y-fix-compilation-for-non-multibyte-builds.patch b/recipes/bash/10309-parse.y-fix-compilation-for-non-multibyte-builds.patch
deleted file mode 100644
index 1d1f28d40e0db2c11577514c28a544f21bcd3150..0000000000000000000000000000000000000000
--- a/recipes/bash/10309-parse.y-fix-compilation-for-non-multibyte-builds.patch
+++ /dev/null
@@ -1,62 +0,0 @@
-From 0217fc2816e47ee296472df71d1011f0eb2937e6 Mon Sep 17 00:00:00 2001
-From: Vincent Fazio <vfazio@gmail.com>
-Date: Fri, 27 Jan 2023 14:37:26 -0600
-Subject: [PATCH] parse.y: fix compilation for non-multibyte builds
-
-Builds configured with --disable-multibyte or when the toolchain does
-not have WCHAR support would encounter a compile error due to an
-undeclared reference to shell_input_line_property in shell_getc.
-
-Add a HANDLE_MULTIBYTE guard to conditionally compile the block that
-references shell_input_line_property in shell_getc as it's only declared
-when HANDLE_MULTIBYTE is defined.
-
-Signed-off-by: Vincent Fazio <vfazio@gmail.com>
----
- parse.y | 2 ++
- y.tab.c | 2 ++
- 2 files changed, 4 insertions(+)
-
-diff --git a/parse.y b/parse.y
-index 1d12e639..8f1355c6 100644
---- a/parse.y
-+++ b/parse.y
-@@ -2625,6 +2625,7 @@ next_alias_char:
-       parser_state |= PST_ENDALIAS;
-       /* We need to do this to make sure last_shell_getc_is_singlebyte returns
- 	 true, since we are returning a single-byte space. */
-+#if defined (HANDLE_MULTIBYTE)
-       if (shell_input_line_index == shell_input_line_len && last_shell_getc_is_singlebyte == 0)
- 	{
- #if 0
-@@ -2638,6 +2639,7 @@ next_alias_char:
- 	  shell_input_line_property[shell_input_line_index - 1] = 1;
- #endif
- 	}
-+#endif /* HANDLE_MULTIBYTE */
-       return ' ';	/* END_ALIAS */
-     }
- #endif
-diff --git a/y.tab.c b/y.tab.c
-index 50c5845b..799f730f 100644
---- a/y.tab.c
-+++ b/y.tab.c
-@@ -4936,6 +4936,7 @@ next_alias_char:
-       parser_state |= PST_ENDALIAS;
-       /* We need to do this to make sure last_shell_getc_is_singlebyte returns
- 	 true, since we are returning a single-byte space. */
-+#if defined (HANDLE_MULTIBYTE)
-       if (shell_input_line_index == shell_input_line_len && last_shell_getc_is_singlebyte == 0)
- 	{
- #if 0
-@@ -4949,6 +4950,7 @@ next_alias_char:
- 	  shell_input_line_property[shell_input_line_index - 1] = 1;
- #endif
- 	}
-+#endif /* HANDLE_MULTIBYTE */
-       return ' ';	/* END_ALIAS */
-     }
- #endif
--- 
-2.25.1
-
diff --git a/recipes/bash/recipe.toml b/recipes/bash/recipe.toml
index d5ca540d84873bf9a9eaf0d3d3d8fd0d137fb2d8..06a56482d7ac0e6ec0e97b43edc9db10d45a3e4d 100644
--- a/recipes/bash/recipe.toml
+++ b/recipes/bash/recipe.toml
@@ -2,8 +2,7 @@
 tar = "http://ftp.gnu.org/gnu/bash/bash-5.2.15.tar.gz"
 blake3 = "c1548e3f2a9b6de5296e18c28b3d2007985e647273e03f039efd3e489edaa41f"
 patches = [
-    "redox.patch",
-    "10309-parse.y-fix-compilation-for-non-multibyte-builds.patch",
+    "redox.patch"
 ]
 
 [build]
diff --git a/recipes/bash/redox.patch b/recipes/bash/redox.patch
index 3466700f91912043af06f15d516d7718715f6c13..ff7ac1c83586a3d9c918eacd1c6f9714b7e8fcfe 100644
--- a/recipes/bash/redox.patch
+++ b/recipes/bash/redox.patch
@@ -1,6 +1,6 @@
 diff -ruwN bash-5.2.15/bashline.c source/bashline.c
 --- bash-5.2.15/bashline.c	2022-04-17 16:37:12.000000000 -0600
-+++ source/bashline.c	2023-09-09 07:52:41.177719614 -0600
++++ source/bashline.c	2023-09-09 09:07:14.698070413 -0600
 @@ -2645,7 +2645,7 @@
       const char *text;
       int state;
@@ -12,7 +12,7 @@ diff -ruwN bash-5.2.15/bashline.c source/bashline.c
    static char *gname = (char *)NULL;
 diff -ruwN bash-5.2.15/builtins/ulimit.def source/builtins/ulimit.def
 --- bash-5.2.15/builtins/ulimit.def	2021-11-05 07:19:53.000000000 -0600
-+++ source/builtins/ulimit.def	2023-09-09 07:52:41.177719614 -0600
++++ source/builtins/ulimit.def	2023-09-09 09:07:14.698070413 -0600
 @@ -609,7 +609,7 @@
        }
    else
@@ -24,7 +24,7 @@ diff -ruwN bash-5.2.15/builtins/ulimit.def source/builtins/ulimit.def
  #  if defined (HPUX9)
 diff -ruwN bash-5.2.15/config-top.h source/config-top.h
 --- bash-5.2.15/config-top.h	2021-11-05 07:11:12.000000000 -0600
-+++ source/config-top.h	2023-09-09 07:52:41.177719614 -0600
++++ source/config-top.h	2023-09-09 09:07:14.698070413 -0600
 @@ -63,24 +63,24 @@
  /* The default value of the PATH variable. */
  #ifndef DEFAULT_PATH_VALUE
@@ -56,7 +56,7 @@ diff -ruwN bash-5.2.15/config-top.h source/config-top.h
  /* Default primary and secondary prompt strings. */
 diff -ruwN bash-5.2.15/configure source/configure
 --- bash-5.2.15/configure	2022-09-23 08:13:22.000000000 -0600
-+++ source/configure	2023-09-09 07:55:01.365878738 -0600
++++ source/configure	2023-09-09 09:07:14.702070414 -0600
 @@ -3298,6 +3298,7 @@
  *-nsk*)		opt_bash_malloc=no ;;	# HP NonStop
  *-haiku*)	opt_bash_malloc=no ;;	# Haiku OS
@@ -67,7 +67,7 @@ diff -ruwN bash-5.2.15/configure source/configure
  # memory scrambling on free()
 diff -ruwN bash-5.2.15/configure.ac source/configure.ac
 --- bash-5.2.15/configure.ac	2022-09-23 08:12:27.000000000 -0600
-+++ source/configure.ac	2023-09-09 07:52:41.177719614 -0600
++++ source/configure.ac	2023-09-09 09:07:14.702070414 -0600
 @@ -92,6 +92,7 @@
  *-nsk*)		opt_bash_malloc=no ;;	# HP NonStop
  *-haiku*)	opt_bash_malloc=no ;;	# Haiku OS
@@ -78,7 +78,7 @@ diff -ruwN bash-5.2.15/configure.ac source/configure.ac
  # memory scrambling on free()
 diff -ruwN bash-5.2.15/execute_cmd.c source/execute_cmd.c
 --- bash-5.2.15/execute_cmd.c	2022-12-13 10:09:02.000000000 -0700
-+++ source/execute_cmd.c	2023-09-09 08:04:16.779201158 -0600
++++ source/execute_cmd.c	2023-09-09 09:07:14.702070414 -0600
 @@ -1379,11 +1379,11 @@
    nullcmd = (command == 0) || (command->type == cm_simple && command->value.Simple->words == 0 && command->value.Simple->redirects == 0);
    if (posixly_correct && nullcmd)
@@ -95,7 +95,7 @@ diff -ruwN bash-5.2.15/execute_cmd.c source/execute_cmd.c
  #endif
 diff -ruwN bash-5.2.15/general.c source/general.c
 --- bash-5.2.15/general.c	2022-11-23 15:10:12.000000000 -0700
-+++ source/general.c	2023-09-09 07:52:41.177719614 -0600
++++ source/general.c	2023-09-09 09:07:14.702070414 -0600
 @@ -589,6 +589,7 @@
  void
  check_dev_tty ()
@@ -127,7 +127,7 @@ diff -ruwN bash-5.2.15/general.c source/general.c
    *p_index = i;
 diff -ruwN bash-5.2.15/include/posixwait.h source/include/posixwait.h
 --- bash-5.2.15/include/posixwait.h	2019-03-29 11:25:52.000000000 -0600
-+++ source/include/posixwait.h	2023-09-09 07:52:41.177719614 -0600
++++ source/include/posixwait.h	2023-09-09 09:07:14.702070414 -0600
 @@ -34,7 +34,7 @@
  
  /* How to get the status of a job.  For Posix, this is just an
@@ -146,9 +146,33 @@ diff -ruwN bash-5.2.15/include/posixwait.h source/include/posixwait.h
  
  #  if !defined (WSTOPSIG)
  #    define WSTOPSIG(s)       ((s) >> 8)
+diff -ruwN bash-5.2.15/lib/readline/input.c source/lib/readline/input.c
+--- bash-5.2.15/lib/readline/input.c	2022-04-08 13:43:24.000000000 -0600
++++ source/lib/readline/input.c	2023-09-09 09:07:14.702070414 -0600
+@@ -805,7 +805,7 @@
+   int result;
+   unsigned char c;
+   int fd;
+-#if defined (HAVE_PSELECT)
++#if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
+   sigset_t empty_set;
+   fd_set readfds;
+ #endif
+diff -ruwN bash-5.2.15/lib/readline/terminal.c source/lib/readline/terminal.c
+--- bash-5.2.15/lib/readline/terminal.c	2022-04-05 08:44:17.000000000 -0600
++++ source/lib/readline/terminal.c	2023-09-09 09:09:03.162131539 -0600
+@@ -102,7 +102,7 @@
+ 
+ static int tcap_initialized;
+ 
+-#if !defined (__linux__) && !defined (NCURSES_VERSION)
++#if !defined (__linux__) && !defined (NCURSES_VERSION) && !defined (__redox__)
+ #  if defined (__EMX__) || defined (NEED_EXTERN_PC)
+ extern 
+ #  endif /* __EMX__ || NEED_EXTERN_PC */
 diff -ruwN bash-5.2.15/lib/sh/getcwd.c source/lib/sh/getcwd.c
 --- bash-5.2.15/lib/sh/getcwd.c	2012-03-10 08:48:50.000000000 -0700
-+++ source/lib/sh/getcwd.c	2023-09-09 07:52:41.177719614 -0600
++++ source/lib/sh/getcwd.c	2023-09-09 09:07:14.702070414 -0600
 @@ -20,7 +20,7 @@
  
  #include <config.h>
@@ -158,3 +182,74 @@ diff -ruwN bash-5.2.15/lib/sh/getcwd.c source/lib/sh/getcwd.c
  
  #if !defined (__GNUC__) && !defined (HAVE_ALLOCA_H) && defined (_AIX)
    #pragma alloca
+diff -ruwN bash-5.2.15/lib/sh/input_avail.c source/lib/sh/input_avail.c
+--- bash-5.2.15/lib/sh/input_avail.c	2021-05-24 09:16:33.000000000 -0600
++++ source/lib/sh/input_avail.c	2023-09-09 09:07:14.702070414 -0600
+@@ -33,7 +33,7 @@
+ #  include <sys/file.h>
+ #endif /* HAVE_SYS_FILE_H */
+ 
+-#if defined (HAVE_PSELECT)
++#if defined (HAVE_PSELECT) || defined (HAVE_SELECT)
+ #  include <signal.h>
+ #endif
+ 
+diff -ruwN bash-5.2.15/lib/sh/strtoimax.c source/lib/sh/strtoimax.c
+--- bash-5.2.15/lib/sh/strtoimax.c	2021-09-10 08:32:35.000000000 -0600
++++ source/lib/sh/strtoimax.c	2023-09-09 09:10:21.618185121 -0600
+@@ -55,6 +55,8 @@
+ extern long long strtoll PARAMS((const char *, char **, int));
+ #endif
+ 
++#if !defined (__redox__)
++
+ #ifdef strtoimax
+ #undef strtoimax
+ #endif
+@@ -79,6 +81,8 @@
+   return (strtol (ptr, endptr, base));
+ }
+ 
++#endif
++
+ #ifdef TESTING
+ # include <stdio.h>
+ int
+diff -ruwN bash-5.2.15/parse.y source/parse.y
+--- bash-5.2.15/parse.y	2022-12-13 10:09:02.000000000 -0700
++++ source/parse.y	2023-09-09 09:07:14.706070416 -0600
+@@ -2625,6 +2625,7 @@
+       parser_state |= PST_ENDALIAS;
+       /* We need to do this to make sure last_shell_getc_is_singlebyte returns
+ 	 true, since we are returning a single-byte space. */
++#if defined (HANDLE_MULTIBYTE)
+       if (shell_input_line_index == shell_input_line_len && last_shell_getc_is_singlebyte == 0)
+ 	{
+ #if 0
+@@ -2638,6 +2639,7 @@
+ 	  shell_input_line_property[shell_input_line_index - 1] = 1;
+ #endif
+ 	}
++#endif /* HANDLE_MULTIBYTE */
+       return ' ';	/* END_ALIAS */
+     }
+ #endif
+diff -ruwN bash-5.2.15/y.tab.c source/y.tab.c
+--- bash-5.2.15/y.tab.c	2022-12-13 10:09:02.000000000 -0700
++++ source/y.tab.c	2023-09-09 09:07:14.706070416 -0600
+@@ -4936,6 +4936,7 @@
+       parser_state |= PST_ENDALIAS;
+       /* We need to do this to make sure last_shell_getc_is_singlebyte returns
+ 	 true, since we are returning a single-byte space. */
++#if defined (HANDLE_MULTIBYTE)
+       if (shell_input_line_index == shell_input_line_len && last_shell_getc_is_singlebyte == 0)
+ 	{
+ #if 0
+@@ -4949,6 +4950,7 @@
+ 	  shell_input_line_property[shell_input_line_index - 1] = 1;
+ #endif
+ 	}
++#endif /* HANDLE_MULTIBYTE */
+       return ' ';	/* END_ALIAS */
+     }
+ #endif