From 1e2c002a1070c139ce381f0eecd39730cb069a2b Mon Sep 17 00:00:00 2001 From: liuhongchao Date: Tue, 5 Nov 2024 10:55:46 +0800 Subject: [PATCH] nuttx: add open and close callback functions for the mouse. Signed-off-by: liuhongchao --- drivers/input/Kconfig | 6 +++--- drivers/input/mouse_upper.c | 12 +++++++++++ include/nuttx/input/mouse.h | 41 +++++++++++++++++++++++++++++++++++-- 3 files changed, 54 insertions(+), 5 deletions(-) diff --git a/drivers/input/Kconfig b/drivers/input/Kconfig index 257ec382f32d5..959b9e0cda4c6 100644 --- a/drivers/input/Kconfig +++ b/drivers/input/Kconfig @@ -65,7 +65,7 @@ endif # FF_AW86225 endif # INPUT_FF config INPUT_MOUSE - bool "Enable mouse support" + bool default n ---help--- Enable support for mouse devices. @@ -82,11 +82,11 @@ config INPUT_MOUSE_WHEEL endif # INPUT_MOUSE config INPUT_TOUCHSCREEN - bool "Enable touchscreen support" + bool default n config INPUT_KEYBOARD - bool "Enable keyboard support" + bool default n config INPUT_UINPUT diff --git a/drivers/input/mouse_upper.c b/drivers/input/mouse_upper.c index 62d625e26ab4b..069b47a969b64 100644 --- a/drivers/input/mouse_upper.c +++ b/drivers/input/mouse_upper.c @@ -103,6 +103,7 @@ static int mouse_open(FAR struct file *filep) FAR struct mouse_openpriv_s *openpriv; FAR struct inode *inode = filep->f_inode; FAR struct mouse_upperhalf_s *upper = inode->i_private; + FAR struct mouse_lowerhalf_s *lower = upper->lower; int ret; ret = nxmutex_lock(&upper->lock); @@ -131,6 +132,11 @@ static int mouse_open(FAR struct file *filep) nxmutex_init(&openpriv->lock); list_add_tail(&upper->head, &openpriv->node); + if (lower->open && list_is_singular(&openpriv->node)) + { + ret = lower->open(lower); + } + /* Save the buffer node pointer so that it can be used directly * in the read operation. */ @@ -149,6 +155,7 @@ static int mouse_close(FAR struct file *filep) FAR struct mouse_openpriv_s *openpriv = filep->f_priv; FAR struct inode *inode = filep->f_inode; FAR struct mouse_upperhalf_s *upper = inode->i_private; + FAR struct mouse_lowerhalf_s *lower = upper->lower; int ret; ret = nxmutex_lock(&upper->lock); @@ -157,6 +164,11 @@ static int mouse_close(FAR struct file *filep) return ret; } + if (lower->close && list_is_singular(&openpriv->node)) + { + ret = lower->close(lower); + } + list_delete(&openpriv->node); circbuf_uninit(&openpriv->circbuf); nxsem_destroy(&openpriv->waitsem); diff --git a/include/nuttx/input/mouse.h b/include/nuttx/input/mouse.h index 62426d2461ec7..37174f819a651 100644 --- a/include/nuttx/input/mouse.h +++ b/include/nuttx/input/mouse.h @@ -114,9 +114,7 @@ struct mouse_report_s /* Possibly padded with 1 byte here */ int16_t x; /* X coordinate of the mouse position */ int16_t y; /* Y coordinate of the mouse position */ -#ifdef CONFIG_INPUT_MOUSE_WHEEL int16_t wheel; /* Mouse wheel position */ -#endif }; /* This structure is for mouse lower half driver */ @@ -143,6 +141,45 @@ struct mouse_lowerhalf_s CODE int (*control)(FAR struct mouse_lowerhalf_s *lower, int cmd, unsigned long arg); + + /************************************************************************** + * Name: open + * + * Description: + * This function pointer is used to open a connection to the mouse driver + * instance. It initializes the mouse and prepares it for subsequent + * interactions with the user. This function typically sets up the state + * of the driver and allocates any necessary resources. + * + * Input Parameters: + * lower - A pointer to the instance of the lower half mouse driver. + * filep - A pointer to the file structure representing the user. + * + * Returned Value: + * It returns zero (OK) on success; a negative errno value on failure. + **************************************************************************/ + + CODE int (*open)(FAR struct mouse_lowerhalf_s *lower); + + /************************************************************************** + * Name: close + * + * Description: + * This function pointer is used to close the connection to the mouse + * driver instance. It performs any necessary cleanup operations, such as + * releasing resources and resetting the state of the mouse driver, + * before ending theinteraction with the user. + * + * Input Parameters: + * lower - A pointer to the instance of the lower half mouse driver. + * filep - A pointer to the file structure representing the user closing + * the mouse connection. + * + * Returned Value: + * Returns zero (OK) on success; a negative errno value on failure. + **************************************************************************/ + + CODE int (*close)(FAR struct mouse_lowerhalf_s *lower); }; /****************************************************************************