# Kconfig - I2C configuration options # # Copyright (c) 2015 Intel Corporation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # # I2C options # menuconfig I2C bool prompt "I2C Drivers" default n help Enable I2C Driver Configuration config I2C_INIT_PRIORITY int depends on I2C default 60 prompt "Init priority" help I2C device driver initialization priority. config I2C_STATUS_DELAY int "Delay for controller response" depends on I2C default 1000 config I2C_CLOCK_SPEED int "Set the clock speed for I2C" default 32 depends on I2C config I2C_DEBUG bool "Enable I2C debug options" default n depends on I2C help This option enables the debug features for I2C connections config I2C_DW bool "Design Ware I2C support" depends on I2C default n help Enable Design Ware I2C support on the selected platform choice prompt "IRQ Trigger Condition" default I2C_DW_IRQ_RISING_EDGE depends on I2C_DW config I2C_DW_IRQ_FALLING_EDGE bool "Falling Edge" help This option signifies that the controller uses falling edge interrupt. config I2C_DW_IRQ_RISING_EDGE bool "Rising Edge" help This option signifies that the controller uses rising edge interrupt. config I2C_DW_IRQ_LEVEL_HIGH bool "Level High" help This option signifies that the controller uses level high interrupt. config I2C_DW_IRQ_LEVEL_LOW bool "Level Low" help This option signifies that the controller uses level low interrupt. endchoice config I2C_DW_SHARED_IRQ bool default n depends on I2C_DW config I2C_DW_VENDOR_ID hex "PCI Vendor ID of the controllers" depends on I2C_DW && PCI default 0x8086 config I2C_DW_DEVICE_ID hex "PCI Device ID of the controllers" depends on I2C_DW && PCI default 0x934 config I2C_DW_CLASS hex "PCI device class" depends on I2C_DW && PCI default 0x0C config I2C_DW_0 bool "Enable I2C0" default n depends on I2C_DW config I2C_DW_0_BASE hex "Base address for I2C0" default 0x00000000 depends on I2C_DW_0 config I2C_DW_0_NAME string "Select a name for finding the device" depends on I2C_DW_0 default "I2C0" choice prompt "I2C0 Interrupts via" default I2C_DW_0_IRQ_DIRECT depends on I2C_DW_0 config I2C_DW_0_IRQ_DIRECT bool "Direct Hardware Interrupt" help When interrupts fire, the driver's ISR function is being called directly. config I2C_DW_0_IRQ_SHARED bool "Shared IRQ" depends on SHARED_IRQ select I2C_DW_SHARED_IRQ help When interrupts fire, the shared IRQ driver is notified. Then the shared IRQ driver dispatches the interrupt to other drivers. endchoice config I2C_DW_0_IRQ_SHARED_NAME string "Device name for Shared IRQ" depends on I2C_DW_0 && I2C_DW_0_IRQ_SHARED help Specify the device name for the shared IRQ driver. It is used to register this driver with the shared IRQ driver, so interrupts can be dispatched correctly. config I2C_DW_0_IRQ int "Controller interrupt" depends on I2C_DW_0 && I2C_DW_0_IRQ_DIRECT default 0 config I2C_DW_0_INT_PRIORITY int "Controller interrupt priority" depends on I2C_DW_0 && I2C_DW_0_IRQ_DIRECT default 2 help IRQ priority config I2C_DW_0_DEFAULT_CFG hex "I2C default configuration" depends on I2C_DW_0 default 0x0 help Allows the I2C port to be brought up with a default configuration. This is useful to set if other drivers depend upon using the I2C bus before the application has a chance to custom configure the port. Setting this value does not prohibit the application from customizing the values later. Refer to the I2C datasheet for proper values. config I2C_DW_0_BUS int "PCI Bus number" depends on I2C_DW_0 && PCI default 0 config I2C_DW_0_DEV int "PCI device number" depends on I2C_DW_0 && PCI default 0 config I2C_DW_0_FUNCTION int "PCI function number" depends on I2C_DW_0 && PCI default 0 config I2C_DW_0_BAR int "PCI BAR number" depends on I2C_DW_0 && PCI default 0 config I2C_DW_1 bool "Enable I2C1" default n depends on I2C_DW config I2C_DW_1_BASE hex "Base address for I2C1" default 0x00000000 depends on I2C_DW_1 config I2C_DW_1_NAME string "Select a name for finding the device" depends on I2C_DW_1 default "I2C1" config I2C_DW_1_IRQ int "Controller interrupt" depends on I2C_DW_1 default 0 config I2C_DW_1_INT_PRIORITY int "Controller interrupt priority" depends on I2C_DW_1 default 2 help IRQ priority config I2C_DW_1_DEFAULT_CFG hex "I2C default configuration" depends on I2C_DW_1 default 0x0 help Allows the I2C port to be brought up with a default configuration. This is useful to set if other drivers depend upon using the I2C bus before the application has a chance to custom configure the port. Setting this value does not prohibit the application from customizing the values later. Refer to the I2C datasheet for proper values. config I2C_QUARK_SE_SS bool "Enable I2C Support on Quark SE Sensor Subsystem (SS)" default n depends on SOC_QUARK_SE_SS depends on I2C help This option enables the driver to support the I2C on Quark SE Sensor Subsystem. config I2C_QUARK_SE_SS_0 bool "Enable Quark SE SS I2C Port 0" depends on I2C_QUARK_SE_SS default n config I2C_QUARK_SE_SS_0_BASE hex "Base address for Quark SE SS I2C Port 0" depends on I2C_QUARK_SE_SS_0 default 0x00000000 config I2C_QUARK_SE_SS_0_NAME string "Select a name for finding the device" depends on I2C_QUARK_SE_SS_0 default "I2C_SS_0" config I2C_QUARK_SE_SS_0_DEFAULT_CFG hex "Default Configuration for Quark SE SS I2C Port 0" depends on I2C_QUARK_SE_SS_0 default 0x0 help Allows the I2C port to be brought up with a default configuration. This is useful to set if other drivers depend upon using the I2C bus before the application has a chance to custom configure the port. Setting this value does not prohibit the application from customizing the values later. Refer to the I2C datasheet for proper values. config I2C_QUARK_SE_SS_1 bool "Enable Quark SE SS I2C Port 1" depends on I2C_QUARK_SE_SS default n config I2C_QUARK_SE_SS_1_BASE hex "Base address for Quark SE SS I2C Port 1" depends on I2C_QUARK_SE_SS_1 default 0x00000000 config I2C_QUARK_SE_SS_1_NAME string "Select a name for finding the device" depends on I2C_QUARK_SE_SS_1 default "I2C_SS_1" config I2C_QUARK_SE_SS_1_DEFAULT_CFG hex "Default Configuration for Quark SE SS I2C Port 1" depends on I2C_QUARK_SE_SS_1 default 0x0 help Allows the I2C port to be brought up with a default configuration. This is useful to set if other drivers depend upon using the I2C bus before the application has a chance to custom configure the port. Setting this value does not prohibit the application from customizing the values later. Refer to the I2C datasheet for proper values. config I2C_QMSI bool "QMSI I2C driver" depends on QMSI_DRIVERS && I2C default n help This option enable the QMSI I2C driver. This driver is simply a shim driver based on the I2C driver provided by the QMSI BSP. For more information about QMSI BSP see CONFIG_QMSI_DRIVERS. config I2C_QMSI_0 bool "Enable I2C_0 controller" default n depends on I2C_QMSI config I2C_QMSI_0_NAME string "I2C_0 device name" depends on I2C_QMSI_0 default "I2C0" config I2C_QMSI_0_IRQ int "IRQ number from I2C_0 controller" depends on I2C_QMSI_0 config I2C_QMSI_0_INT_PRIORITY int "Interrupt priority from I2C_0 controller" depends on I2C_QMSI_0 config I2C_QMSI_1 bool "Enable I2C_1 controller" default n depends on I2C_QMSI config I2C_QMSI_1_NAME string "I2C_1 device name" depends on I2C_QMSI_1 default "I2C1" config I2C_QMSI_1_IRQ int "IRQ number from I2C_1 controller" depends on I2C_QMSI_1 config I2C_QMSI_1_INT_PRIORITY int "Interrupt priority from I2C_1 controller" depends on I2C_QMSI_1