aboutsummaryrefslogtreecommitdiffstats
path: root/custom_baud_linux.c
diff options
context:
space:
mode:
authorPeter Stuge <peter@stuge.se>2022-12-11 04:02:10 +0100
committerThomas Heijligen <src@posteo.de>2023-02-16 17:29:21 +0000
commitcd84b8de7664c3b278310c558521f8e94e3128e0 (patch)
tree12c651d06016026db71fd7b67e373ff30d1ee680 /custom_baud_linux.c
parent65e3554b1376141608698f3b9df8cd5d44ce5e91 (diff)
downloadflashrom-cd84b8de7664c3b278310c558521f8e94e3128e0.tar.gz
flashrom-cd84b8de7664c3b278310c558521f8e94e3128e0.tar.bz2
flashrom-cd84b8de7664c3b278310c558521f8e94e3128e0.zip
serial: Call set_custom_baudrate() thrice
Call the function before tcsetattr() settings are known, then again with settings prepared but not yet applied and finally a third time after tcsetattr(). Darwin support needs this change; there custom_baud code must be called to modify the settings passed to tcsetattr() and then again after tcsetattr() returns. The change should be non-functional on all currently supported systems; current code calls set_custom_baudrate() before any tcsetattr() settings are prepared, so we have three stages in total. This change originates from discussion of the macOS patch proposed by Denis Ahrens in https://review.coreboot.org/c/flashrom/+/67822 Change-Id: I40cc443cfb7bf6b212b31826d437b898cc13c427 Signed-off-by: Peter Stuge <peter@stuge.se> Reviewed-on: https://review.coreboot.org/c/flashrom/+/70569 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Thomas Heijligen <src@posteo.de>
Diffstat (limited to 'custom_baud_linux.c')
-rw-r--r--custom_baud_linux.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/custom_baud_linux.c b/custom_baud_linux.c
index 2d5f261d..761d4961 100644
--- a/custom_baud_linux.c
+++ b/custom_baud_linux.c
@@ -29,9 +29,13 @@
* for more info.
*/
-int set_custom_baudrate(int fd, unsigned int baud)
+int set_custom_baudrate(int fd, unsigned int baud, const enum custom_baud_stage stage, void *tio_wanted)
{
struct termios2 tio;
+
+ if (stage != BEFORE_FLAGS)
+ return 0;
+
if (ioctl(fd, TCGETS2, &tio)) {
return -1;
}