1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (c) 2015 Google, Inc
6 #define LOG_CATEGORY UCLASS_KEYBOARD
13 static int keyboard_start(struct stdio_dev *sdev)
15 struct udevice *dev = sdev->priv;
16 struct keyboard_ops *ops = keyboard_get_ops(dev);
19 return ops->start(dev);
24 static int keyboard_stop(struct stdio_dev *sdev)
26 struct udevice *dev = sdev->priv;
27 struct keyboard_ops *ops = keyboard_get_ops(dev);
30 return ops->stop(dev);
35 static int keyboard_tstc(struct stdio_dev *sdev)
37 struct udevice *dev = sdev->priv;
38 struct keyboard_priv *priv = dev_get_uclass_priv(dev);
39 struct keyboard_ops *ops = keyboard_get_ops(dev);
41 /* Just get input to do this for us if we can */
43 return input_tstc(&priv->input);
45 return ops->tstc(dev);
50 static int keyboard_getc(struct stdio_dev *sdev)
52 struct udevice *dev = sdev->priv;
53 struct keyboard_priv *priv = dev_get_uclass_priv(dev);
54 struct keyboard_ops *ops = keyboard_get_ops(dev);
56 /* Just get input to do this for us if we can */
58 return input_getc(&priv->input);
60 return ops->getc(dev);
65 static int keyboard_pre_probe(struct udevice *dev)
67 struct keyboard_priv *priv = dev_get_uclass_priv(dev);
68 struct stdio_dev *sdev = &priv->sdev;
71 strlcpy(sdev->name, dev->name, sizeof(sdev->name));
72 sdev->flags = DEV_FLAGS_INPUT;
73 sdev->getc = keyboard_getc;
74 sdev->tstc = keyboard_tstc;
75 sdev->start = keyboard_start;
76 sdev->stop = keyboard_stop;
78 ret = input_init(&priv->input, 0);
80 debug("%s: Cannot set up input, ret=%d - please add DEBUG to drivers/input/input.c to figure out the cause\n",
88 UCLASS_DRIVER(keyboard) = {
89 .id = UCLASS_KEYBOARD,
91 .pre_probe = keyboard_pre_probe,
92 .per_device_auto = sizeof(struct keyboard_priv),