From: Andy Shevchenko Date: Mon, 21 Dec 2020 12:30:08 +0000 (+0200) Subject: IOMUX: Stop dropped consoles X-Git-Url: http://git.dujemihanovic.xyz/?a=commitdiff_plain;h=70c2525c0d3c5b459ba5a438b23056be648a5249;p=u-boot.git IOMUX: Stop dropped consoles When at some point environment shrinks we need to stop dropped devices. Signed-off-by: Andy Shevchenko Reviewed-by: Simon Glass --- diff --git a/common/iomux.c b/common/iomux.c index 126d92ce85..15bf533885 100644 --- a/common/iomux.c +++ b/common/iomux.c @@ -27,8 +27,8 @@ int iomux_doenv(const int console, const char *arg) { char *console_args, *temp, **start; int i, j, k, io_flag, cs_idx, repeat; + struct stdio_dev **cons_set, **old_set; struct stdio_dev *dev; - struct stdio_dev **cons_set; console_args = strdup(arg); if (console_args == NULL) @@ -128,10 +128,23 @@ int iomux_doenv(const int console, const char *arg) return 1; } - /* Works even if console_devices[console] is NULL. */ - free(console_devices[console]); + old_set = console_devices[console]; + repeat = cd_count[console]; + console_devices[console] = cons_set; cd_count[console] = cs_idx; + + /* Stop dropped consoles */ + for (i = 0; i < repeat; i++) { + for (j = 0; j < cs_idx; j++) { + if (old_set[i] == cons_set[j]) + break; + } + if (j == cs_idx) + console_stop(console, old_set[i]); + } + + free(old_set); return 0; } #endif /* CONSOLE_MUX */