xref: /openbmc/linux/drivers/misc/Kconfig (revision d6f3609d)
1#
2# Misc strange devices
3#
4
5menu "Misc devices"
6
7config SENSORS_LIS3LV02D
8	tristate
9	depends on INPUT
10	select INPUT_POLLDEV
11	default n
12
13config AD525X_DPOT
14	tristate "Analog Devices Digital Potentiometers"
15	depends on (I2C || SPI) && SYSFS
16	help
17	  If you say yes here, you get support for the Analog Devices
18	  AD5258, AD5259, AD5251, AD5252, AD5253, AD5254, AD5255
19	  AD5160, AD5161, AD5162, AD5165, AD5200, AD5201, AD5203,
20	  AD5204, AD5206, AD5207, AD5231, AD5232, AD5233, AD5235,
21	  AD5260, AD5262, AD5263, AD5290, AD5291, AD5292, AD5293,
22	  AD7376, AD8400, AD8402, AD8403, ADN2850, AD5241, AD5242,
23	  AD5243, AD5245, AD5246, AD5247, AD5248, AD5280, AD5282,
24	  ADN2860, AD5273, AD5171, AD5170, AD5172, AD5173, AD5270,
25	  AD5271, AD5272, AD5274
26	  digital potentiometer chips.
27
28	  See Documentation/misc-devices/ad525x_dpot.txt for the
29	  userspace interface.
30
31	  This driver can also be built as a module.  If so, the module
32	  will be called ad525x_dpot.
33
34config AD525X_DPOT_I2C
35	tristate "support I2C bus connection"
36	depends on AD525X_DPOT && I2C
37	help
38	  Say Y here if you have a digital potentiometers hooked to an I2C bus.
39
40	  To compile this driver as a module, choose M here: the
41	  module will be called ad525x_dpot-i2c.
42
43config AD525X_DPOT_SPI
44	tristate "support SPI bus connection"
45	depends on AD525X_DPOT && SPI_MASTER
46	help
47	  Say Y here if you have a digital potentiometers hooked to an SPI bus.
48
49	  If unsure, say N (but it's safe to say "Y").
50
51	  To compile this driver as a module, choose M here: the
52	  module will be called ad525x_dpot-spi.
53
54config ATMEL_TCLIB
55	bool "Atmel AT32/AT91 Timer/Counter Library"
56	depends on (AVR32 || ARCH_AT91)
57	help
58	  Select this if you want a library to allocate the Timer/Counter
59	  blocks found on many Atmel processors.  This facilitates using
60	  these blocks by different drivers despite processor differences.
61
62config ATMEL_TCB_CLKSRC
63	bool "TC Block Clocksource"
64	depends on ATMEL_TCLIB
65	default y
66	help
67	  Select this to get a high precision clocksource based on a
68	  TC block with a 5+ MHz base clock rate.  Two timer channels
69	  are combined to make a single 32-bit timer.
70
71	  When GENERIC_CLOCKEVENTS is defined, the third timer channel
72	  may be used as a clock event device supporting oneshot mode
73	  (delays of up to two seconds) based on the 32 KiHz clock.
74
75config ATMEL_TCB_CLKSRC_BLOCK
76	int
77	depends on ATMEL_TCB_CLKSRC
78	prompt "TC Block" if CPU_AT32AP700X
79	default 0
80	range 0 1
81	help
82	  Some chips provide more than one TC block, so you have the
83	  choice of which one to use for the clock framework.  The other
84	  TC can be used for other purposes, such as PWM generation and
85	  interval timing.
86
87config DUMMY_IRQ
88	tristate "Dummy IRQ handler"
89	default n
90	---help---
91	  This module accepts a single 'irq' parameter, which it should register for.
92	  The sole purpose of this module is to help with debugging of systems on
93	  which spurious IRQs would happen on disabled IRQ vector.
94
95config IBM_ASM
96	tristate "Device driver for IBM RSA service processor"
97	depends on X86 && PCI && INPUT
98	depends on SERIAL_8250 || SERIAL_8250=n
99	---help---
100	  This option enables device driver support for in-band access to the
101	  IBM RSA (Condor) service processor in eServer xSeries systems.
102	  The ibmasm device driver allows user space application to access
103	  ASM (Advanced Systems Management) functions on the service
104	  processor. The driver is meant to be used in conjunction with
105	  a user space API.
106	  The ibmasm driver also enables the OS to use the UART on the
107	  service processor board as a regular serial port. To make use of
108	  this feature serial driver support (CONFIG_SERIAL_8250) must be
109	  enabled.
110
111	  WARNING: This software may not be supported or function
112	  correctly on your IBM server. Please consult the IBM ServerProven
113	  website <http://www-03.ibm.com/systems/info/x86servers/serverproven/compat/us/>
114	  for information on the specific driver level and support statement
115	  for your IBM server.
116
117config PHANTOM
118	tristate "Sensable PHANToM (PCI)"
119	depends on PCI
120	help
121	  Say Y here if you want to build a driver for Sensable PHANToM device.
122
123	  This driver is only for PCI PHANToMs.
124
125	  If you choose to build module, its name will be phantom. If unsure,
126	  say N here.
127
128config INTEL_MID_PTI
129	tristate "Parallel Trace Interface for MIPI P1149.7 cJTAG standard"
130	depends on PCI && TTY && (X86_INTEL_MID || COMPILE_TEST)
131	default n
132	help
133	  The PTI (Parallel Trace Interface) driver directs
134	  trace data routed from various parts in the system out
135	  through an Intel Penwell PTI port and out of the mobile
136	  device for analysis with a debugging tool (Lauterbach or Fido).
137
138	  You should select this driver if the target kernel is meant for
139	  an Intel Atom (non-netbook) mobile device containing a MIPI
140	  P1149.7 standard implementation.
141
142config SGI_IOC4
143	tristate "SGI IOC4 Base IO support"
144	depends on PCI
145	---help---
146	  This option enables basic support for the IOC4 chip on certain
147	  SGI IO controller cards (IO9, IO10, and PCI-RT).  This option
148	  does not enable any specific functions on such a card, but provides
149	  necessary infrastructure for other drivers to utilize.
150
151	  If you have an SGI Altix with an IOC4-based card say Y.
152	  Otherwise say N.
153
154config TIFM_CORE
155	tristate "TI Flash Media interface support"
156	depends on PCI
157	help
158	  If you want support for Texas Instruments(R) Flash Media adapters
159	  you should select this option and then also choose an appropriate
160	  host adapter, such as 'TI Flash Media PCI74xx/PCI76xx host adapter
161	  support', if you have a TI PCI74xx compatible card reader, for
162	  example.
163	  You will also have to select some flash card format drivers. MMC/SD
164	  cards are supported via 'MMC/SD Card support: TI Flash Media MMC/SD
165	  Interface support (MMC_TIFM_SD)'.
166
167	  To compile this driver as a module, choose M here: the module will
168	  be called tifm_core.
169
170config TIFM_7XX1
171	tristate "TI Flash Media PCI74xx/PCI76xx host adapter support"
172	depends on PCI && TIFM_CORE
173	default TIFM_CORE
174	help
175	  This option enables support for Texas Instruments(R) PCI74xx and
176	  PCI76xx families of Flash Media adapters, found in many laptops.
177	  To make actual use of the device, you will have to select some
178	  flash card format drivers, as outlined in the TIFM_CORE Help.
179
180	  To compile this driver as a module, choose M here: the module will
181	  be called tifm_7xx1.
182
183config ICS932S401
184	tristate "Integrated Circuits ICS932S401"
185	depends on I2C
186	help
187	  If you say yes here you get support for the Integrated Circuits
188	  ICS932S401 clock control chips.
189
190	  This driver can also be built as a module. If so, the module
191	  will be called ics932s401.
192
193config ATMEL_SSC
194	tristate "Device driver for Atmel SSC peripheral"
195	depends on HAS_IOMEM && (AVR32 || ARCH_AT91 || COMPILE_TEST)
196	---help---
197	  This option enables device driver support for Atmel Synchronized
198	  Serial Communication peripheral (SSC).
199
200	  The SSC peripheral supports a wide variety of serial frame based
201	  communications, i.e. I2S, SPI, etc.
202
203	  If unsure, say N.
204
205config ENCLOSURE_SERVICES
206	tristate "Enclosure Services"
207	default n
208	help
209	  Provides support for intelligent enclosures (bays which
210	  contain storage devices).  You also need either a host
211	  driver (SCSI/ATA) which supports enclosures
212	  or a SCSI enclosure device (SES) to use these services.
213
214config SGI_XP
215	tristate "Support communication between SGI SSIs"
216	depends on NET
217	depends on (IA64_GENERIC || IA64_SGI_SN2 || IA64_SGI_UV || X86_UV) && SMP
218	select IA64_UNCACHED_ALLOCATOR if IA64_GENERIC || IA64_SGI_SN2
219	select GENERIC_ALLOCATOR if IA64_GENERIC || IA64_SGI_SN2
220	select SGI_GRU if X86_64 && SMP
221	---help---
222	  An SGI machine can be divided into multiple Single System
223	  Images which act independently of each other and have
224	  hardware based memory protection from the others.  Enabling
225	  this feature will allow for direct communication between SSIs
226	  based on a network adapter and DMA messaging.
227
228config CS5535_MFGPT
229	tristate "CS5535/CS5536 Geode Multi-Function General Purpose Timer (MFGPT) support"
230	depends on MFD_CS5535
231	default n
232	help
233	  This driver provides access to MFGPT functionality for other
234	  drivers that need timers.  MFGPTs are available in the CS5535 and
235	  CS5536 companion chips that are found in AMD Geode and several
236	  other platforms.  They have a better resolution and max interval
237	  than the generic PIT, and are suitable for use as high-res timers.
238	  You probably don't want to enable this manually; other drivers that
239	  make use of it should enable it.
240
241config CS5535_MFGPT_DEFAULT_IRQ
242	int
243	depends on CS5535_MFGPT
244	default 7
245	help
246	  MFGPTs on the CS5535 require an interrupt.  The selected IRQ
247	  can be overridden as a module option as well as by driver that
248	  use the cs5535_mfgpt_ API; however, different architectures might
249	  want to use a different IRQ by default.  This is here for
250	  architectures to set as necessary.
251
252config CS5535_CLOCK_EVENT_SRC
253	tristate "CS5535/CS5536 high-res timer (MFGPT) events"
254	depends on GENERIC_CLOCKEVENTS && CS5535_MFGPT
255	help
256	  This driver provides a clock event source based on the MFGPT
257	  timer(s) in the CS5535 and CS5536 companion chips.
258	  MFGPTs have a better resolution and max interval than the
259	  generic PIT, and are suitable for use as high-res timers.
260
261config HP_ILO
262	tristate "Channel interface driver for the HP iLO processor"
263	depends on PCI
264	default n
265	help
266	  The channel interface driver allows applications to communicate
267	  with iLO management processors present on HP ProLiant servers.
268	  Upon loading, the driver creates /dev/hpilo/dXccbN files, which
269	  can be used to gather data from the management processor, via
270	  read and write system calls.
271
272	  To compile this driver as a module, choose M here: the
273	  module will be called hpilo.
274
275config QCOM_COINCELL
276	tristate "Qualcomm coincell charger support"
277	depends on MFD_SPMI_PMIC || COMPILE_TEST
278	help
279	  This driver supports the coincell block found inside of
280	  Qualcomm PMICs.  The coincell charger provides a means to
281	  charge a coincell battery or backup capacitor which is used
282	  to maintain PMIC register and RTC state in the absence of
283	  external power.
284
285config SGI_GRU
286	tristate "SGI GRU driver"
287	depends on X86_UV && SMP
288	default n
289	select MMU_NOTIFIER
290	---help---
291	The GRU is a hardware resource located in the system chipset. The GRU
292	contains memory that can be mmapped into the user address space. This memory is
293	used to communicate with the GRU to perform functions such as load/store,
294	scatter/gather, bcopy, AMOs, etc.  The GRU is directly accessed by user
295	instructions using user virtual addresses. GRU instructions (ex., bcopy) use
296	user virtual addresses for operands.
297
298	If you are not running on a SGI UV system, say N.
299
300config SGI_GRU_DEBUG
301	bool  "SGI GRU driver debug"
302	depends on SGI_GRU
303	default n
304	---help---
305	This option enables additional debugging code for the SGI GRU driver.
306	If you are unsure, say N.
307
308config APDS9802ALS
309	tristate "Medfield Avago APDS9802 ALS Sensor module"
310	depends on I2C
311	help
312	  If you say yes here you get support for the ALS APDS9802 ambient
313	  light sensor.
314
315	  This driver can also be built as a module.  If so, the module
316	  will be called apds9802als.
317
318config ISL29003
319	tristate "Intersil ISL29003 ambient light sensor"
320	depends on I2C && SYSFS
321	help
322	  If you say yes here you get support for the Intersil ISL29003
323	  ambient light sensor.
324
325	  This driver can also be built as a module.  If so, the module
326	  will be called isl29003.
327
328config ISL29020
329	tristate "Intersil ISL29020 ambient light sensor"
330	depends on I2C
331	help
332	  If you say yes here you get support for the Intersil ISL29020
333	  ambient light sensor.
334
335	  This driver can also be built as a module.  If so, the module
336	  will be called isl29020.
337
338config SENSORS_TSL2550
339	tristate "Taos TSL2550 ambient light sensor"
340	depends on I2C && SYSFS
341	help
342	  If you say yes here you get support for the Taos TSL2550
343	  ambient light sensor.
344
345	  This driver can also be built as a module.  If so, the module
346	  will be called tsl2550.
347
348config SENSORS_BH1770
349         tristate "BH1770GLC / SFH7770 combined ALS - Proximity sensor"
350         depends on I2C
351         ---help---
352           Say Y here if you want to build a driver for BH1770GLC (ROHM) or
353	   SFH7770 (Osram) combined ambient light and proximity sensor chip.
354
355           To compile this driver as a module, choose M here: the
356           module will be called bh1770glc. If unsure, say N here.
357
358config SENSORS_APDS990X
359	 tristate "APDS990X combined als and proximity sensors"
360	 depends on I2C
361	 default n
362	 ---help---
363	   Say Y here if you want to build a driver for Avago APDS990x
364	   combined ambient light and proximity sensor chip.
365
366	   To compile this driver as a module, choose M here: the
367	   module will be called apds990x. If unsure, say N here.
368
369config HMC6352
370	tristate "Honeywell HMC6352 compass"
371	depends on I2C
372	help
373	  This driver provides support for the Honeywell HMC6352 compass,
374	  providing configuration and heading data via sysfs.
375
376config DS1682
377	tristate "Dallas DS1682 Total Elapsed Time Recorder with Alarm"
378	depends on I2C
379	help
380	  If you say yes here you get support for Dallas Semiconductor
381	  DS1682 Total Elapsed Time Recorder.
382
383	  This driver can also be built as a module.  If so, the module
384	  will be called ds1682.
385
386config SPEAR13XX_PCIE_GADGET
387	bool "PCIe gadget support for SPEAr13XX platform"
388	depends on ARCH_SPEAR13XX && BROKEN
389	default n
390	help
391	 This option enables gadget support for PCIe controller. If
392	 board file defines any controller as PCIe endpoint then a sysfs
393	 entry will be created for that controller. User can use these
394	 sysfs node to configure PCIe EP as per his requirements.
395
396config TI_DAC7512
397	tristate "Texas Instruments DAC7512"
398	depends on SPI && SYSFS
399	help
400	  If you say yes here you get support for the Texas Instruments
401	  DAC7512 16-bit digital-to-analog converter.
402
403	  This driver can also be built as a module. If so, the module
404	  will be called ti_dac7512.
405
406config VMWARE_BALLOON
407	tristate "VMware Balloon Driver"
408	depends on VMWARE_VMCI && X86 && HYPERVISOR_GUEST
409	help
410	  This is VMware physical memory management driver which acts
411	  like a "balloon" that can be inflated to reclaim physical pages
412	  by reserving them in the guest and invalidating them in the
413	  monitor, freeing up the underlying machine pages so they can
414	  be allocated to other guests. The balloon can also be deflated
415	  to allow the guest to use more physical memory.
416
417	  If unsure, say N.
418
419	  To compile this driver as a module, choose M here: the
420	  module will be called vmw_balloon.
421
422config ARM_CHARLCD
423	bool "ARM Ltd. Character LCD Driver"
424	depends on PLAT_VERSATILE
425	help
426	  This is a driver for the character LCD found on the ARM Ltd.
427	  Versatile and RealView Platform Baseboards. It doesn't do
428	  very much more than display the text "ARM Linux" on the first
429	  line and the Linux version on the second line, but that's
430	  still useful.
431
432config PCH_PHUB
433	tristate "Intel EG20T PCH/LAPIS Semicon IOH(ML7213/ML7223/ML7831) PHUB"
434	select GENERIC_NET_UTILS
435	depends on PCI && (X86_32 || MIPS || COMPILE_TEST)
436	help
437	  This driver is for PCH(Platform controller Hub) PHUB(Packet Hub) of
438	  Intel Topcliff which is an IOH(Input/Output Hub) for x86 embedded
439	  processor. The Topcliff has MAC address and Option ROM data in SROM.
440	  This driver can access MAC address and Option ROM data in SROM.
441
442	  This driver also can be used for LAPIS Semiconductor's IOH,
443	  ML7213/ML7223/ML7831.
444	  ML7213 which is for IVI(In-Vehicle Infotainment) use.
445	  ML7223 IOH is for MP(Media Phone) use.
446	  ML7831 IOH is for general purpose use.
447	  ML7213/ML7223/ML7831 is companion chip for Intel Atom E6xx series.
448	  ML7213/ML7223/ML7831 is completely compatible for Intel EG20T PCH.
449
450	  To compile this driver as a module, choose M here: the module will
451	  be called pch_phub.
452
453config USB_SWITCH_FSA9480
454	tristate "FSA9480 USB Switch"
455	depends on I2C
456	help
457	  The FSA9480 is a USB port accessory detector and switch.
458	  The FSA9480 is fully controlled using I2C and enables USB data,
459	  stereo and mono audio, video, microphone and UART data to use
460	  a common connector port.
461
462config LATTICE_ECP3_CONFIG
463	tristate "Lattice ECP3 FPGA bitstream configuration via SPI"
464	depends on SPI && SYSFS
465	select FW_LOADER
466	default	n
467	help
468	  This option enables support for bitstream configuration (programming
469	  or loading) of the Lattice ECP3 FPGA family via SPI.
470
471	  If unsure, say N.
472
473config SRAM
474	bool "Generic on-chip SRAM driver"
475	depends on HAS_IOMEM
476	select GENERIC_ALLOCATOR
477	select SRAM_EXEC if ARM
478	help
479	  This driver allows you to declare a memory region to be managed by
480	  the genalloc API. It is supposed to be used for small on-chip SRAM
481	  areas found on many SoCs.
482
483config SRAM_EXEC
484	bool
485
486config VEXPRESS_SYSCFG
487	bool "Versatile Express System Configuration driver"
488	depends on VEXPRESS_CONFIG
489	default y
490	help
491	  ARM Ltd. Versatile Express uses specialised platform configuration
492	  bus. System Configuration interface is one of the possible means
493	  of generating transactions on this bus.
494config PANEL
495	tristate "Parallel port LCD/Keypad Panel support"
496	depends on PARPORT
497	---help---
498	  Say Y here if you have an HD44780 or KS-0074 LCD connected to your
499	  parallel port. This driver also features 4 and 6-key keypads. The LCD
500	  is accessible through the /dev/lcd char device (10, 156), and the
501	  keypad through /dev/keypad (10, 185). Both require misc device to be
502	  enabled. This code can either be compiled as a module, or linked into
503	  the kernel and started at boot. If you don't understand what all this
504	  is about, say N.
505
506config PANEL_PARPORT
507	int "Default parallel port number (0=LPT1)"
508	depends on PANEL
509	range 0 255
510	default "0"
511	---help---
512	  This is the index of the parallel port the panel is connected to. One
513	  driver instance only supports one parallel port, so if your keypad
514	  and LCD are connected to two separate ports, you have to start two
515	  modules with different arguments. Numbering starts with '0' for LPT1,
516	  and so on.
517
518config PANEL_PROFILE
519	int "Default panel profile (0-5, 0=custom)"
520	depends on PANEL
521	range 0 5
522	default "5"
523	---help---
524	  To ease configuration, the driver supports different configuration
525	  profiles for past and recent wirings. These profiles can also be
526	  used to define an approximative configuration, completed by a few
527	  other options. Here are the profiles :
528
529	    0 = custom (see further)
530	    1 = 2x16 parallel LCD, old keypad
531	    2 = 2x16 serial LCD (KS-0074), new keypad
532	    3 = 2x16 parallel LCD (Hantronix), no keypad
533	    4 = 2x16 parallel LCD (Nexcom NSA1045) with Nexcom's keypad
534	    5 = 2x40 parallel LCD (old one), with old keypad
535
536	  Custom configurations allow you to define how your display is
537	  wired to the parallel port, and how it works. This is only intended
538	  for experts.
539
540config PANEL_KEYPAD
541	depends on PANEL && PANEL_PROFILE="0"
542	int "Keypad type (0=none, 1=old 6 keys, 2=new 6 keys, 3=Nexcom 4 keys)"
543	range 0 3
544	default 0
545	---help---
546	  This enables and configures a keypad connected to the parallel port.
547	  The keys will be read from character device 10,185. Valid values are :
548
549	    0 : do not enable this driver
550	    1 : old 6 keys keypad
551	    2 : new 6 keys keypad, as used on the server at www.ant-computing.com
552	    3 : Nexcom NSA1045's 4 keys keypad
553
554	  New profiles can be described in the driver source. The driver also
555	  supports simultaneous keys pressed when the keypad supports them.
556
557config PANEL_LCD
558	depends on PANEL && PANEL_PROFILE="0"
559	int "LCD type (0=none, 1=custom, 2=old //, 3=ks0074, 4=hantronix, 5=Nexcom)"
560	range 0 5
561	default 0
562	---help---
563	   This enables and configures an LCD connected to the parallel port.
564	   The driver includes an interpreter for escape codes starting with
565	   '\e[L' which are specific to the LCD, and a few ANSI codes. The
566	   driver will be registered as character device 10,156, usually
567	   under the name '/dev/lcd'. There are a total of 6 supported types :
568
569	     0 : do not enable the driver
570	     1 : custom configuration and wiring (see further)
571	     2 : 2x16 & 2x40 parallel LCD (old wiring)
572	     3 : 2x16 serial LCD (KS-0074 based)
573	     4 : 2x16 parallel LCD (Hantronix wiring)
574	     5 : 2x16 parallel LCD (Nexcom wiring)
575
576	   When type '1' is specified, other options will appear to configure
577	   more precise aspects (wiring, dimensions, protocol, ...). Please note
578	   that those values changed from the 2.4 driver for better consistency.
579
580config PANEL_LCD_HEIGHT
581	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
582	int "Number of lines on the LCD (1-2)"
583	range 1 2
584	default 2
585	---help---
586	  This is the number of visible character lines on the LCD in custom profile.
587	  It can either be 1 or 2.
588
589config PANEL_LCD_WIDTH
590	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
591	int "Number of characters per line on the LCD (1-40)"
592	range 1 40
593	default 40
594	---help---
595	  This is the number of characters per line on the LCD in custom profile.
596	  Common values are 16,20,24,40.
597
598config PANEL_LCD_BWIDTH
599	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
600	int "Internal LCD line width (1-40, 40 by default)"
601	range 1 40
602	default 40
603	---help---
604	  Most LCDs use a standard controller which supports hardware lines of 40
605	  characters, although sometimes only 16, 20 or 24 of them are really wired
606	  to the terminal. This results in some non-visible but addressable characters,
607	  and is the case for most parallel LCDs. Other LCDs, and some serial ones,
608	  however, use the same line width internally as what is visible. The KS0074
609	  for example, uses 16 characters per line for 16 visible characters per line.
610
611	  This option lets you configure the value used by your LCD in 'custom' profile.
612	  If you don't know, put '40' here.
613
614config PANEL_LCD_HWIDTH
615	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
616	int "Hardware LCD line width (1-64, 64 by default)"
617	range 1 64
618	default 64
619	---help---
620	  Most LCDs use a single address bit to differentiate line 0 and line 1. Since
621	  some of them need to be able to address 40 chars with the lower bits, they
622	  often use the immediately superior power of 2, which is 64, to address the
623	  next line.
624
625	  If you don't know what your LCD uses, in doubt let 16 here for a 2x16, and
626	  64 here for a 2x40.
627
628config PANEL_LCD_CHARSET
629	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
630	int "LCD character set (0=normal, 1=KS0074)"
631	range 0 1
632	default 0
633	---help---
634	  Some controllers such as the KS0074 use a somewhat strange character set
635	  where many symbols are at unusual places. The driver knows how to map
636	  'standard' ASCII characters to the character sets used by these controllers.
637	  Valid values are :
638
639	     0 : normal (untranslated) character set
640	     1 : KS0074 character set
641
642	  If you don't know, use the normal one (0).
643
644config PANEL_LCD_PROTO
645	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
646	int "LCD communication mode (0=parallel 8 bits, 1=serial)"
647	range 0 1
648	default 0
649	---help---
650	  This driver now supports any serial or parallel LCD wired to a parallel
651	  port. But before assigning signals, the driver needs to know if it will
652	  be driving a serial LCD or a parallel one. Serial LCDs only use 2 wires
653	  (SDA/SCL), while parallel ones use 2 or 3 wires for the control signals
654	  (E, RS, sometimes RW), and 4 or 8 for the data. Use 0 here for a 8 bits
655	  parallel LCD, and 1 for a serial LCD.
656
657config PANEL_LCD_PIN_E
658	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1" && PANEL_LCD_PROTO="0"
659        int "Parallel port pin number & polarity connected to the LCD E signal (-17...17) "
660	range -17 17
661	default 14
662	---help---
663	  This describes the number of the parallel port pin to which the LCD 'E'
664	  signal has been connected. It can be :
665
666	          0 : no connection (eg: connected to ground)
667	      1..17 : directly connected to any of these pins on the DB25 plug
668	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
669
670	  Default for the 'E' pin in custom profile is '14' (AUTOFEED).
671
672config PANEL_LCD_PIN_RS
673	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1" && PANEL_LCD_PROTO="0"
674        int "Parallel port pin number & polarity connected to the LCD RS signal (-17...17) "
675	range -17 17
676	default 17
677	---help---
678	  This describes the number of the parallel port pin to which the LCD 'RS'
679	  signal has been connected. It can be :
680
681	          0 : no connection (eg: connected to ground)
682	      1..17 : directly connected to any of these pins on the DB25 plug
683	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
684
685	  Default for the 'RS' pin in custom profile is '17' (SELECT IN).
686
687config PANEL_LCD_PIN_RW
688	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1" && PANEL_LCD_PROTO="0"
689        int "Parallel port pin number & polarity connected to the LCD RW signal (-17...17) "
690	range -17 17
691	default 16
692	---help---
693	  This describes the number of the parallel port pin to which the LCD 'RW'
694	  signal has been connected. It can be :
695
696	          0 : no connection (eg: connected to ground)
697	      1..17 : directly connected to any of these pins on the DB25 plug
698	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
699
700	  Default for the 'RW' pin in custom profile is '16' (INIT).
701
702config PANEL_LCD_PIN_SCL
703	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1" && PANEL_LCD_PROTO!="0"
704        int "Parallel port pin number & polarity connected to the LCD SCL signal (-17...17) "
705	range -17 17
706	default 1
707	---help---
708	  This describes the number of the parallel port pin to which the serial
709	  LCD 'SCL' signal has been connected. It can be :
710
711	          0 : no connection (eg: connected to ground)
712	      1..17 : directly connected to any of these pins on the DB25 plug
713	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
714
715	  Default for the 'SCL' pin in custom profile is '1' (STROBE).
716
717config PANEL_LCD_PIN_SDA
718	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1" && PANEL_LCD_PROTO!="0"
719        int "Parallel port pin number & polarity connected to the LCD SDA signal (-17...17) "
720	range -17 17
721	default 2
722	---help---
723	  This describes the number of the parallel port pin to which the serial
724	  LCD 'SDA' signal has been connected. It can be :
725
726	          0 : no connection (eg: connected to ground)
727	      1..17 : directly connected to any of these pins on the DB25 plug
728	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
729
730	  Default for the 'SDA' pin in custom profile is '2' (D0).
731
732config PANEL_LCD_PIN_BL
733	depends on PANEL && PANEL_PROFILE="0" && PANEL_LCD="1"
734        int "Parallel port pin number & polarity connected to the LCD backlight signal (-17...17) "
735	range -17 17
736	default 0
737	---help---
738	  This describes the number of the parallel port pin to which the LCD 'BL' signal
739          has been connected. It can be :
740
741	          0 : no connection (eg: connected to ground)
742	      1..17 : directly connected to any of these pins on the DB25 plug
743	    -1..-17 : connected to the same pin through an inverter (eg: transistor).
744
745	  Default for the 'BL' pin in custom profile is '0' (uncontrolled).
746
747config PANEL_CHANGE_MESSAGE
748	depends on PANEL
749	bool "Change LCD initialization message ?"
750	default "n"
751	---help---
752	  This allows you to replace the boot message indicating the kernel version
753	  and the driver version with a custom message. This is useful on appliances
754	  where a simple 'Starting system' message can be enough to stop a customer
755	  from worrying.
756
757	  If you say 'Y' here, you'll be able to choose a message yourself. Otherwise,
758	  say 'N' and keep the default message with the version.
759
760config PANEL_BOOT_MESSAGE
761	depends on PANEL && PANEL_CHANGE_MESSAGE="y"
762	string "New initialization message"
763	default ""
764	---help---
765	  This allows you to replace the boot message indicating the kernel version
766	  and the driver version with a custom message. This is useful on appliances
767	  where a simple 'Starting system' message can be enough to stop a customer
768	  from worrying.
769
770	  An empty message will only clear the display at driver init time. Any other
771	  printf()-formatted message is valid with newline and escape codes.
772
773source "drivers/misc/c2port/Kconfig"
774source "drivers/misc/eeprom/Kconfig"
775source "drivers/misc/cb710/Kconfig"
776source "drivers/misc/ti-st/Kconfig"
777source "drivers/misc/lis3lv02d/Kconfig"
778source "drivers/misc/altera-stapl/Kconfig"
779source "drivers/misc/mei/Kconfig"
780source "drivers/misc/vmw_vmci/Kconfig"
781source "drivers/misc/mic/Kconfig"
782source "drivers/misc/genwqe/Kconfig"
783source "drivers/misc/echo/Kconfig"
784source "drivers/misc/cxl/Kconfig"
785endmenu
786