mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
mako: initial bring up the mako hardware
support the initial mako hardware. enabled basic power, storage, debug-uart. Change-Id: Ie9f6d5ef1219cb0c3761bb69a3a8fcfdcbb86f19
This commit is contained in:
parent
04f620de39
commit
ea89be9220
30 changed files with 9946 additions and 5 deletions
arch/arm
configs
mach-msm
include/linux
sound/soc/msm
451
arch/arm/configs/mako-perf_defconfig
Executable file
451
arch/arm/configs/mako-perf_defconfig
Executable file
|
@ -0,0 +1,451 @@
|
||||||
|
# CONFIG_ARM_PATCH_PHYS_VIRT is not set
|
||||||
|
CONFIG_EXPERIMENTAL=y
|
||||||
|
CONFIG_LOCALVERSION="-perf"
|
||||||
|
CONFIG_SYSVIPC=y
|
||||||
|
CONFIG_TASKSTATS=y
|
||||||
|
CONFIG_TASK_DELAY_ACCT=y
|
||||||
|
CONFIG_TASK_XACCT=y
|
||||||
|
CONFIG_TASK_IO_ACCOUNTING=y
|
||||||
|
CONFIG_IKCONFIG=y
|
||||||
|
CONFIG_IKCONFIG_PROC=y
|
||||||
|
CONFIG_CGROUPS=y
|
||||||
|
CONFIG_CGROUP_DEBUG=y
|
||||||
|
CONFIG_CGROUP_FREEZER=y
|
||||||
|
CONFIG_CGROUP_CPUACCT=y
|
||||||
|
CONFIG_RESOURCE_COUNTERS=y
|
||||||
|
CONFIG_CGROUP_SCHED=y
|
||||||
|
CONFIG_RT_GROUP_SCHED=y
|
||||||
|
CONFIG_NAMESPACES=y
|
||||||
|
# CONFIG_UTS_NS is not set
|
||||||
|
# CONFIG_IPC_NS is not set
|
||||||
|
# CONFIG_USER_NS is not set
|
||||||
|
# CONFIG_PID_NS is not set
|
||||||
|
# CONFIG_NET_NS is not set
|
||||||
|
CONFIG_BLK_DEV_INITRD=y
|
||||||
|
CONFIG_RD_BZIP2=y
|
||||||
|
CONFIG_RD_LZMA=y
|
||||||
|
CONFIG_CC_OPTIMIZE_FOR_SIZE=y
|
||||||
|
CONFIG_PANIC_TIMEOUT=5
|
||||||
|
CONFIG_KALLSYMS_ALL=y
|
||||||
|
CONFIG_ASHMEM=y
|
||||||
|
CONFIG_EMBEDDED=y
|
||||||
|
CONFIG_PROFILING=y
|
||||||
|
CONFIG_OPROFILE=y
|
||||||
|
CONFIG_KPROBES=y
|
||||||
|
CONFIG_MODULES=y
|
||||||
|
CONFIG_MODULE_UNLOAD=y
|
||||||
|
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||||
|
CONFIG_MODVERSIONS=y
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
|
CONFIG_EFI_PARTITION=y
|
||||||
|
CONFIG_ARCH_MSM=y
|
||||||
|
CONFIG_ARCH_MSM8960=y
|
||||||
|
CONFIG_ARCH_MSM8930=y
|
||||||
|
CONFIG_ARCH_APQ8064=y
|
||||||
|
CONFIG_MSM_KRAIT_TBB_ABORT_HANDLER=y
|
||||||
|
CONFIG_MACH_APQ8064_MTP=y
|
||||||
|
CONFIG_BOARD_HEADER_FILE="mach/lge/board_mako.h"
|
||||||
|
CONFIG_MACH_APQ8064_MAKO=y
|
||||||
|
# CONFIG_MSM_STACKED_MEMORY is not set
|
||||||
|
CONFIG_KERNEL_PMEM_EBI_REGION=y
|
||||||
|
# CONFIG_MSM_FIQ_SUPPORT is not set
|
||||||
|
# CONFIG_MSM_PROC_COMM is not set
|
||||||
|
CONFIG_MSM_SMD=y
|
||||||
|
CONFIG_MSM_SMD_PKG4=y
|
||||||
|
CONFIG_MSM_BAM_DMUX=y
|
||||||
|
CONFIG_MSM_DSPS=y
|
||||||
|
CONFIG_MSM_IPC_ROUTER=y
|
||||||
|
CONFIG_MSM_IPC_ROUTER_SMD_XPRT=y
|
||||||
|
# CONFIG_MSM_HW3D is not set
|
||||||
|
CONFIG_MSM_PIL_QDSP6V4=y
|
||||||
|
CONFIG_MSM_PIL_RIVA=y
|
||||||
|
CONFIG_MSM_PIL_TZAPPS=y
|
||||||
|
CONFIG_MSM_PIL_DSPS=y
|
||||||
|
CONFIG_MSM_PIL_VIDC=y
|
||||||
|
CONFIG_MSM_PIL_GSS=y
|
||||||
|
CONFIG_MSM_SUBSYSTEM_RESTART=y
|
||||||
|
CONFIG_MSM_MODEM_8960=y
|
||||||
|
CONFIG_MSM_LPASS_8960=y
|
||||||
|
CONFIG_MSM_WCNSS_SSR_8960=y
|
||||||
|
CONFIG_MSM_GSS_SSR_8064=y
|
||||||
|
CONFIG_MSM_TZ_LOG=y
|
||||||
|
CONFIG_MSM_RPM_LOG=y
|
||||||
|
CONFIG_MSM_RPM_STATS_LOG=y
|
||||||
|
CONFIG_MSM_BUS_SCALING=y
|
||||||
|
CONFIG_MSM_BUS_RPM_MULTI_TIER_ENABLED=y
|
||||||
|
CONFIG_MSM_WATCHDOG=y
|
||||||
|
CONFIG_MSM_DLOAD_MODE=y
|
||||||
|
CONFIG_MSM_QDSS=y
|
||||||
|
CONFIG_MSM_SLEEP_STATS=y
|
||||||
|
CONFIG_MSM_RTB=y
|
||||||
|
CONFIG_MSM_RTB_SEPARATE_CPUS=y
|
||||||
|
CONFIG_MSM_CACHE_ERP=y
|
||||||
|
CONFIG_MSM_L1_ERR_PANIC=y
|
||||||
|
CONFIG_MSM_L2_ERP_2BIT_PANIC=y
|
||||||
|
CONFIG_MSM_DCVS=y
|
||||||
|
CONFIG_MSM_CACHE_DUMP=y
|
||||||
|
CONFIG_MSM_CACHE_DUMP_ON_PANIC=y
|
||||||
|
CONFIG_MSM_HSIC_SYSMON=y
|
||||||
|
CONFIG_STRICT_MEMORY_RWX=y
|
||||||
|
CONFIG_NO_HZ=y
|
||||||
|
CONFIG_HIGH_RES_TIMERS=y
|
||||||
|
CONFIG_SMP=y
|
||||||
|
# CONFIG_SMP_ON_UP is not set
|
||||||
|
CONFIG_PREEMPT=y
|
||||||
|
CONFIG_AEABI=y
|
||||||
|
CONFIG_HIGHMEM=y
|
||||||
|
CONFIG_VMALLOC_RESERVE=0x19000000
|
||||||
|
CONFIG_COMPACTION=y
|
||||||
|
CONFIG_CC_STACKPROTECTOR=y
|
||||||
|
CONFIG_CP_ACCESS=y
|
||||||
|
CONFIG_CPU_FREQ=y
|
||||||
|
CONFIG_CPU_FREQ_GOV_POWERSAVE=y
|
||||||
|
CONFIG_CPU_FREQ_GOV_USERSPACE=y
|
||||||
|
CONFIG_CPU_FREQ_GOV_ONDEMAND=y
|
||||||
|
CONFIG_CPU_IDLE=y
|
||||||
|
CONFIG_VFP=y
|
||||||
|
CONFIG_NEON=y
|
||||||
|
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||||
|
CONFIG_WAKELOCK=y
|
||||||
|
CONFIG_PM_RUNTIME=y
|
||||||
|
CONFIG_NET=y
|
||||||
|
CONFIG_PACKET=y
|
||||||
|
CONFIG_UNIX=y
|
||||||
|
CONFIG_XFRM_USER=y
|
||||||
|
CONFIG_XFRM_SUB_POLICY=y
|
||||||
|
CONFIG_XFRM_MIGRATE=y
|
||||||
|
CONFIG_XFRM_STATISTICS=y
|
||||||
|
CONFIG_NET_KEY=y
|
||||||
|
CONFIG_INET=y
|
||||||
|
CONFIG_IP_ADVANCED_ROUTER=y
|
||||||
|
CONFIG_IP_MULTIPLE_TABLES=y
|
||||||
|
CONFIG_IP_ROUTE_VERBOSE=y
|
||||||
|
CONFIG_IP_PNP=y
|
||||||
|
CONFIG_IP_PNP_DHCP=y
|
||||||
|
CONFIG_INET_AH=y
|
||||||
|
CONFIG_INET_ESP=y
|
||||||
|
CONFIG_INET_IPCOMP=y
|
||||||
|
# CONFIG_INET_LRO is not set
|
||||||
|
CONFIG_IPV6=y
|
||||||
|
CONFIG_IPV6_PRIVACY=y
|
||||||
|
CONFIG_IPV6_ROUTER_PREF=y
|
||||||
|
CONFIG_IPV6_ROUTE_INFO=y
|
||||||
|
CONFIG_IPV6_OPTIMISTIC_DAD=y
|
||||||
|
CONFIG_INET6_AH=y
|
||||||
|
CONFIG_INET6_ESP=y
|
||||||
|
CONFIG_INET6_IPCOMP=y
|
||||||
|
CONFIG_IPV6_MIP6=y
|
||||||
|
CONFIG_IPV6_MULTIPLE_TABLES=y
|
||||||
|
CONFIG_IPV6_SUBTREES=y
|
||||||
|
CONFIG_NETFILTER=y
|
||||||
|
CONFIG_NF_CONNTRACK=y
|
||||||
|
CONFIG_NF_CONNTRACK_EVENTS=y
|
||||||
|
CONFIG_NF_CT_PROTO_DCCP=y
|
||||||
|
CONFIG_NF_CT_PROTO_SCTP=y
|
||||||
|
CONFIG_NF_CT_PROTO_UDPLITE=y
|
||||||
|
CONFIG_NF_CONNTRACK_AMANDA=y
|
||||||
|
CONFIG_NF_CONNTRACK_FTP=y
|
||||||
|
CONFIG_NF_CONNTRACK_H323=y
|
||||||
|
CONFIG_NF_CONNTRACK_IRC=y
|
||||||
|
CONFIG_NF_CONNTRACK_NETBIOS_NS=y
|
||||||
|
CONFIG_NF_CONNTRACK_PPTP=y
|
||||||
|
CONFIG_NF_CONNTRACK_SANE=y
|
||||||
|
CONFIG_NF_CONNTRACK_SIP=y
|
||||||
|
CONFIG_NF_CONNTRACK_TFTP=y
|
||||||
|
CONFIG_NF_CT_NETLINK=y
|
||||||
|
CONFIG_NETFILTER_TPROXY=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_CLASSIFY=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_CONNMARK=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_MARK=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_NFLOG=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_NFQUEUE=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_TPROXY=y
|
||||||
|
CONFIG_NETFILTER_XT_TARGET_TRACE=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_COMMENT=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_CONNLIMIT=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_CONNMARK=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_CONNTRACK=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_HASHLIMIT=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_HELPER=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_IPRANGE=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_LENGTH=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_LIMIT=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_MAC=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_MARK=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_MULTIPORT=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_POLICY=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_PKTTYPE=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_QTAGUID=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_QUOTA=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_QUOTA2=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_QUOTA2_LOG=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_SOCKET=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_STATE=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_STATISTIC=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_STRING=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_TIME=y
|
||||||
|
CONFIG_NETFILTER_XT_MATCH_U32=y
|
||||||
|
CONFIG_NF_CONNTRACK_IPV4=y
|
||||||
|
CONFIG_IP_NF_IPTABLES=y
|
||||||
|
CONFIG_IP_NF_MATCH_AH=y
|
||||||
|
CONFIG_IP_NF_MATCH_ECN=y
|
||||||
|
CONFIG_IP_NF_MATCH_TTL=y
|
||||||
|
CONFIG_IP_NF_FILTER=y
|
||||||
|
CONFIG_IP_NF_TARGET_REJECT=y
|
||||||
|
CONFIG_IP_NF_TARGET_REJECT_SKERR=y
|
||||||
|
CONFIG_NF_NAT=y
|
||||||
|
CONFIG_IP_NF_TARGET_MASQUERADE=y
|
||||||
|
CONFIG_IP_NF_TARGET_NETMAP=y
|
||||||
|
CONFIG_IP_NF_TARGET_REDIRECT=y
|
||||||
|
CONFIG_IP_NF_MANGLE=y
|
||||||
|
CONFIG_IP_NF_RAW=y
|
||||||
|
CONFIG_IP_NF_ARPTABLES=y
|
||||||
|
CONFIG_IP_NF_ARPFILTER=y
|
||||||
|
CONFIG_IP_NF_ARP_MANGLE=y
|
||||||
|
CONFIG_NF_CONNTRACK_IPV6=y
|
||||||
|
CONFIG_IP6_NF_IPTABLES=y
|
||||||
|
CONFIG_IP6_NF_FILTER=y
|
||||||
|
CONFIG_IP6_NF_TARGET_REJECT=y
|
||||||
|
CONFIG_IP6_NF_TARGET_REJECT_SKERR=y
|
||||||
|
CONFIG_IP6_NF_MANGLE=y
|
||||||
|
CONFIG_IP6_NF_RAW=y
|
||||||
|
CONFIG_L2TP=y
|
||||||
|
CONFIG_NET_SCHED=y
|
||||||
|
CONFIG_NET_SCH_HTB=y
|
||||||
|
CONFIG_NET_SCH_PRIO=y
|
||||||
|
CONFIG_NET_CLS_FW=y
|
||||||
|
CONFIG_NET_CLS_U32=y
|
||||||
|
CONFIG_CLS_U32_MARK=y
|
||||||
|
CONFIG_NET_CLS_FLOW=y
|
||||||
|
CONFIG_NET_EMATCH=y
|
||||||
|
CONFIG_NET_EMATCH_CMP=y
|
||||||
|
CONFIG_NET_EMATCH_NBYTE=y
|
||||||
|
CONFIG_NET_EMATCH_U32=y
|
||||||
|
CONFIG_NET_EMATCH_META=y
|
||||||
|
CONFIG_NET_EMATCH_TEXT=y
|
||||||
|
CONFIG_NET_CLS_ACT=y
|
||||||
|
CONFIG_BT=y
|
||||||
|
CONFIG_BT_RFCOMM=y
|
||||||
|
CONFIG_BT_RFCOMM_TTY=y
|
||||||
|
CONFIG_BT_BNEP=y
|
||||||
|
CONFIG_BT_BNEP_MC_FILTER=y
|
||||||
|
CONFIG_BT_BNEP_PROTO_FILTER=y
|
||||||
|
CONFIG_BT_HIDP=y
|
||||||
|
CONFIG_BT_HCISMD=y
|
||||||
|
CONFIG_CFG80211=m
|
||||||
|
# CONFIG_CFG80211_WEXT is not set
|
||||||
|
CONFIG_RFKILL=y
|
||||||
|
CONFIG_GENLOCK=y
|
||||||
|
CONFIG_GENLOCK_MISCDEVICE=y
|
||||||
|
CONFIG_CONNECTOR=y
|
||||||
|
CONFIG_BLK_DEV_LOOP=y
|
||||||
|
CONFIG_BLK_DEV_RAM=y
|
||||||
|
CONFIG_UID_STAT=y
|
||||||
|
CONFIG_HAPTIC_ISA1200=y
|
||||||
|
CONFIG_PMIC8XXX_VIBRATOR=y
|
||||||
|
CONFIG_QSEECOM=y
|
||||||
|
CONFIG_USB_HSIC_SMSC_HUB=y
|
||||||
|
CONFIG_SCSI=y
|
||||||
|
CONFIG_SCSI_TGT=y
|
||||||
|
CONFIG_BLK_DEV_SD=y
|
||||||
|
CONFIG_CHR_DEV_SG=y
|
||||||
|
CONFIG_CHR_DEV_SCH=y
|
||||||
|
CONFIG_SCSI_MULTI_LUN=y
|
||||||
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
|
CONFIG_SCSI_LOGGING=y
|
||||||
|
CONFIG_SCSI_SCAN_ASYNC=y
|
||||||
|
CONFIG_MD=y
|
||||||
|
CONFIG_BLK_DEV_DM=y
|
||||||
|
CONFIG_DM_CRYPT=y
|
||||||
|
CONFIG_NETDEVICES=y
|
||||||
|
CONFIG_DUMMY=y
|
||||||
|
CONFIG_KS8851=m
|
||||||
|
# CONFIG_MSM_RMNET is not set
|
||||||
|
CONFIG_MSM_RMNET_BAM=y
|
||||||
|
CONFIG_MSM_RMNET_SMUX=y
|
||||||
|
CONFIG_USB_USBNET=y
|
||||||
|
CONFIG_MSM_RMNET_USB=y
|
||||||
|
CONFIG_WCNSS_CORE=y
|
||||||
|
CONFIG_INPUT_EVDEV=y
|
||||||
|
CONFIG_INPUT_EVBUG=m
|
||||||
|
CONFIG_KEYBOARD_GPIO=y
|
||||||
|
CONFIG_KEYBOARD_PMIC8XXX=y
|
||||||
|
CONFIG_INPUT_JOYSTICK=y
|
||||||
|
CONFIG_JOYSTICK_XPAD=y
|
||||||
|
CONFIG_INPUT_TOUCHSCREEN=y
|
||||||
|
CONFIG_INPUT_MISC=y
|
||||||
|
CONFIG_INPUT_PMIC8XXX_PWRKEY=y
|
||||||
|
CONFIG_INPUT_KEYCHORD=y
|
||||||
|
CONFIG_INPUT_UINPUT=y
|
||||||
|
# CONFIG_LEGACY_PTYS is not set
|
||||||
|
CONFIG_N_SMUX=y
|
||||||
|
CONFIG_N_SMUX_LOOPBACK=y
|
||||||
|
CONFIG_SMUX_CTL=y
|
||||||
|
CONFIG_SERIAL_MSM_HS=y
|
||||||
|
CONFIG_SERIAL_MSM_HSL=y
|
||||||
|
CONFIG_SERIAL_MSM_HSL_CONSOLE=y
|
||||||
|
CONFIG_DIAG_CHAR=y
|
||||||
|
CONFIG_HW_RANDOM=y
|
||||||
|
CONFIG_HW_RANDOM_MSM=y
|
||||||
|
CONFIG_I2C=y
|
||||||
|
CONFIG_I2C_CHARDEV=y
|
||||||
|
# CONFIG_I2C_MSM is not set
|
||||||
|
CONFIG_I2C_QUP=y
|
||||||
|
CONFIG_SPI=y
|
||||||
|
CONFIG_SPI_QUP=y
|
||||||
|
CONFIG_SPI_SPIDEV=m
|
||||||
|
CONFIG_SLIMBUS_MSM_CTRL=y
|
||||||
|
CONFIG_DEBUG_GPIO=y
|
||||||
|
CONFIG_GPIO_SYSFS=y
|
||||||
|
CONFIG_GPIO_SX150X=y
|
||||||
|
CONFIG_POWER_SUPPLY=y
|
||||||
|
# CONFIG_BATTERY_MSM is not set
|
||||||
|
CONFIG_ISL9519_CHARGER=y
|
||||||
|
CONFIG_PM8921_CHARGER=y
|
||||||
|
CONFIG_PM8921_BMS=y
|
||||||
|
CONFIG_SENSORS_PM8XXX_ADC=y
|
||||||
|
CONFIG_THERMAL=y
|
||||||
|
CONFIG_THERMAL_TSENS8960=y
|
||||||
|
CONFIG_THERMAL_PM8XXX=y
|
||||||
|
CONFIG_THERMAL_MONITOR=y
|
||||||
|
CONFIG_MFD_PM8921_CORE=y
|
||||||
|
CONFIG_MFD_PM8821_CORE=y
|
||||||
|
CONFIG_MFD_PM8038_CORE=y
|
||||||
|
CONFIG_MFD_PM8XXX_SPK=y
|
||||||
|
CONFIG_MFD_PM8XXX_BATT_ALARM=y
|
||||||
|
CONFIG_WCD9304_CODEC=y
|
||||||
|
CONFIG_WCD9310_CODEC=y
|
||||||
|
CONFIG_REGULATOR_PM8XXX=y
|
||||||
|
CONFIG_REGULATOR_MSM_GPIO=y
|
||||||
|
CONFIG_MEDIA_SUPPORT=y
|
||||||
|
CONFIG_MEDIA_CONTROLLER=y
|
||||||
|
CONFIG_VIDEO_DEV=y
|
||||||
|
CONFIG_VIDEO_V4L2_SUBDEV_API=y
|
||||||
|
# CONFIG_MEDIA_TUNER_CUSTOMISE is not set
|
||||||
|
CONFIG_VIDEO_HELPER_CHIPS_AUTO=y
|
||||||
|
CONFIG_USB_VIDEO_CLASS=y
|
||||||
|
CONFIG_ION=y
|
||||||
|
CONFIG_ION_MSM=y
|
||||||
|
CONFIG_MSM_KGSL=y
|
||||||
|
CONFIG_KGSL_PER_PROCESS_PAGE_TABLE=y
|
||||||
|
CONFIG_MSM_KGSL_PAGE_TABLE_COUNT=24
|
||||||
|
CONFIG_FB=y
|
||||||
|
CONFIG_FB_VIRTUAL=y
|
||||||
|
CONFIG_FB_MSM=y
|
||||||
|
# CONFIG_FB_MSM_BACKLIGHT is not set
|
||||||
|
CONFIG_FB_MSM_LOGO=y
|
||||||
|
CONFIG_FB_MSM_TRIPLE_BUFFER=y
|
||||||
|
CONFIG_FB_MSM_MDP40=y
|
||||||
|
CONFIG_FB_MSM_OVERLAY=y
|
||||||
|
CONFIG_FB_MSM_OVERLAY0_WRITEBACK=y
|
||||||
|
CONFIG_FB_MSM_OVERLAY1_WRITEBACK=y
|
||||||
|
CONFIG_FB_MSM_WRITEBACK_MSM_PANEL=y
|
||||||
|
CONFIG_FB_MSM_LVDS_MIPI_PANEL_DETECT=y
|
||||||
|
CONFIG_FB_MSM_HDMI_MSM_PANEL=y
|
||||||
|
CONFIG_BACKLIGHT_LCD_SUPPORT=y
|
||||||
|
CONFIG_BACKLIGHT_CLASS_DEVICE=y
|
||||||
|
CONFIG_SOUND=y
|
||||||
|
CONFIG_SND=y
|
||||||
|
CONFIG_SND_DYNAMIC_MINORS=y
|
||||||
|
# CONFIG_SND_ARM is not set
|
||||||
|
# CONFIG_SND_SPI is not set
|
||||||
|
CONFIG_SND_USB_AUDIO=y
|
||||||
|
CONFIG_SND_SOC=y
|
||||||
|
CONFIG_SND_SOC_MSM8960=y
|
||||||
|
CONFIG_HID_APPLE=y
|
||||||
|
CONFIG_HID_MAGICMOUSE=y
|
||||||
|
CONFIG_HID_MICROSOFT=y
|
||||||
|
CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
|
||||||
|
CONFIG_USB_SUSPEND=y
|
||||||
|
CONFIG_USB_EHCI_HCD=y
|
||||||
|
CONFIG_USB_EHCI_EHSET=y
|
||||||
|
CONFIG_USB_EHCI_MSM=y
|
||||||
|
CONFIG_USB_EHCI_MSM_HSIC=y
|
||||||
|
CONFIG_USB_ACM=y
|
||||||
|
CONFIG_USB_STORAGE=y
|
||||||
|
CONFIG_USB_STORAGE_DEBUG=y
|
||||||
|
CONFIG_USB_STORAGE_DATAFAB=y
|
||||||
|
CONFIG_USB_STORAGE_FREECOM=y
|
||||||
|
CONFIG_USB_STORAGE_ISD200=y
|
||||||
|
CONFIG_USB_STORAGE_USBAT=y
|
||||||
|
CONFIG_USB_STORAGE_SDDR09=y
|
||||||
|
CONFIG_USB_STORAGE_SDDR55=y
|
||||||
|
CONFIG_USB_STORAGE_JUMPSHOT=y
|
||||||
|
CONFIG_USB_STORAGE_ALAUDA=y
|
||||||
|
CONFIG_USB_STORAGE_ONETOUCH=y
|
||||||
|
CONFIG_USB_STORAGE_KARMA=y
|
||||||
|
CONFIG_USB_STORAGE_CYPRESS_ATACB=y
|
||||||
|
CONFIG_USB_SERIAL=y
|
||||||
|
CONFIG_USB_SERIAL_QUALCOMM=y
|
||||||
|
CONFIG_USB_SERIAL_CSVT=y
|
||||||
|
CONFIG_USB_EHSET_TEST_FIXTURE=y
|
||||||
|
CONFIG_USB_QCOM_DIAG_BRIDGE=y
|
||||||
|
CONFIG_USB_QCOM_MDM_BRIDGE=y
|
||||||
|
CONFIG_USB_GADGET=y
|
||||||
|
CONFIG_USB_GADGET_DEBUG_FILES=y
|
||||||
|
CONFIG_USB_CI13XXX_MSM=y
|
||||||
|
CONFIG_USB_G_ANDROID=y
|
||||||
|
CONFIG_USB_ANDROID_RMNET_CTRL_SMD=y
|
||||||
|
CONFIG_MMC=y
|
||||||
|
CONFIG_MMC_PERF_PROFILING=y
|
||||||
|
CONFIG_MMC_UNSAFE_RESUME=y
|
||||||
|
CONFIG_MMC_CLKGATE=y
|
||||||
|
CONFIG_MMC_PARANOID_SD_INIT=y
|
||||||
|
CONFIG_MMC_BLOCK_MINORS=32
|
||||||
|
# CONFIG_MMC_BLOCK_BOUNCE is not set
|
||||||
|
CONFIG_MMC_MSM=y
|
||||||
|
CONFIG_MMC_MSM_CARD_HW_DETECTION=y
|
||||||
|
CONFIG_MMC_MSM_SDC1_8_BIT_SUPPORT=y
|
||||||
|
# CONFIG_MMC_MSM_SDC2_SUPPORT is not set
|
||||||
|
CONFIG_MMC_MSM_SDC3_SUPPORT=y
|
||||||
|
CONFIG_MMC_MSM_SDC3_WP_SUPPORT=y
|
||||||
|
CONFIG_MMC_MSM_SPS_SUPPORT=y
|
||||||
|
CONFIG_LEDS_PM8XXX=y
|
||||||
|
CONFIG_LEDS_TRIGGERS=y
|
||||||
|
CONFIG_LEDS_TRIGGER_HEARTBEAT=y
|
||||||
|
CONFIG_SWITCH=y
|
||||||
|
CONFIG_RTC_CLASS=y
|
||||||
|
# CONFIG_RTC_DRV_MSM is not set
|
||||||
|
CONFIG_RTC_DRV_PM8XXX=y
|
||||||
|
CONFIG_STAGING=y
|
||||||
|
CONFIG_ANDROID=y
|
||||||
|
CONFIG_ANDROID_BINDER_IPC=y
|
||||||
|
CONFIG_ANDROID_LOGGER=y
|
||||||
|
CONFIG_ANDROID_RAM_CONSOLE=y
|
||||||
|
CONFIG_ANDROID_TIMED_GPIO=y
|
||||||
|
CONFIG_ANDROID_LOW_MEMORY_KILLER=y
|
||||||
|
CONFIG_MSM_SSBI=y
|
||||||
|
CONFIG_SPS=y
|
||||||
|
CONFIG_SPS_SUPPORT_BAMDMA=y
|
||||||
|
CONFIG_MSM_IOMMU=y
|
||||||
|
CONFIG_EXT2_FS=y
|
||||||
|
CONFIG_EXT2_FS_XATTR=y
|
||||||
|
CONFIG_EXT3_FS=y
|
||||||
|
# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
|
||||||
|
CONFIG_EXT4_FS=y
|
||||||
|
CONFIG_FUSE_FS=y
|
||||||
|
CONFIG_VFAT_FS=y
|
||||||
|
CONFIG_TMPFS=y
|
||||||
|
CONFIG_CIFS=y
|
||||||
|
CONFIG_CIFS_XATTR=y
|
||||||
|
CONFIG_CIFS_POSIX=y
|
||||||
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
|
CONFIG_NLS_ASCII=y
|
||||||
|
CONFIG_NLS_ISO8859_1=y
|
||||||
|
CONFIG_NLS_UTF8=y
|
||||||
|
CONFIG_PRINTK_TIME=y
|
||||||
|
CONFIG_MAGIC_SYSRQ=y
|
||||||
|
# CONFIG_SCHED_DEBUG is not set
|
||||||
|
CONFIG_TIMER_STATS=y
|
||||||
|
# CONFIG_DEBUG_PREEMPT is not set
|
||||||
|
CONFIG_DEBUG_INFO=y
|
||||||
|
CONFIG_DEBUG_MEMORY_INIT=y
|
||||||
|
CONFIG_ENABLE_DEFAULT_TRACERS=y
|
||||||
|
CONFIG_DYNAMIC_DEBUG=y
|
||||||
|
CONFIG_DEBUG_USER=y
|
||||||
|
CONFIG_PID_IN_CONTEXTIDR=y
|
||||||
|
CONFIG_CRYPTO_TWOFISH=y
|
||||||
|
CONFIG_CRYPTO_DEV_QCRYPTO=m
|
||||||
|
CONFIG_CRYPTO_DEV_QCE=m
|
||||||
|
CONFIG_CRYPTO_DEV_QCEDEV=m
|
||||||
|
CONFIG_CRC_CCITT=y
|
|
@ -867,6 +867,8 @@ config MACH_FSM9XXX_SURF
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
|
||||||
|
source "arch/arm/mach-msm/lge/Kconfig"
|
||||||
|
|
||||||
config MSM_STACKED_MEMORY
|
config MSM_STACKED_MEMORY
|
||||||
bool "Stacked Memory"
|
bool "Stacked Memory"
|
||||||
default y
|
default y
|
||||||
|
|
|
@ -281,7 +281,9 @@ obj-$(CONFIG_MACH_MSM8930_MTP) += board-8930-all.o board-8930-regulator.o
|
||||||
obj-$(CONFIG_MACH_MSM8930_FLUID) += board-8930-all.o board-8930-regulator.o
|
obj-$(CONFIG_MACH_MSM8930_FLUID) += board-8930-all.o board-8930-regulator.o
|
||||||
obj-$(CONFIG_PM8921_BMS) += bms-batterydata.o bms-batterydata-desay.o
|
obj-$(CONFIG_PM8921_BMS) += bms-batterydata.o bms-batterydata-desay.o
|
||||||
obj-$(CONFIG_MACH_APQ8064_CDP) += board-8064-all.o board-8064-regulator.o
|
obj-$(CONFIG_MACH_APQ8064_CDP) += board-8064-all.o board-8064-regulator.o
|
||||||
|
ifndef CONFIG_MACH_LGE # FIXME: will be fixed
|
||||||
obj-$(CONFIG_MACH_APQ8064_MTP) += board-8064-all.o board-8064-regulator.o
|
obj-$(CONFIG_MACH_APQ8064_MTP) += board-8064-all.o board-8064-regulator.o
|
||||||
|
endif
|
||||||
obj-$(CONFIG_MACH_APQ8064_LIQUID) += board-8064-all.o board-8064-regulator.o
|
obj-$(CONFIG_MACH_APQ8064_LIQUID) += board-8064-all.o board-8064-regulator.o
|
||||||
obj-$(CONFIG_MACH_MPQ8064_HRD) += board-8064-all.o board-8064-regulator.o
|
obj-$(CONFIG_MACH_MPQ8064_HRD) += board-8064-all.o board-8064-regulator.o
|
||||||
obj-$(CONFIG_MACH_MPQ8064_DTV) += board-8064-all.o board-8064-regulator.o
|
obj-$(CONFIG_MACH_MPQ8064_DTV) += board-8064-all.o board-8064-regulator.o
|
||||||
|
@ -300,6 +302,9 @@ obj-$(CONFIG_MACH_SAPPHIRE) += board-sapphire-keypad.o board-sapphire-panel.o
|
||||||
obj-$(CONFIG_MACH_SAPPHIRE) += board-sapphire-mmc.o board-sapphire-wifi.o
|
obj-$(CONFIG_MACH_SAPPHIRE) += board-sapphire-mmc.o board-sapphire-wifi.o
|
||||||
obj-$(CONFIG_MACH_SAPPHIRE) += board-sapphire-rfkill.o msm_vibrator.o
|
obj-$(CONFIG_MACH_SAPPHIRE) += board-sapphire-rfkill.o msm_vibrator.o
|
||||||
|
|
||||||
|
obj-$(CONFIG_MACH_LGE) += board-8960-all.o board-8960-regulator.o
|
||||||
|
obj-$(CONFIG_MACH_LGE) += lge/
|
||||||
|
|
||||||
CFLAGS_msm_vibrator.o += -Idrivers/staging/android
|
CFLAGS_msm_vibrator.o += -Idrivers/staging/android
|
||||||
CFLAGS_board-9615.o += -Idrivers/usb/gadget
|
CFLAGS_board-9615.o += -Idrivers/usb/gadget
|
||||||
|
|
||||||
|
|
9
arch/arm/mach-msm/clock-8960.c
Normal file → Executable file
9
arch/arm/mach-msm/clock-8960.c
Normal file → Executable file
|
@ -5198,13 +5198,13 @@ static struct clk_lookup msm_clocks_8064[] = {
|
||||||
CLK_LOOKUP("core_clk", gp0_clk.c, ""),
|
CLK_LOOKUP("core_clk", gp0_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gp1_clk.c, ""),
|
CLK_LOOKUP("core_clk", gp1_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gp2_clk.c, ""),
|
CLK_LOOKUP("core_clk", gp2_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi1_uart_clk.c, "msm_serial_hsl.1"),
|
CLK_LOOKUP("core_clk", gsbi1_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi2_uart_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi2_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi3_uart_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi3_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi4_uart_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi4_uart_clk.c, "msm_serial_hsl.0"),
|
||||||
CLK_LOOKUP("core_clk", gsbi5_uart_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi5_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi6_uart_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi6_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi7_uart_clk.c, "msm_serial_hsl.0"),
|
CLK_LOOKUP("core_clk", gsbi7_uart_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi1_qup_clk.c, "qup_i2c.0"),
|
CLK_LOOKUP("core_clk", gsbi1_qup_clk.c, "qup_i2c.0"),
|
||||||
CLK_LOOKUP("core_clk", gsbi2_qup_clk.c, ""),
|
CLK_LOOKUP("core_clk", gsbi2_qup_clk.c, ""),
|
||||||
CLK_LOOKUP("core_clk", gsbi3_qup_clk.c, "qup_i2c.3"),
|
CLK_LOOKUP("core_clk", gsbi3_qup_clk.c, "qup_i2c.3"),
|
||||||
|
@ -5246,10 +5246,11 @@ static struct clk_lookup msm_clocks_8064[] = {
|
||||||
CLK_LOOKUP("ce3_core_src_clk", ce3_src_clk.c, "qce.0"),
|
CLK_LOOKUP("ce3_core_src_clk", ce3_src_clk.c, "qce.0"),
|
||||||
CLK_LOOKUP("ce3_core_src_clk", ce3_src_clk.c, "qcrypto.0"),
|
CLK_LOOKUP("ce3_core_src_clk", ce3_src_clk.c, "qcrypto.0"),
|
||||||
CLK_LOOKUP("dma_bam_pclk", dma_bam_p_clk.c, NULL),
|
CLK_LOOKUP("dma_bam_pclk", dma_bam_p_clk.c, NULL),
|
||||||
CLK_LOOKUP("iface_clk", gsbi1_p_clk.c, "msm_serial_hsl.1"),
|
CLK_LOOKUP("iface_clk", gsbi1_p_clk.c, ""),
|
||||||
CLK_LOOKUP("iface_clk", gsbi1_p_clk.c, "qup_i2c.0"),
|
CLK_LOOKUP("iface_clk", gsbi1_p_clk.c, "qup_i2c.0"),
|
||||||
CLK_LOOKUP("iface_clk", gsbi2_p_clk.c, ""),
|
CLK_LOOKUP("iface_clk", gsbi2_p_clk.c, ""),
|
||||||
CLK_LOOKUP("iface_clk", gsbi3_p_clk.c, "qup_i2c.3"),
|
CLK_LOOKUP("iface_clk", gsbi3_p_clk.c, "qup_i2c.3"),
|
||||||
|
CLK_LOOKUP("iface_clk", gsbi4_p_clk.c, "msm_serial_hsl.0"),
|
||||||
CLK_LOOKUP("iface_clk", gsbi4_p_clk.c, "qup_i2c.4"),
|
CLK_LOOKUP("iface_clk", gsbi4_p_clk.c, "qup_i2c.4"),
|
||||||
CLK_LOOKUP("iface_clk", gsbi5_p_clk.c, "spi_qsd.0"),
|
CLK_LOOKUP("iface_clk", gsbi5_p_clk.c, "spi_qsd.0"),
|
||||||
CLK_LOOKUP("iface_clk", gsbi5_p_clk.c, "qup_i2c.5"),
|
CLK_LOOKUP("iface_clk", gsbi5_p_clk.c, "qup_i2c.5"),
|
||||||
|
|
|
@ -49,6 +49,7 @@
|
||||||
|
|
||||||
/* Address of GSBI blocks */
|
/* Address of GSBI blocks */
|
||||||
#define MSM_GSBI1_PHYS 0x12440000
|
#define MSM_GSBI1_PHYS 0x12440000
|
||||||
|
#define MSM_GSBI2_PHYS 0x13440000
|
||||||
#define MSM_GSBI3_PHYS 0x16200000
|
#define MSM_GSBI3_PHYS 0x16200000
|
||||||
#define MSM_GSBI4_PHYS 0x16300000
|
#define MSM_GSBI4_PHYS 0x16300000
|
||||||
#define MSM_GSBI5_PHYS 0x1A200000
|
#define MSM_GSBI5_PHYS 0x1A200000
|
||||||
|
@ -58,10 +59,13 @@
|
||||||
/* GSBI UART devices */
|
/* GSBI UART devices */
|
||||||
#define MSM_UART1DM_PHYS (MSM_GSBI1_PHYS + 0x10000)
|
#define MSM_UART1DM_PHYS (MSM_GSBI1_PHYS + 0x10000)
|
||||||
#define MSM_UART3DM_PHYS (MSM_GSBI3_PHYS + 0x40000)
|
#define MSM_UART3DM_PHYS (MSM_GSBI3_PHYS + 0x40000)
|
||||||
|
#define MSM_UART4DM_PHYS (MSM_GSBI4_PHYS + 0x40000)
|
||||||
|
#define MSM_UART6DM_PHYS (MSM_GSBI6_PHYS + 0x40000)
|
||||||
#define MSM_UART7DM_PHYS (MSM_GSBI7_PHYS + 0x40000)
|
#define MSM_UART7DM_PHYS (MSM_GSBI7_PHYS + 0x40000)
|
||||||
|
|
||||||
/* GSBI QUP devices */
|
/* GSBI QUP devices */
|
||||||
#define MSM_GSBI1_QUP_PHYS (MSM_GSBI1_PHYS + 0x20000)
|
#define MSM_GSBI1_QUP_PHYS (MSM_GSBI1_PHYS + 0x20000)
|
||||||
|
#define MSM_GSBI2_QUP_PHYS (MSM_GSBI2_PHYS + 0x20000)
|
||||||
#define MSM_GSBI3_QUP_PHYS (MSM_GSBI3_PHYS + 0x80000)
|
#define MSM_GSBI3_QUP_PHYS (MSM_GSBI3_PHYS + 0x80000)
|
||||||
#define MSM_GSBI4_QUP_PHYS (MSM_GSBI4_PHYS + 0x80000)
|
#define MSM_GSBI4_QUP_PHYS (MSM_GSBI4_PHYS + 0x80000)
|
||||||
#define MSM_GSBI5_QUP_PHYS (MSM_GSBI5_PHYS + 0x80000)
|
#define MSM_GSBI5_QUP_PHYS (MSM_GSBI5_PHYS + 0x80000)
|
||||||
|
@ -285,6 +289,33 @@ struct platform_device apq8064_device_qup_i2c_gsbi3 = {
|
||||||
.resource = resources_qup_i2c_gsbi3,
|
.resource = resources_qup_i2c_gsbi3,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct resource resources_uart_gsbi4[] = {
|
||||||
|
{
|
||||||
|
.start = GSBI4_UARTDM_IRQ,
|
||||||
|
.end = GSBI4_UARTDM_IRQ,
|
||||||
|
.flags = IORESOURCE_IRQ,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.start = MSM_UART4DM_PHYS,
|
||||||
|
.end = MSM_UART4DM_PHYS + PAGE_SIZE - 1,
|
||||||
|
.name = "uartdm_resource",
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.start = MSM_GSBI4_PHYS,
|
||||||
|
.end = MSM_GSBI4_PHYS + PAGE_SIZE - 1,
|
||||||
|
.name = "gsbi_resource",
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
struct platform_device apq8064_device_uart_gsbi4 = {
|
||||||
|
.name = "msm_serial_hsl",
|
||||||
|
.id = 0,
|
||||||
|
.num_resources = ARRAY_SIZE(resources_uart_gsbi4),
|
||||||
|
.resource = resources_uart_gsbi4,
|
||||||
|
};
|
||||||
|
|
||||||
static struct resource resources_qup_i2c_gsbi4[] = {
|
static struct resource resources_qup_i2c_gsbi4[] = {
|
||||||
{
|
{
|
||||||
.name = "gsbi_qup_i2c_addr",
|
.name = "gsbi_qup_i2c_addr",
|
||||||
|
|
|
@ -84,6 +84,7 @@ extern struct platform_device msm8960_device_ebi1_ch1_erp;
|
||||||
|
|
||||||
extern struct platform_device apq8064_device_uart_gsbi1;
|
extern struct platform_device apq8064_device_uart_gsbi1;
|
||||||
extern struct platform_device apq8064_device_uart_gsbi3;
|
extern struct platform_device apq8064_device_uart_gsbi3;
|
||||||
|
extern struct platform_device apq8064_device_uart_gsbi4;
|
||||||
extern struct platform_device apq8064_device_uart_gsbi7;
|
extern struct platform_device apq8064_device_uart_gsbi7;
|
||||||
extern struct platform_device apq8064_device_qup_i2c_gsbi1;
|
extern struct platform_device apq8064_device_qup_i2c_gsbi1;
|
||||||
extern struct platform_device apq8064_device_qup_i2c_gsbi3;
|
extern struct platform_device apq8064_device_qup_i2c_gsbi3;
|
||||||
|
|
151
arch/arm/mach-msm/include/mach/board_lge.h
Normal file
151
arch/arm/mach-msm/include/mach/board_lge.h
Normal file
|
@ -0,0 +1,151 @@
|
||||||
|
/* arch/arm/mach-msm/include/mach/board_lge.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2007 Google, Inc.
|
||||||
|
* Copyright (c) 2008-2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
* Author: Brian Swetland <swetland@google.com>
|
||||||
|
*
|
||||||
|
* This software is licensed under the terms of the GNU General Public
|
||||||
|
* License version 2, as published by the Free Software Foundation, and
|
||||||
|
* may be copied, distributed, and modified under those terms.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ASM_ARCH_MSM_BOARD_LGE_H
|
||||||
|
#define __ASM_ARCH_MSM_BOARD_LGE_H
|
||||||
|
|
||||||
|
#ifdef CONFIG_ANDROID_RAM_CONSOLE
|
||||||
|
#define LGE_RAM_CONSOLE_SIZE (124*SZ_1K * 2)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_HANDLE_PANIC
|
||||||
|
#define LGE_CRASH_LOG_SIZE (4*SZ_1K)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
HW_REV_EVB1 = 0,
|
||||||
|
HW_REV_EVB2,
|
||||||
|
HW_REV_A,
|
||||||
|
HW_REV_B,
|
||||||
|
HW_REV_C,
|
||||||
|
HW_REV_D,
|
||||||
|
HW_REV_E,
|
||||||
|
HW_REV_F,
|
||||||
|
HW_REV_G,
|
||||||
|
HW_REV_H,
|
||||||
|
HW_REV_1_0,
|
||||||
|
HW_REV_1_1,
|
||||||
|
HW_REV_1_2,
|
||||||
|
HW_REV_MAX
|
||||||
|
} hw_rev_type;
|
||||||
|
|
||||||
|
hw_rev_type lge_get_board_revno(void);
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
/*Classified the ADC value for cable detection */
|
||||||
|
typedef enum {
|
||||||
|
NO_INIT_CABLE = 0,
|
||||||
|
CABLE_MHL_1K,
|
||||||
|
CABLE_U_28P7K,
|
||||||
|
CABLE_28P7K,
|
||||||
|
CABLE_56K,
|
||||||
|
CABLE_100K,
|
||||||
|
CABLE_130K,
|
||||||
|
CABLE_180K,
|
||||||
|
CABLE_200K,
|
||||||
|
CABLE_220K,
|
||||||
|
CABLE_270K,
|
||||||
|
CABLE_330K,
|
||||||
|
CABLE_620K,
|
||||||
|
CABLE_910K,
|
||||||
|
CABLE_NONE
|
||||||
|
} acc_cable_type;
|
||||||
|
|
||||||
|
struct chg_cable_info {
|
||||||
|
acc_cable_type cable_type;
|
||||||
|
unsigned ta_ma;
|
||||||
|
unsigned usb_ma;
|
||||||
|
};
|
||||||
|
|
||||||
|
int lge_pm_get_cable_info(struct chg_cable_info *);
|
||||||
|
void lge_pm_read_cable_info(void);
|
||||||
|
acc_cable_type lge_pm_get_cable_type(void);
|
||||||
|
unsigned lge_pm_get_ta_current(void);
|
||||||
|
unsigned lge_pm_get_usb_current(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM_BATTERY_ID_CHECKER
|
||||||
|
enum {
|
||||||
|
BATT_UNKNOWN,
|
||||||
|
BATT_DS2704_N = 17,
|
||||||
|
BATT_DS2704_L = 32,
|
||||||
|
BATT_ISL6296_N = 73,
|
||||||
|
BATT_ISL6296_L = 94,
|
||||||
|
};
|
||||||
|
extern int lge_battery_info;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_KCAL
|
||||||
|
struct kcal_platform_data {
|
||||||
|
int (*set_values) (int r, int g, int b);
|
||||||
|
int (*get_values) (int *r, int *g, int *b);
|
||||||
|
int (*refresh_display) (void);
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
struct pseudo_batt_info_type {
|
||||||
|
int mode;
|
||||||
|
int id;
|
||||||
|
int therm;
|
||||||
|
int temp;
|
||||||
|
int volt;
|
||||||
|
int capacity;
|
||||||
|
int charging;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
int __init lge_get_uart_mode(void);
|
||||||
|
|
||||||
|
#if defined(CONFIG_LGE_NFC_PN544)
|
||||||
|
void __init lge_add_nfc_devices(void);
|
||||||
|
#endif
|
||||||
|
/* from androidboot.mode */
|
||||||
|
enum lge_boot_mode_type {
|
||||||
|
LGE_BOOT_MODE_NORMAL = 0,
|
||||||
|
LGE_BOOT_MODE_CHARGER,
|
||||||
|
LGE_BOOT_MODE_CHARGERLOGO,
|
||||||
|
LGE_BOOT_MODE_FACTORY,
|
||||||
|
LGE_BOOT_MODE_FACTORY2,
|
||||||
|
LGE_BOOT_MODE_PIFBOOT,
|
||||||
|
LGE_BOOT_MODE_PIFBOOT2,
|
||||||
|
};
|
||||||
|
#ifdef CONFIG_ANDROID_RAM_CONSOLE
|
||||||
|
void __init lge_add_ramconsole_devices(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_HANDLE_PANIC
|
||||||
|
void __init lge_add_panic_handler_devices(void);
|
||||||
|
int lge_get_magic_for_subsystem(void);
|
||||||
|
void lge_set_magic_for_subsystem(const char *subsys_name);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_QFPROM_INTERFACE
|
||||||
|
void __init lge_add_qfprom_devices(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
enum lge_boot_mode_type lge_get_boot_mode(void);
|
||||||
|
int lge_get_factory_boot(void);
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_BOOT_TIME_CHECK
|
||||||
|
void __init lge_add_boot_time_checker(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_ECO_MODE
|
||||||
|
void __init lge_add_lge_kernel_devices(void);
|
||||||
|
#endif
|
||||||
|
#endif // __ASM_ARCH_MSM_BOARD_LGE_H
|
93
arch/arm/mach-msm/include/mach/lge/board_mako.h
Normal file
93
arch/arm/mach-msm/include/mach/lge/board_mako.h
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
/* arch/arm/mach-msm/include/mach/board_mako.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2007 Google, Inc.
|
||||||
|
* Copyright (c) 2008-2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE.
|
||||||
|
* Author: Brian Swetland <swetland@google.com>
|
||||||
|
*
|
||||||
|
* This software is licensed under the terms of the GNU General Public
|
||||||
|
* License version 2, as published by the Free Software Foundation, and
|
||||||
|
* may be copied, distributed, and modified under those terms.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ASM_ARCH_MSM_BOARD_MAKO_H
|
||||||
|
#define __ASM_ARCH_MSM_BOARD_MAKO_H
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
#define ADC_CHANGE_REV HW_REV_EVB1
|
||||||
|
#define IBAT_CURRENT 825
|
||||||
|
|
||||||
|
/* Ref resistance value = 665K */
|
||||||
|
#define ADC_NO_INIT_CABLE 0
|
||||||
|
#define ADC_CABLE_MHL_1K 30000
|
||||||
|
#define ADC_CABLE_U_28P7K 60000
|
||||||
|
#define ADC_CABLE_28P7K 110000
|
||||||
|
#define ADC_CABLE_56K 185000
|
||||||
|
#define ADC_CABLE_100K 265000
|
||||||
|
#define ADC_CABLE_130K 340000
|
||||||
|
#define ADC_CABLE_180K 400000
|
||||||
|
#define ADC_CABLE_200K 431000
|
||||||
|
#define ADC_CABLE_220K 485000
|
||||||
|
#define ADC_CABLE_270K 560000
|
||||||
|
#define ADC_CABLE_330K 735000
|
||||||
|
#define ADC_CABLE_620K 955000
|
||||||
|
#define ADC_CABLE_910K 1140000
|
||||||
|
#define ADC_CABLE_NONE 1800000
|
||||||
|
|
||||||
|
/* Ref resistance value = 200K */
|
||||||
|
#define ADC_NO_INIT_CABLE2 0
|
||||||
|
#define ADC_CABLE_MHL_1K2 50000
|
||||||
|
#define ADC_CABLE_U_28P7K2 200000
|
||||||
|
#define ADC_CABLE_28P7K2 300000
|
||||||
|
#define ADC_CABLE_56K2 490000
|
||||||
|
#define ADC_CABLE_100K2 650000
|
||||||
|
#define ADC_CABLE_130K2 780000
|
||||||
|
#define ADC_CABLE_180K2 875000
|
||||||
|
#define ADC_CABLE_200K2 920000
|
||||||
|
#define ADC_CABLE_220K2 988000
|
||||||
|
#define ADC_CABLE_270K2 1077000
|
||||||
|
#define ADC_CABLE_330K2 1294000
|
||||||
|
#define ADC_CABLE_620K2 1418000
|
||||||
|
#define ADC_CABLE_910K2 1600000
|
||||||
|
#define ADC_CABLE_NONE2 1800000
|
||||||
|
|
||||||
|
#define C_NO_INIT_TA_MA 0
|
||||||
|
#define C_MHL_1K_TA_MA 500
|
||||||
|
#define C_U_28P7K_TA_MA 500
|
||||||
|
#define C_28P7K_TA_MA 500
|
||||||
|
#define C_56K_TA_MA 1500 /* it will be changed in future */
|
||||||
|
#define C_100K_TA_MA 500
|
||||||
|
#define C_130K_TA_MA 1500
|
||||||
|
#define C_180K_TA_MA 700
|
||||||
|
#define C_200K_TA_MA 700
|
||||||
|
#define C_220K_TA_MA 900
|
||||||
|
#define C_270K_TA_MA 800
|
||||||
|
#define C_330K_TA_MA 500
|
||||||
|
#define C_620K_TA_MA 500
|
||||||
|
#define C_910K_TA_MA 1500//[ORG]500
|
||||||
|
#define C_NONE_TA_MA 900 //900mA for open cable
|
||||||
|
|
||||||
|
#define C_NO_INIT_USB_MA 0
|
||||||
|
#define C_MHL_1K_USB_MA 500
|
||||||
|
#define C_U_28P7K_USB_MA 500
|
||||||
|
#define C_28P7K_USB_MA 500
|
||||||
|
#define C_56K_USB_MA 1500 /* it will be changed in future */
|
||||||
|
#define C_100K_USB_MA 500
|
||||||
|
#define C_130K_USB_MA 1500
|
||||||
|
#define C_180K_USB_MA 500
|
||||||
|
#define C_200K_USB_MA 500
|
||||||
|
#define C_220K_USB_MA 500
|
||||||
|
#define C_270K_USB_MA 500
|
||||||
|
#define C_330K_USB_MA 500
|
||||||
|
#define C_620K_USB_MA 500
|
||||||
|
#define C_910K_USB_MA 1500//[ORG]500
|
||||||
|
#define C_NONE_USB_MA 500
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __ASM_ARCH_MSM_BOARD_MAKO_H
|
11
arch/arm/mach-msm/lge/Kconfig
Normal file
11
arch/arm/mach-msm/lge/Kconfig
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
config MACH_LGE
|
||||||
|
bool
|
||||||
|
|
||||||
|
menu "LGE Board Selection"
|
||||||
|
source "arch/arm/mach-msm/lge/Kconfig.board"
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
|
||||||
|
menu "LGE Specific Patches"
|
||||||
|
|
||||||
|
endmenu
|
7
arch/arm/mach-msm/lge/Kconfig.board
Normal file
7
arch/arm/mach-msm/lge/Kconfig.board
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#
|
||||||
|
# Inlcude the specific Kconfig file for LGE board
|
||||||
|
#
|
||||||
|
|
||||||
|
# MAKO
|
||||||
|
source "arch/arm/mach-msm/lge/mako/Kconfig"
|
||||||
|
|
5
arch/arm/mach-msm/lge/Makefile
Normal file
5
arch/arm/mach-msm/lge/Makefile
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
subdir-ccflags-$(CONFIG_ARCH_MSM) += -Iarch/arm/mach-msm
|
||||||
|
|
||||||
|
-include $(src)/Makefile.board
|
||||||
|
|
||||||
|
obj-$(CONFIG_MACH_LGE) += devices_lge.o
|
6
arch/arm/mach-msm/lge/Makefile.board
Normal file
6
arch/arm/mach-msm/lge/Makefile.board
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
#
|
||||||
|
# Makefile for the LGE board
|
||||||
|
#
|
||||||
|
|
||||||
|
# MAKO
|
||||||
|
obj-$(CONFIG_MACH_APQ8064_MAKO) += mako/
|
404
arch/arm/mach-msm/lge/devices_lge.c
Normal file
404
arch/arm/mach-msm/lge/devices_lge.c
Normal file
|
@ -0,0 +1,404 @@
|
||||||
|
/* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/memory.h>
|
||||||
|
|
||||||
|
#include <asm/setup.h>
|
||||||
|
#include <asm/sizes.h>
|
||||||
|
#include <asm/system_info.h>
|
||||||
|
#include <asm/memory.h>
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <mach/board_lge.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
#include CONFIG_BOARD_HEADER_FILE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_BOOT_TIME_CHECK
|
||||||
|
#include "lge_boot_time_checker.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* setting whether uart console is enalbed or disabled */
|
||||||
|
static int uart_console_mode = 0;
|
||||||
|
|
||||||
|
int __init lge_get_uart_mode(void)
|
||||||
|
{
|
||||||
|
return uart_console_mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int __init lge_uart_mode(char *uart_mode)
|
||||||
|
{
|
||||||
|
if (!strncmp("enable", uart_mode, 5)) {
|
||||||
|
printk(KERN_INFO"UART CONSOLE : enable\n");
|
||||||
|
uart_console_mode = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printk(KERN_INFO"UART CONSOLE : disable\n");
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("uart_console=", lge_uart_mode);
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
/* Implement cable detection */
|
||||||
|
struct chg_cable_info_table {
|
||||||
|
int threshhold;
|
||||||
|
acc_cable_type type;
|
||||||
|
unsigned ta_ma;
|
||||||
|
unsigned usb_ma;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* This table is only for J1 */
|
||||||
|
static struct chg_cable_info_table pm8921_acc_cable_type_data[]={
|
||||||
|
{ADC_NO_INIT_CABLE, NO_INIT_CABLE, C_NO_INIT_TA_MA, C_NO_INIT_USB_MA},
|
||||||
|
{ADC_CABLE_MHL_1K, CABLE_MHL_1K, C_MHL_1K_TA_MA, C_MHL_1K_USB_MA},
|
||||||
|
{ADC_CABLE_U_28P7K, CABLE_U_28P7K, C_U_28P7K_TA_MA, C_U_28P7K_USB_MA},
|
||||||
|
{ADC_CABLE_28P7K, CABLE_28P7K, C_28P7K_TA_MA, C_28P7K_USB_MA},
|
||||||
|
{ADC_CABLE_56K, CABLE_56K, C_56K_TA_MA, C_56K_USB_MA},
|
||||||
|
{ADC_CABLE_100K, CABLE_100K, C_100K_TA_MA, C_100K_USB_MA},
|
||||||
|
{ADC_CABLE_130K, CABLE_130K, C_130K_TA_MA, C_130K_USB_MA},
|
||||||
|
{ADC_CABLE_180K, CABLE_180K, C_180K_TA_MA, C_180K_USB_MA},
|
||||||
|
{ADC_CABLE_200K, CABLE_200K, C_200K_TA_MA, C_200K_USB_MA},
|
||||||
|
{ADC_CABLE_220K, CABLE_220K, C_220K_TA_MA, C_220K_USB_MA},
|
||||||
|
{ADC_CABLE_270K, CABLE_270K, C_270K_TA_MA, C_270K_USB_MA},
|
||||||
|
{ADC_CABLE_330K, CABLE_330K, C_330K_TA_MA, C_330K_USB_MA},
|
||||||
|
{ADC_CABLE_620K, CABLE_620K, C_620K_TA_MA, C_620K_USB_MA},
|
||||||
|
{ADC_CABLE_910K, CABLE_910K, C_910K_TA_MA, C_910K_USB_MA},
|
||||||
|
{ADC_CABLE_NONE, CABLE_NONE, C_NONE_TA_MA, C_NONE_USB_MA},
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* for board revision */
|
||||||
|
static hw_rev_type lge_bd_rev = HW_REV_EVB1;
|
||||||
|
|
||||||
|
static int __init board_revno_setup(char *rev_info)
|
||||||
|
{
|
||||||
|
/* CAUTION: These strings are come from LK. */
|
||||||
|
char *rev_str[] = {"evb1", "evb2", "rev_a", "rev_b", "rev_c", "rev_d",
|
||||||
|
"rev_e", "rev_f", "rev_g", "rev_h", "rev_10", "rev_11", "rev_12",
|
||||||
|
"reserved"};
|
||||||
|
int i;
|
||||||
|
|
||||||
|
printk(KERN_INFO "BOARD : LGE input %s \n", rev_info);
|
||||||
|
for (i=0; i< HW_REV_MAX; i++) {
|
||||||
|
if( !strncmp(rev_info, rev_str[i], 6)) {
|
||||||
|
lge_bd_rev = (hw_rev_type) i;
|
||||||
|
system_rev = lge_bd_rev;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
printk(KERN_INFO "BOARD : LGE matched %s \n", rev_str[lge_bd_rev]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("lge.rev=", board_revno_setup);
|
||||||
|
|
||||||
|
hw_rev_type lge_get_board_revno(void)
|
||||||
|
{
|
||||||
|
return lge_bd_rev;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
int lge_pm_get_cable_info(struct chg_cable_info *cable_info)
|
||||||
|
{
|
||||||
|
char *type_str[] = {"NOT INIT", "MHL 1K", "U_28P7K", "28P7K", "56K",
|
||||||
|
"100K", "130K", "180K", "200K", "220K", "270K", "330K", "620K", "910K",
|
||||||
|
"OPEN"};
|
||||||
|
|
||||||
|
struct pm8xxx_adc_chan_result result;
|
||||||
|
struct chg_cable_info *info = cable_info;
|
||||||
|
struct chg_cable_info_table *table;
|
||||||
|
int table_size = ARRAY_SIZE(pm8921_acc_cable_type_data);
|
||||||
|
int acc_read_value = 0;
|
||||||
|
int i, rc;
|
||||||
|
int count = 5;
|
||||||
|
|
||||||
|
if (!info) {
|
||||||
|
pr_err("lge_pm_get_cable_info: invalid info parameters\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < count; i++) {
|
||||||
|
rc = pm8xxx_adc_mpp_config_read(PM8XXX_AMUX_MPP_12,
|
||||||
|
ADC_MPP_1_AMUX6, &result);
|
||||||
|
|
||||||
|
if (rc < 0) {
|
||||||
|
if (rc == -ETIMEDOUT) {
|
||||||
|
/* reason: adc read timeout, assume it is open cable */
|
||||||
|
info->cable_type = CABLE_NONE;
|
||||||
|
info->ta_ma = C_NONE_TA_MA;
|
||||||
|
info->usb_ma = C_NONE_USB_MA;
|
||||||
|
pr_err("[DEBUG] lge_pm_get_cable_info : adc read timeout \n");
|
||||||
|
} else {
|
||||||
|
pr_err("lge_pm_get_cable_info: adc read error - %d\n", rc);
|
||||||
|
}
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
acc_read_value = (int)result.physical;
|
||||||
|
pr_info("%s: acc_read_value - %d\n", __func__, (int)result.physical);
|
||||||
|
mdelay(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
info->cable_type = NO_INIT_CABLE;
|
||||||
|
info->ta_ma = C_NO_INIT_TA_MA;
|
||||||
|
info->usb_ma = C_NO_INIT_USB_MA;
|
||||||
|
|
||||||
|
/* assume: adc value must be existed in ascending order */
|
||||||
|
for (i = 0; i < table_size; i++) {
|
||||||
|
table = &pm8921_acc_cable_type_data[i];
|
||||||
|
|
||||||
|
if (acc_read_value <= table->threshhold) {
|
||||||
|
info->cable_type = table->type;
|
||||||
|
info->ta_ma = table->ta_ma;
|
||||||
|
info->usb_ma = table->usb_ma;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pr_info("\n\n[PM]Cable detected: %d(%s)(%d, %d)\n\n",
|
||||||
|
acc_read_value, type_str[info->cable_type],
|
||||||
|
info->ta_ma, info->usb_ma);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Belows are for using in interrupt context */
|
||||||
|
static struct chg_cable_info lge_cable_info;
|
||||||
|
|
||||||
|
acc_cable_type lge_pm_get_cable_type(void)
|
||||||
|
{
|
||||||
|
return lge_cable_info.cable_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned lge_pm_get_ta_current(void)
|
||||||
|
{
|
||||||
|
return lge_cable_info.ta_ma;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned lge_pm_get_usb_current(void)
|
||||||
|
{
|
||||||
|
return lge_cable_info.usb_ma;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This must be invoked in process context */
|
||||||
|
void lge_pm_read_cable_info(void)
|
||||||
|
{
|
||||||
|
lge_cable_info.cable_type = NO_INIT_CABLE;
|
||||||
|
lge_cable_info.ta_ma = C_NO_INIT_TA_MA;
|
||||||
|
lge_cable_info.usb_ma = C_NO_INIT_USB_MA;
|
||||||
|
|
||||||
|
lge_pm_get_cable_info(&lge_cable_info);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM_BATTERY_ID_CHECKER
|
||||||
|
int lge_battery_info = BATT_UNKNOWN;
|
||||||
|
|
||||||
|
static int __init battery_information_setup(char *batt_info)
|
||||||
|
{
|
||||||
|
if(!strcmp(batt_info, "ds2704_n"))
|
||||||
|
lge_battery_info = BATT_DS2704_N;
|
||||||
|
else if(!strcmp(batt_info, "ds2704_l"))
|
||||||
|
lge_battery_info = BATT_DS2704_L;
|
||||||
|
else if(!strcmp(batt_info, "isl6296_n"))
|
||||||
|
lge_battery_info = BATT_ISL6296_N;
|
||||||
|
else if(!strcmp(batt_info, "isl6296_l"))
|
||||||
|
lge_battery_info = BATT_ISL6296_L;
|
||||||
|
else
|
||||||
|
lge_battery_info = BATT_UNKNOWN;
|
||||||
|
|
||||||
|
printk(KERN_INFO "Battery : %s %d\n", batt_info, lge_battery_info);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("lge.batt_info=", battery_information_setup);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_KCAL
|
||||||
|
int g_kcal_r = 255;
|
||||||
|
int g_kcal_g = 255;
|
||||||
|
int g_kcal_b = 255;
|
||||||
|
static int __init display_kcal_setup(char *kcal)
|
||||||
|
{
|
||||||
|
char vaild_k = 0;
|
||||||
|
sscanf(kcal, "%d|%d|%d|%c", &g_kcal_r, &g_kcal_g, &g_kcal_b, &vaild_k );
|
||||||
|
printk(KERN_INFO "kcal is %d|%d|%d|%c\n",
|
||||||
|
g_kcal_r, g_kcal_g, g_kcal_b, vaild_k);
|
||||||
|
|
||||||
|
if(vaild_k != 'K') {
|
||||||
|
printk(KERN_INFO "kcal not calibrated yet : %d\n", vaild_k);
|
||||||
|
g_kcal_r = g_kcal_g = g_kcal_b = 255;
|
||||||
|
printk(KERN_INFO "set to default : %d\n", g_kcal_r);
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("lge.kcal=", display_kcal_setup);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* get boot mode information from cmdline.
|
||||||
|
* If any boot mode is not specified,
|
||||||
|
* boot mode is normal type.
|
||||||
|
*/
|
||||||
|
static enum lge_boot_mode_type lge_boot_mode = LGE_BOOT_MODE_NORMAL;
|
||||||
|
int __init lge_boot_mode_init(char *s)
|
||||||
|
{
|
||||||
|
if (!strcmp(s, "charger"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_CHARGER;
|
||||||
|
else if (!strcmp(s, "chargerlogo"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_CHARGERLOGO;
|
||||||
|
else if (!strcmp(s, "factory"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_FACTORY;
|
||||||
|
else if (!strcmp(s, "factory2"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_FACTORY2;
|
||||||
|
else if (!strcmp(s, "pifboot"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_PIFBOOT;
|
||||||
|
else if (!strcmp(s, "pifboot2"))
|
||||||
|
lge_boot_mode = LGE_BOOT_MODE_PIFBOOT2;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("androidboot.mode=", lge_boot_mode_init);
|
||||||
|
|
||||||
|
enum lge_boot_mode_type lge_get_boot_mode(void)
|
||||||
|
{
|
||||||
|
return lge_boot_mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
int lge_get_factory_boot(void)
|
||||||
|
{
|
||||||
|
int res;
|
||||||
|
|
||||||
|
/* if boot mode is factory,
|
||||||
|
* cable must be factory cable.
|
||||||
|
*/
|
||||||
|
switch (lge_boot_mode) {
|
||||||
|
case LGE_BOOT_MODE_FACTORY:
|
||||||
|
case LGE_BOOT_MODE_FACTORY2:
|
||||||
|
case LGE_BOOT_MODE_PIFBOOT:
|
||||||
|
case LGE_BOOT_MODE_PIFBOOT2:
|
||||||
|
res = 1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
res = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_ANDROID_RAM_CONSOLE
|
||||||
|
static struct resource ram_console_resource[] = {
|
||||||
|
{
|
||||||
|
.name = "ram_console",
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device ram_console_device = {
|
||||||
|
.name = "ram_console",
|
||||||
|
.id = -1,
|
||||||
|
.num_resources = ARRAY_SIZE(ram_console_resource),
|
||||||
|
.resource = ram_console_resource,
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init lge_add_ramconsole_devices(void)
|
||||||
|
{
|
||||||
|
struct resource* res = ram_console_resource;
|
||||||
|
struct membank* bank = &meminfo.bank[0];
|
||||||
|
|
||||||
|
res->start = PHYS_OFFSET + bank->size;
|
||||||
|
res->end = res->start + LGE_RAM_CONSOLE_SIZE - 1;
|
||||||
|
|
||||||
|
printk(KERN_INFO "RAM CONSOLE START ADDR : %X\n", res->start);
|
||||||
|
printk(KERN_INFO "RAM CONSOLE END ADDR : %X\n", res->end);
|
||||||
|
|
||||||
|
platform_device_register(&ram_console_device);
|
||||||
|
}
|
||||||
|
#endif // CONFIG_ANDROID_RAM_CONSOLE
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_HANDLE_PANIC
|
||||||
|
static struct resource crash_log_resource[] = {
|
||||||
|
{
|
||||||
|
.name = "crash_log",
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device panic_handler_device = {
|
||||||
|
.name = "panic-handler",
|
||||||
|
.num_resources = ARRAY_SIZE(crash_log_resource),
|
||||||
|
.resource = crash_log_resource,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = NULL,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init lge_add_panic_handler_devices(void)
|
||||||
|
{
|
||||||
|
struct resource* res = crash_log_resource;
|
||||||
|
struct membank* bank = &meminfo.bank[0];
|
||||||
|
|
||||||
|
res->start = bank->start + bank->size + LGE_RAM_CONSOLE_SIZE;
|
||||||
|
res->end = res->start + LGE_CRASH_LOG_SIZE - 1;
|
||||||
|
|
||||||
|
printk(KERN_INFO "CRASH LOG START ADDR : %X\n", res->start);
|
||||||
|
printk(KERN_INFO "CRASH LOG END ADDR : %X\n", res->end);
|
||||||
|
|
||||||
|
platform_device_register(&panic_handler_device);
|
||||||
|
}
|
||||||
|
#endif // CONFIG_LGE_HANDLE_PANIC
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_ECO_MODE
|
||||||
|
static struct platform_device lge_kernel_device = {
|
||||||
|
.name = "lge_kernel_driver",
|
||||||
|
.id = -1,
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init lge_add_lge_kernel_devices(void)
|
||||||
|
{
|
||||||
|
platform_device_register(&lge_kernel_device);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_QFPROM_INTERFACE
|
||||||
|
static struct platform_device qfprom_device = {
|
||||||
|
.name = "lge-apq8064-qfprom",
|
||||||
|
.id = -1,
|
||||||
|
};
|
||||||
|
void __init lge_add_qfprom_devices(void)
|
||||||
|
{
|
||||||
|
platform_device_register(&qfprom_device);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_BOOT_TIME_CHECK
|
||||||
|
static struct platform_device boot_time_device = {
|
||||||
|
.name = "boot_time",
|
||||||
|
.id = -1,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = NULL,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
void __init lge_add_boot_time_checker(void)
|
||||||
|
{
|
||||||
|
platform_device_register(&boot_time_device);
|
||||||
|
}
|
||||||
|
#endif
|
10
arch/arm/mach-msm/lge/mako/Kconfig
Normal file
10
arch/arm/mach-msm/lge/mako/Kconfig
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
config BOARD_HEADER_FILE
|
||||||
|
string "LGE board specific header file name"
|
||||||
|
default ""
|
||||||
|
|
||||||
|
config MACH_APQ8064_MAKO
|
||||||
|
depends on ARCH_APQ8064
|
||||||
|
select MACH_LGE
|
||||||
|
bool "MSM8064 MAKO"
|
||||||
|
help
|
||||||
|
Support for the LGE MAKO device.
|
12
arch/arm/mach-msm/lge/mako/Makefile
Normal file
12
arch/arm/mach-msm/lge/mako/Makefile
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
obj-$(CONFIG_MACH_APQ8064_MAKO) += board-mako.o \
|
||||||
|
board-mako-camera.o \
|
||||||
|
board-mako-display.o \
|
||||||
|
board-mako-gpiomux.o \
|
||||||
|
board-mako-gpu.o \
|
||||||
|
board-mako-input.o \
|
||||||
|
board-mako-pmic.o \
|
||||||
|
board-mako-regulator.o \
|
||||||
|
board-mako-misc.o \
|
||||||
|
board-mako-sound.o \
|
||||||
|
board-mako-storage.o \
|
||||||
|
board-mako-nfc.o
|
628
arch/arm/mach-msm/lge/mako/board-mako-camera.c
Normal file
628
arch/arm/mach-msm/lge/mako/board-mako-camera.c
Normal file
|
@ -0,0 +1,628 @@
|
||||||
|
/* Copyright (c) 2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <asm/mach-types.h>
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <mach/board.h>
|
||||||
|
#include <mach/msm_bus_board.h>
|
||||||
|
#include <mach/gpiomux.h>
|
||||||
|
|
||||||
|
#include "devices.h"
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_MSM_CAMERA
|
||||||
|
static struct gpiomux_setting cam_settings[] = {
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_GPIO, /*suspend*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_DOWN,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_1, /*active 1*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_GPIO, /*active 2*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_1, /*active 3*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_4, /*active 4*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_6, /*active 5*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_UP,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_2, /*active 6*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_UP,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_3, /*active 7*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_UP,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_GPIO, /*i2c suspend*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_KEEPER,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_9, /*active 9*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_A, /*active 10*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_6, /*active 11*/
|
||||||
|
.drv = GPIOMUX_DRV_8MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.func = GPIOMUX_FUNC_4, /*active 12*/
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
},
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_gpiomux_config apq8064_cam_common_configs[] = {
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_FLASH_EN, /* 7 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[2],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_MCLK0, /* 5 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[1],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
/* FIXME: for old HW (LGU Rev.A,B VZW Rev.A,B ATT Rev.A) */
|
||||||
|
#if 1
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_MCLK2, /* 2 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[4],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_MCLK1, /* 4 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[1],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM2_RST_N, /* 34 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[2],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM1_RST_N, /* 32 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[2],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[0],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_I2C_SDA, /* 12 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[3],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[8],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpio = GPIO_CAM_I2C_SCL, /* 13 */
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &cam_settings[3],
|
||||||
|
[GPIOMUX_SUSPENDED] = &cam_settings[8],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
#if defined(CONFIG_IMX111) || defined(CONFIG_IMX091)
|
||||||
|
static struct msm_gpiomux_config apq8064_cam_2d_configs[] = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors cam_init_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VFE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VPE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_JPEG_ENC,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors cam_preview_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VFE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 27648000,
|
||||||
|
.ib = 110592000,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VPE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_JPEG_ENC,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors cam_video_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VFE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 140451840,
|
||||||
|
.ib = 561807360,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VPE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 206807040,
|
||||||
|
.ib = 488816640,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_JPEG_ENC,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors cam_snapshot_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VFE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 274423680,
|
||||||
|
.ib = 1097694720,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VPE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_JPEG_ENC,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 540000000,
|
||||||
|
.ib = 1350000000,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors cam_zsl_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VFE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 302071680,
|
||||||
|
.ib = 1812430080,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_VPE,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_JPEG_ENC,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 540000000,
|
||||||
|
.ib = 2025000000,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_paths cam_bus_client_config[] = {
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(cam_init_vectors),
|
||||||
|
cam_init_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(cam_preview_vectors),
|
||||||
|
cam_preview_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(cam_video_vectors),
|
||||||
|
cam_video_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(cam_snapshot_vectors),
|
||||||
|
cam_snapshot_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(cam_zsl_vectors),
|
||||||
|
cam_zsl_vectors,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_scale_pdata cam_bus_client_pdata = {
|
||||||
|
cam_bus_client_config,
|
||||||
|
ARRAY_SIZE(cam_bus_client_config),
|
||||||
|
.name = "msm_camera",
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_device_platform_data msm_camera_csi_device_data[] = {
|
||||||
|
{
|
||||||
|
.csid_core = 0,
|
||||||
|
.is_csiphy = 1,
|
||||||
|
.is_csid = 1,
|
||||||
|
.is_ispif = 1,
|
||||||
|
.is_vpe = 1,
|
||||||
|
.cam_bus_scale_table = &cam_bus_client_pdata,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.csid_core = 1,
|
||||||
|
.is_csiphy = 1,
|
||||||
|
.is_csid = 1,
|
||||||
|
.is_ispif = 1,
|
||||||
|
.is_vpe = 1,
|
||||||
|
.cam_bus_scale_table = &cam_bus_client_pdata,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
static struct camera_vreg_t apq_8064_back_cam_vreg[] = {
|
||||||
|
{"cam1_vdig", REG_LDO, 1200000, 1200000, 105000},
|
||||||
|
{"cam1_vio", REG_VS, 0, 0, 0},
|
||||||
|
{"cam1_vana", REG_LDO, 2850000, 2850000, 85600},
|
||||||
|
#if defined(CONFIG_IMX111) || defined(CONFIG_IMX091)
|
||||||
|
{"cam1_vaf", REG_LDO, 2800000, 2800000, 300000},
|
||||||
|
#else
|
||||||
|
{"cam1_vaf", REG_LDO, 1800000, 1800000, 150000},
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX119
|
||||||
|
static struct camera_vreg_t apq_8064_front_cam_vreg[] = {
|
||||||
|
{"cam2_vio", REG_VS, 0, 0, 0},
|
||||||
|
{"cam2_vana", REG_LDO, 2800000, 2850000, 85600},
|
||||||
|
{"cam2_vdig", REG_LDO, 1200000, 1200000, 105000},
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_IMX111) || defined(CONFIG_IMX091)
|
||||||
|
static struct gpio apq8064_common_cam_gpio[] = {
|
||||||
|
{12, GPIOF_DIR_IN, "CAMIF_I2C_DATA"},
|
||||||
|
{13, GPIOF_DIR_IN, "CAMIF_I2C_CLK"},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct gpio apq8064_back_cam_gpio[] = {
|
||||||
|
{GPIO_CAM_MCLK0, GPIOF_DIR_IN, "CAMIF_MCLK"},
|
||||||
|
{GPIO_CAM1_RST_N, GPIOF_DIR_OUT, "CAM_RESET"},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_gpio_set_tbl apq8064_back_cam_gpio_set_tbl[] = {
|
||||||
|
{GPIO_CAM1_RST_N, GPIOF_OUT_INIT_LOW, 10000},
|
||||||
|
{GPIO_CAM1_RST_N, GPIOF_OUT_INIT_HIGH, 10000},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_gpio_conf apq8064_back_cam_gpio_conf = {
|
||||||
|
.cam_gpiomux_conf_tbl = apq8064_cam_2d_configs,
|
||||||
|
.cam_gpiomux_conf_tbl_size = ARRAY_SIZE(apq8064_cam_2d_configs),
|
||||||
|
.cam_gpio_common_tbl = apq8064_common_cam_gpio,
|
||||||
|
.cam_gpio_common_tbl_size = ARRAY_SIZE(apq8064_common_cam_gpio),
|
||||||
|
.cam_gpio_req_tbl = apq8064_back_cam_gpio,
|
||||||
|
.cam_gpio_req_tbl_size = ARRAY_SIZE(apq8064_back_cam_gpio),
|
||||||
|
.cam_gpio_set_tbl = apq8064_back_cam_gpio_set_tbl,
|
||||||
|
.cam_gpio_set_tbl_size = ARRAY_SIZE(apq8064_back_cam_gpio_set_tbl),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX119
|
||||||
|
static struct gpio apq8064_front_cam_gpio[] = {
|
||||||
|
/* FIXME: for old HW (LGU Rev.A,B VZW Rev.A,B ATT Rev.A) */
|
||||||
|
#if 1
|
||||||
|
{GPIO_CAM_MCLK2, GPIOF_DIR_IN, "CAMIF_MCLK"},
|
||||||
|
#else
|
||||||
|
{GPIO_CAM_MCLK1, GPIOF_DIR_IN, "CAMIF_MCLK"},
|
||||||
|
#endif
|
||||||
|
{GPIO_CAM2_RST_N, GPIOF_DIR_OUT, "CAM_RESET"},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_gpio_set_tbl apq8064_front_cam_gpio_set_tbl[] = {
|
||||||
|
{GPIO_CAM2_RST_N, GPIOF_OUT_INIT_LOW, 10000},
|
||||||
|
{GPIO_CAM2_RST_N, GPIOF_OUT_INIT_HIGH, 10000},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_gpio_conf apq8064_front_cam_gpio_conf = {
|
||||||
|
.cam_gpiomux_conf_tbl = apq8064_cam_2d_configs,
|
||||||
|
.cam_gpiomux_conf_tbl_size = ARRAY_SIZE(apq8064_cam_2d_configs),
|
||||||
|
.cam_gpio_common_tbl = apq8064_common_cam_gpio,
|
||||||
|
.cam_gpio_common_tbl_size = ARRAY_SIZE(apq8064_common_cam_gpio),
|
||||||
|
.cam_gpio_req_tbl = apq8064_front_cam_gpio,
|
||||||
|
.cam_gpio_req_tbl_size = ARRAY_SIZE(apq8064_front_cam_gpio),
|
||||||
|
.cam_gpio_set_tbl = apq8064_front_cam_gpio_set_tbl,
|
||||||
|
.cam_gpio_set_tbl_size = ARRAY_SIZE(apq8064_front_cam_gpio_set_tbl),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (CONFIG_IMX091) || defined (CONFIG_IMX111)
|
||||||
|
static struct msm_camera_i2c_conf apq8064_back_cam_i2c_conf = {
|
||||||
|
.use_i2c_mux = 1,
|
||||||
|
.mux_dev = &msm8960_device_i2c_mux_gsbi4,
|
||||||
|
.i2c_mux_mode = MODE_L,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_IMX111_ACT
|
||||||
|
static struct i2c_board_info msm_act_main_cam_i2c_info = {
|
||||||
|
I2C_BOARD_INFO("msm_actuator", I2C_SLAVE_ADDR_IMX111_ACT),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_actuator_info msm_act_main_cam_0_info = {
|
||||||
|
.board_info = &msm_act_main_cam_i2c_info,
|
||||||
|
.cam_name = MSM_ACTUATOR_MAIN_CAM_1,
|
||||||
|
.bus_id = APQ_8064_GSBI4_QUP_I2C_BUS_ID,
|
||||||
|
.vcm_pwd = 0,
|
||||||
|
.vcm_enable = 0,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX111
|
||||||
|
static struct msm_camera_sensor_flash_data flash_imx111 = {
|
||||||
|
.flash_type = MSM_CAMERA_FLASH_LED,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_csi_lane_params imx111_csi_lane_params = {
|
||||||
|
.csi_lane_assign = 0xE4,
|
||||||
|
.csi_lane_mask = 0xF,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_platform_info sensor_board_info_imx111 = {
|
||||||
|
.mount_angle = 90,
|
||||||
|
.cam_vreg = apq_8064_back_cam_vreg,
|
||||||
|
.num_vreg = ARRAY_SIZE(apq_8064_back_cam_vreg),
|
||||||
|
.gpio_conf = &apq8064_back_cam_gpio_conf,
|
||||||
|
.i2c_conf = &apq8064_back_cam_i2c_conf,
|
||||||
|
.csi_lane_params = &imx111_csi_lane_params,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_info msm_camera_sensor_imx111_data = {
|
||||||
|
.sensor_name = "imx111",
|
||||||
|
.pdata = &msm_camera_csi_device_data[0],
|
||||||
|
.flash_data = &flash_imx111,
|
||||||
|
.sensor_platform_info = &sensor_board_info_imx111,
|
||||||
|
.csi_if = 1,
|
||||||
|
.camera_type = BACK_CAMERA_2D,
|
||||||
|
.sensor_type = BAYER_SENSOR,
|
||||||
|
#ifdef CONFIG_IMX111_ACT
|
||||||
|
.actuator_info = &msm_act_main_cam_0_info,
|
||||||
|
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX091_ACT
|
||||||
|
static struct i2c_board_info msm_act_main_cam_i2c_info = {
|
||||||
|
I2C_BOARD_INFO("msm_actuator", I2C_SLAVE_ADDR_IMX091_ACT), /* 0x18 */
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_actuator_info msm_act_main_cam_0_info = {
|
||||||
|
.board_info = &msm_act_main_cam_i2c_info,
|
||||||
|
.cam_name = MSM_ACTUATOR_MAIN_CAM_1,
|
||||||
|
.bus_id = APQ_8064_GSBI4_QUP_I2C_BUS_ID,
|
||||||
|
.vcm_pwd = 0,
|
||||||
|
.vcm_enable = 0,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_IMX091
|
||||||
|
static struct msm_camera_sensor_flash_data flash_imx091 = {
|
||||||
|
.flash_type = MSM_CAMERA_FLASH_LED,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_csi_lane_params imx091_csi_lane_params = {
|
||||||
|
.csi_lane_assign = 0xE4,
|
||||||
|
.csi_lane_mask = 0xF,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_platform_info sensor_board_info_imx091 = {
|
||||||
|
.mount_angle = 90,
|
||||||
|
.cam_vreg = apq_8064_back_cam_vreg,
|
||||||
|
.num_vreg = ARRAY_SIZE(apq_8064_back_cam_vreg),
|
||||||
|
.gpio_conf = &apq8064_back_cam_gpio_conf,
|
||||||
|
.i2c_conf = &apq8064_back_cam_i2c_conf,
|
||||||
|
.csi_lane_params = &imx091_csi_lane_params,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info imx091_eeprom_i2c_info = {
|
||||||
|
I2C_BOARD_INFO("imx091_eeprom", 0x21),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_eeprom_info imx091_eeprom_info = {
|
||||||
|
.board_info = &imx091_eeprom_i2c_info,
|
||||||
|
.bus_id = APQ_8064_GSBI4_QUP_I2C_BUS_ID,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_info msm_camera_sensor_imx091_data = {
|
||||||
|
.sensor_name = "imx091",
|
||||||
|
.pdata = &msm_camera_csi_device_data[0],
|
||||||
|
.flash_data = &flash_imx091,
|
||||||
|
.sensor_platform_info = &sensor_board_info_imx091,
|
||||||
|
.csi_if = 1,
|
||||||
|
.camera_type = BACK_CAMERA_2D,
|
||||||
|
.sensor_type = BAYER_SENSOR,
|
||||||
|
#ifdef CONFIG_IMX091_ACT
|
||||||
|
.actuator_info = &msm_act_main_cam_0_info,
|
||||||
|
#endif
|
||||||
|
.eeprom_info = &imx091_eeprom_info,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX119
|
||||||
|
static struct msm_camera_i2c_conf apq8064_front_cam_i2c_conf = {
|
||||||
|
.use_i2c_mux = 1,
|
||||||
|
.mux_dev = &msm8960_device_i2c_mux_gsbi4,
|
||||||
|
.i2c_mux_mode = MODE_L,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_IMX119
|
||||||
|
static struct msm_camera_sensor_flash_data flash_imx119 = {
|
||||||
|
.flash_type = MSM_CAMERA_FLASH_NONE,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_csi_lane_params imx119_csi_lane_params = {
|
||||||
|
.csi_lane_assign = 0xE4,
|
||||||
|
.csi_lane_mask = 0x1,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_platform_info sensor_board_info_imx119 = {
|
||||||
|
.mount_angle = 270,
|
||||||
|
.cam_vreg = apq_8064_front_cam_vreg,
|
||||||
|
.num_vreg = ARRAY_SIZE(apq_8064_front_cam_vreg),
|
||||||
|
.gpio_conf = &apq8064_front_cam_gpio_conf,
|
||||||
|
.i2c_conf = &apq8064_front_cam_i2c_conf,
|
||||||
|
.csi_lane_params = &imx119_csi_lane_params,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_camera_sensor_info msm_camera_sensor_imx119_data = {
|
||||||
|
.sensor_name = "imx119",
|
||||||
|
.pdata = &msm_camera_csi_device_data[1],
|
||||||
|
.flash_data = &flash_imx119,
|
||||||
|
.sensor_platform_info = &sensor_board_info_imx119,
|
||||||
|
.csi_if = 1,
|
||||||
|
.camera_type = FRONT_CAMERA_2D,
|
||||||
|
.sensor_type = BAYER_SENSOR,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enabling flash LED for camera */
|
||||||
|
struct led_flash_platform_data {
|
||||||
|
unsigned gpio_en;
|
||||||
|
unsigned scl_gpio;
|
||||||
|
unsigned sda_gpio;
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct led_flash_platform_data lm3559_flash_pdata[] = {
|
||||||
|
{
|
||||||
|
.scl_gpio = GPIO_CAM_FLASH_I2C_SCL,
|
||||||
|
.sda_gpio = GPIO_CAM_FLASH_I2C_SDA,
|
||||||
|
.gpio_en = GPIO_CAM_FLASH_EN,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device msm_camera_server = {
|
||||||
|
.name = "msm_cam_server",
|
||||||
|
.id = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init apq8064_init_cam(void)
|
||||||
|
{
|
||||||
|
msm_gpiomux_install(apq8064_cam_common_configs,
|
||||||
|
ARRAY_SIZE(apq8064_cam_common_configs));
|
||||||
|
|
||||||
|
platform_device_register(&msm_camera_server);
|
||||||
|
platform_device_register(&msm8960_device_i2c_mux_gsbi4);
|
||||||
|
platform_device_register(&msm8960_device_csiphy0);
|
||||||
|
platform_device_register(&msm8960_device_csiphy1);
|
||||||
|
platform_device_register(&msm8960_device_csid0);
|
||||||
|
platform_device_register(&msm8960_device_csid1);
|
||||||
|
platform_device_register(&msm8960_device_ispif);
|
||||||
|
platform_device_register(&msm8960_device_vfe);
|
||||||
|
platform_device_register(&msm8960_device_vpe);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_I2C
|
||||||
|
static struct i2c_board_info apq8064_camera_i2c_boardinfo[] = {
|
||||||
|
#ifdef CONFIG_IMX111
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("imx111", I2C_SLAVE_ADDR_IMX111), /* 0x0D */
|
||||||
|
.platform_data = &msm_camera_sensor_imx111_data,
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_IMX091
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("imx091", I2C_SLAVE_ADDR_IMX091), /* 0x0D */
|
||||||
|
.platform_data = &msm_camera_sensor_imx091_data,
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_IMX119
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("imx119", I2C_SLAVE_ADDR_IMX119), /* 0x6E */
|
||||||
|
.platform_data = &msm_camera_sensor_imx119_data,
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Enabling flash LED for camera */
|
||||||
|
static struct i2c_board_info apq8064_lge_camera_i2c_boardinfo[] = {
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("lm3559", I2C_SLAVE_ADDR_FLASH),
|
||||||
|
.platform_data = &lm3559_flash_pdata,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
struct msm_camera_board_info apq8064_camera_board_info = {
|
||||||
|
.board_info = apq8064_camera_i2c_boardinfo,
|
||||||
|
.num_i2c_board_info = ARRAY_SIZE(apq8064_camera_i2c_boardinfo),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Enabling flash LED for camera */
|
||||||
|
struct msm_camera_board_info apq8064_lge_camera_board_info = {
|
||||||
|
.board_info = apq8064_lge_camera_i2c_boardinfo,
|
||||||
|
.num_i2c_board_info = ARRAY_SIZE(apq8064_lge_camera_i2c_boardinfo),
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
1354
arch/arm/mach-msm/lge/mako/board-mako-display.c
Normal file
1354
arch/arm/mach-msm/lge/mako/board-mako-display.c
Normal file
File diff suppressed because it is too large
Load diff
1047
arch/arm/mach-msm/lge/mako/board-mako-gpiomux.c
Normal file
1047
arch/arm/mach-msm/lge/mako/board-mako-gpiomux.c
Normal file
File diff suppressed because it is too large
Load diff
252
arch/arm/mach-msm/lge/mako/board-mako-gpu.c
Normal file
252
arch/arm/mach-msm/lge/mako/board-mako-gpu.c
Normal file
|
@ -0,0 +1,252 @@
|
||||||
|
/* Copyright (c) 2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/msm_kgsl.h>
|
||||||
|
#include <mach/msm_bus_board.h>
|
||||||
|
#include <mach/board.h>
|
||||||
|
#include <mach/msm_dcvs.h>
|
||||||
|
|
||||||
|
#include "devices.h"
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_MSM_DCVS
|
||||||
|
static struct msm_dcvs_freq_entry grp3d_freq[] = {
|
||||||
|
{0, 0, 333932},
|
||||||
|
{0, 0, 497532},
|
||||||
|
{0, 0, 707610},
|
||||||
|
{0, 0, 844545},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_dcvs_core_info grp3d_core_info = {
|
||||||
|
.freq_tbl = &grp3d_freq[0],
|
||||||
|
.core_param = {
|
||||||
|
.max_time_us = 100000,
|
||||||
|
.num_freq = ARRAY_SIZE(grp3d_freq),
|
||||||
|
},
|
||||||
|
.algo_param = {
|
||||||
|
.slack_time_us = 39000,
|
||||||
|
.disable_pc_threshold = 86000,
|
||||||
|
.ss_window_size = 1000000,
|
||||||
|
.ss_util_pct = 95,
|
||||||
|
.em_max_util_pct = 97,
|
||||||
|
.ss_iobusy_conv = 100,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#endif /* CONFIG_MSM_DCVS */
|
||||||
|
|
||||||
|
#ifdef CONFIG_MSM_BUS_SCALING
|
||||||
|
static struct msm_bus_vectors grp3d_init_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D_PORT1,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = 0,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors grp3d_low_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(1000),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D_PORT1,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(1000),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors grp3d_nominal_low_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(2000),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D_PORT1,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(2000),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors grp3d_nominal_high_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(3200),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D_PORT1,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(3200),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_vectors grp3d_max_vectors[] = {
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(4264),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.src = MSM_BUS_MASTER_GRAPHICS_3D_PORT1,
|
||||||
|
.dst = MSM_BUS_SLAVE_EBI_CH0,
|
||||||
|
.ab = 0,
|
||||||
|
.ib = KGSL_CONVERT_TO_MBPS(4264),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_paths grp3d_bus_scale_usecases[] = {
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(grp3d_init_vectors),
|
||||||
|
grp3d_init_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(grp3d_low_vectors),
|
||||||
|
grp3d_low_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(grp3d_nominal_low_vectors),
|
||||||
|
grp3d_nominal_low_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(grp3d_nominal_high_vectors),
|
||||||
|
grp3d_nominal_high_vectors,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ARRAY_SIZE(grp3d_max_vectors),
|
||||||
|
grp3d_max_vectors,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_bus_scale_pdata grp3d_bus_scale_pdata = {
|
||||||
|
grp3d_bus_scale_usecases,
|
||||||
|
ARRAY_SIZE(grp3d_bus_scale_usecases),
|
||||||
|
.name = "grp3d",
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct resource kgsl_3d0_resources[] = {
|
||||||
|
{
|
||||||
|
.name = KGSL_3D0_REG_MEMORY,
|
||||||
|
.start = 0x04300000, /* GFX3D address */
|
||||||
|
.end = 0x0431ffff,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.name = KGSL_3D0_IRQ,
|
||||||
|
.start = GFX3D_IRQ,
|
||||||
|
.end = GFX3D_IRQ,
|
||||||
|
.flags = IORESOURCE_IRQ,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct kgsl_iommu_ctx kgsl_3d0_iommu0_ctxs[] = {
|
||||||
|
{ "gfx3d_user", 0 },
|
||||||
|
{ "gfx3d_priv", 1 },
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct kgsl_iommu_ctx kgsl_3d0_iommu1_ctxs[] = {
|
||||||
|
{ "gfx3d1_user", 0 },
|
||||||
|
{ "gfx3d1_priv", 1 },
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct kgsl_device_iommu_data kgsl_3d0_iommu_data[] = {
|
||||||
|
{
|
||||||
|
.iommu_ctxs = kgsl_3d0_iommu0_ctxs,
|
||||||
|
.iommu_ctx_count = ARRAY_SIZE(kgsl_3d0_iommu0_ctxs),
|
||||||
|
.physstart = 0x07C00000,
|
||||||
|
.physend = 0x07C00000 + SZ_1M - 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.iommu_ctxs = kgsl_3d0_iommu1_ctxs,
|
||||||
|
.iommu_ctx_count = ARRAY_SIZE(kgsl_3d0_iommu1_ctxs),
|
||||||
|
.physstart = 0x07D00000,
|
||||||
|
.physend = 0x07D00000 + SZ_1M - 1,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct kgsl_device_platform_data kgsl_3d0_pdata = {
|
||||||
|
.pwrlevel = {
|
||||||
|
{
|
||||||
|
.gpu_freq = 400000000,
|
||||||
|
.bus_freq = 4,
|
||||||
|
.io_fraction = 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpu_freq = 325000000,
|
||||||
|
.bus_freq = 3,
|
||||||
|
.io_fraction = 33,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpu_freq = 200000000,
|
||||||
|
.bus_freq = 2,
|
||||||
|
.io_fraction = 100,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpu_freq = 128000000,
|
||||||
|
.bus_freq = 1,
|
||||||
|
.io_fraction = 100,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.gpu_freq = 27000000,
|
||||||
|
.bus_freq = 0,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
.init_level = 1,
|
||||||
|
.num_levels = 5,
|
||||||
|
.set_grp_async = NULL,
|
||||||
|
.idle_timeout = HZ/10,
|
||||||
|
.nap_allowed = true,
|
||||||
|
.clk_map = KGSL_CLK_CORE | KGSL_CLK_IFACE | KGSL_CLK_MEM_IFACE,
|
||||||
|
#ifdef CONFIG_MSM_BUS_SCALING
|
||||||
|
.bus_scale_table = &grp3d_bus_scale_pdata,
|
||||||
|
#endif
|
||||||
|
.iommu_data = kgsl_3d0_iommu_data,
|
||||||
|
.iommu_count = ARRAY_SIZE(kgsl_3d0_iommu_data),
|
||||||
|
#ifdef CONFIG_MSM_DCVS
|
||||||
|
.core_info = &grp3d_core_info,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
struct platform_device device_kgsl_3d0 = {
|
||||||
|
.name = "kgsl-3d0",
|
||||||
|
.id = 0,
|
||||||
|
.num_resources = ARRAY_SIZE(kgsl_3d0_resources),
|
||||||
|
.resource = kgsl_3d0_resources,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &kgsl_3d0_pdata,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init apq8064_init_gpu(void)
|
||||||
|
{
|
||||||
|
platform_device_register(&device_kgsl_3d0);
|
||||||
|
}
|
310
arch/arm/mach-msm/lge/mako/board-mako-input.c
Normal file
310
arch/arm/mach-msm/lge/mako/board-mako-input.c
Normal file
|
@ -0,0 +1,310 @@
|
||||||
|
/* Copyright (c) 2009-2010, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||||||
|
* 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/gpio_event.h>
|
||||||
|
|
||||||
|
#include <mach/vreg.h>
|
||||||
|
#include <mach/rpc_server_handset.h>
|
||||||
|
#include <mach/board.h>
|
||||||
|
|
||||||
|
/* keypad */
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
|
||||||
|
/* i2c */
|
||||||
|
#include <linux/regulator/consumer.h>
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4
|
||||||
|
#include <linux/input/touch_synaptics_rmi4_i2c.h>
|
||||||
|
#include <linux/input/lge_touch_core.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <mach/board_lge.h>
|
||||||
|
#ifdef CONFIG_TOUCHSCREEN_MMS136
|
||||||
|
#include <linux/i2c/melfas_ts.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_RMI4_I2C)
|
||||||
|
#include <linux/rmi.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
/* TOUCH GPIOS */
|
||||||
|
#define SYNAPTICS_TS_I2C_SDA 8
|
||||||
|
#define SYNAPTICS_TS_I2C_SCL 9
|
||||||
|
#define SYNAPTICS_TS_I2C_INT_GPIO 6
|
||||||
|
#define TOUCH_RESET 33
|
||||||
|
|
||||||
|
#define TOUCH_FW_VERSION 1
|
||||||
|
|
||||||
|
/* touch screen device */
|
||||||
|
#define APQ8064_GSBI3_QUP_I2C_BUS_ID 3
|
||||||
|
|
||||||
|
#if defined(CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4)
|
||||||
|
int synaptics_t1320_power_on(int on)
|
||||||
|
{
|
||||||
|
int rc = -EINVAL;
|
||||||
|
static struct regulator *vreg_l15;
|
||||||
|
static struct regulator *vreg_l22;
|
||||||
|
|
||||||
|
vreg_l15 = regulator_get(NULL, "8921_l15"); //3.3V_TOUCH_VDD, VREG_L15: 2.75 ~ 3.3
|
||||||
|
if (IS_ERR(vreg_l15)) {
|
||||||
|
pr_err("%s: regulator get of 8921_l15 failed (%ld)\n", __func__,
|
||||||
|
PTR_ERR(vreg_l15));
|
||||||
|
rc = PTR_ERR(vreg_l15);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
vreg_l22 = regulator_get(NULL, "8921_l22"); //1.8V_TOUCH_IO, VREG_L22: 1.7 ~ 2.85
|
||||||
|
if (IS_ERR(vreg_l22)) {
|
||||||
|
pr_err("%s: regulator get of 8921_l22 failed (%ld)\n", __func__,
|
||||||
|
PTR_ERR(vreg_l22));
|
||||||
|
rc = PTR_ERR(vreg_l22);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = regulator_set_voltage(vreg_l15, 3300000, 3300000);
|
||||||
|
rc = regulator_set_voltage(vreg_l22, 1800000, 1800000);
|
||||||
|
|
||||||
|
if (on) {
|
||||||
|
printk("[Touch D]touch enable\n");
|
||||||
|
regulator_enable(vreg_l15);
|
||||||
|
regulator_enable(vreg_l22);
|
||||||
|
} else {
|
||||||
|
printk("[Touch D]touch disable\n");
|
||||||
|
regulator_disable(vreg_l15);
|
||||||
|
regulator_disable(vreg_l22);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rc < 0) {
|
||||||
|
printk(KERN_INFO "[Touch D] %s: cannot request GPIO\n",
|
||||||
|
__func__);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct touch_power_module touch_pwr = {
|
||||||
|
.use_regulator = 0,
|
||||||
|
.vdd = "8921_l15",
|
||||||
|
.vdd_voltage = 3300000,
|
||||||
|
.vio = "8921_l22",
|
||||||
|
.vio_voltage = 1800000,
|
||||||
|
.power = synaptics_t1320_power_on,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct touch_device_caps touch_caps = {
|
||||||
|
.button_support = 1,
|
||||||
|
.y_button_boundary = 0,
|
||||||
|
.number_of_button = 3,
|
||||||
|
.button_name = {KEY_BACK, KEY_HOMEPAGE, KEY_MENU},
|
||||||
|
.button_margin = 0,
|
||||||
|
.is_width_supported = 1,
|
||||||
|
.is_pressure_supported = 1,
|
||||||
|
.is_id_supported = 1,
|
||||||
|
.max_width = 15,
|
||||||
|
.max_pressure = 0xFF,
|
||||||
|
.max_id = 10,
|
||||||
|
.lcd_x = 768,
|
||||||
|
.lcd_y = 1280,
|
||||||
|
.x_max = 1100,
|
||||||
|
.y_max = 1900,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct touch_operation_role touch_role = {
|
||||||
|
.operation_mode = INTERRUPT_MODE,
|
||||||
|
.key_type = TOUCH_HARD_KEY,
|
||||||
|
.report_mode = CONTINUOUS_REPORT_MODE,
|
||||||
|
.delta_pos_threshold = 0,
|
||||||
|
.orientation = 0,
|
||||||
|
.report_period = 10000000,
|
||||||
|
.booting_delay = 400,
|
||||||
|
.reset_delay = 20,
|
||||||
|
.suspend_pwr = POWER_OFF,
|
||||||
|
.resume_pwr = POWER_ON,
|
||||||
|
.jitter_filter_enable = 1,
|
||||||
|
.jitter_curr_ratio = 30,
|
||||||
|
.accuracy_filter_enable = 1,
|
||||||
|
.irqflags = IRQF_TRIGGER_FALLING,
|
||||||
|
#if defined(CONFIG_TOUCH_REG_MAP_TM2000) || defined(CONFIG_TOUCH_REG_MAP_TM2372)
|
||||||
|
.show_touches = 0,
|
||||||
|
.pointer_location = 0,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct touch_platform_data mako_ts_data = {
|
||||||
|
.int_pin = SYNAPTICS_TS_I2C_INT_GPIO,
|
||||||
|
.reset_pin = TOUCH_RESET,
|
||||||
|
.maker = "Synaptics",
|
||||||
|
.caps = &touch_caps,
|
||||||
|
.role = &touch_role,
|
||||||
|
.pwr = &touch_pwr,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info synaptics_ts_info[] = {
|
||||||
|
[0] = {
|
||||||
|
I2C_BOARD_INFO(LGE_TOUCH_NAME, 0x20),
|
||||||
|
.platform_data = &mako_ts_data,
|
||||||
|
.irq = MSM_GPIO_TO_INT(SYNAPTICS_TS_I2C_INT_GPIO),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_RMI4_I2C)
|
||||||
|
struct syna_gpio_data {
|
||||||
|
u16 gpio_number;
|
||||||
|
char *gpio_name;
|
||||||
|
};
|
||||||
|
|
||||||
|
static int synaptics_touchpad_gpio_setup(void *gpio_data, bool configure)
|
||||||
|
{
|
||||||
|
|
||||||
|
int rc = -EINVAL;
|
||||||
|
static struct regulator *vreg_l15;
|
||||||
|
static struct regulator *vreg_l22;
|
||||||
|
|
||||||
|
struct syna_gpio_data *data = gpio_data;
|
||||||
|
|
||||||
|
pr_err("%s: [Touch D] S1 \n", __func__);
|
||||||
|
|
||||||
|
/* Touch IC Power On */
|
||||||
|
vreg_l15 = regulator_get(NULL, "8921_l15"); //3.3V_TOUCH_VDD, VREG_L15: 2.75 ~ 3.3
|
||||||
|
if (IS_ERR(vreg_l15)) {
|
||||||
|
pr_err("%s: regulator get of 8921_l15 failed (%ld)\n", __func__,
|
||||||
|
PTR_ERR(vreg_l15));
|
||||||
|
rc = PTR_ERR(vreg_l15);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
pr_err("%s: [Touch D] S2 \n", __func__);
|
||||||
|
vreg_l22 = regulator_get(NULL, "8921_l22"); //1.8V_TOUCH_IO, VREG_L22: 1.7 ~ 2.85
|
||||||
|
if (IS_ERR(vreg_l22)) {
|
||||||
|
pr_err("%s: regulator get of 8921_l22 failed (%ld)\n", __func__,
|
||||||
|
PTR_ERR(vreg_l22));
|
||||||
|
rc = PTR_ERR(vreg_l22);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
pr_err("%s: [Touch D] S3 \n", __func__);
|
||||||
|
rc = regulator_set_voltage(vreg_l15, 3300000, 3300000);
|
||||||
|
rc = regulator_set_voltage(vreg_l22, 1800000, 1800000);
|
||||||
|
|
||||||
|
regulator_enable(vreg_l15);
|
||||||
|
regulator_enable(vreg_l22);
|
||||||
|
|
||||||
|
if (configure) {
|
||||||
|
rc = gpio_request(data->gpio_number, "rmi4_attn");
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: Failed to get attn gpio %d. Code: %d.",
|
||||||
|
__func__, data->gpio_number, rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpio_tlmm_config(GPIO_CFG(data->gpio_number, 0, GPIO_CFG_INPUT,
|
||||||
|
GPIO_CFG_PULL_UP, GPIO_CFG_6MA),
|
||||||
|
GPIO_CFG_ENABLE);
|
||||||
|
|
||||||
|
rc = gpio_direction_input(data->gpio_number);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: Failed to setup attn gpio %d. Code: %d.",
|
||||||
|
__func__, data->gpio_number, rc);
|
||||||
|
gpio_free(data->gpio_number);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
pr_warn("%s: No way to deconfigure gpio %d.",
|
||||||
|
__func__, data->gpio_number);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rc < 0) {
|
||||||
|
printk(KERN_INFO "[Touch D] %s: cannot request GPIO\n",
|
||||||
|
__func__);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
printk("[Touch D]synaptics_touchpad_gpio_setup -- \n");
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define AXIS_ALIGNMENT { \
|
||||||
|
.swap_axes = false, \
|
||||||
|
.flip_x = false, \
|
||||||
|
.flip_y = false, \
|
||||||
|
.clip_X_low = 0, \
|
||||||
|
.clip_Y_low = 0, \
|
||||||
|
.offset_X = 0, \
|
||||||
|
.offset_Y = 0, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define TM2144_ADDR 0x20
|
||||||
|
#define TM2144_ATTN 6
|
||||||
|
|
||||||
|
static unsigned char tm2144_button_codes[] = {
|
||||||
|
KEY_BACK, KEY_HOMEPAGE, KEY_MENU
|
||||||
|
};
|
||||||
|
static struct rmi_f1a_button_map tm2144_button_map = {
|
||||||
|
.nbuttons = ARRAY_SIZE(tm2144_button_codes),
|
||||||
|
.map = tm2144_button_codes,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct syna_gpio_data tm2144_gpiodata = {
|
||||||
|
.gpio_number = TM2144_ATTN,
|
||||||
|
.gpio_name = "ts_int.gpio_6",
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct rmi_device_platform_data tm2144_platformdata = {
|
||||||
|
.driver_name = "rmi_generic",
|
||||||
|
.sensor_name = "TM2144",
|
||||||
|
.attn_gpio = TM2144_ATTN,
|
||||||
|
.attn_polarity = RMI_ATTN_ACTIVE_LOW,
|
||||||
|
.gpio_data = &tm2144_gpiodata,
|
||||||
|
.gpio_config = synaptics_touchpad_gpio_setup,
|
||||||
|
.axis_align = AXIS_ALIGNMENT,
|
||||||
|
.f1a_button_map = &tm2144_button_map,
|
||||||
|
.reset_delay_ms = 100,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info synaptics_ds4_rmi_info[] = {
|
||||||
|
[0] = {
|
||||||
|
I2C_BOARD_INFO("rmi_i2c", TM2144_ADDR),
|
||||||
|
.platform_data = &tm2144_platformdata,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* common function */
|
||||||
|
void __init apq8064_init_input(void)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4)
|
||||||
|
printk(KERN_INFO "[Touch D] %s: NOT DCM KDDI, reg synaptics driver \n",
|
||||||
|
__func__);
|
||||||
|
i2c_register_board_info(APQ8064_GSBI3_QUP_I2C_BUS_ID,
|
||||||
|
&synaptics_ts_info[0], 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Wireless Debugging Porting */
|
||||||
|
#if defined(CONFIG_RMI4_I2C)
|
||||||
|
i2c_register_board_info(APQ8064_GSBI3_QUP_I2C_BUS_ID,
|
||||||
|
&synaptics_ds4_rmi_info[0], 1);
|
||||||
|
#endif
|
||||||
|
}
|
631
arch/arm/mach-msm/lge/mako/board-mako-misc.c
Normal file
631
arch/arm/mach-msm/lge/mako/board-mako-misc.c
Normal file
|
@ -0,0 +1,631 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2011,2012 LGE, Inc.
|
||||||
|
*
|
||||||
|
* Author: Sungwoo Cho <sungwoo.cho@lge.com>
|
||||||
|
*
|
||||||
|
* This software is licensed under the terms of the GNU General
|
||||||
|
* License version 2, as published by the Free Software Foundation,
|
||||||
|
* may be copied, distributed, and modified under those terms.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/err.h>
|
||||||
|
#include <mach/msm_iomap.h>
|
||||||
|
#include <linux/io.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <mach/gpiomux.h>
|
||||||
|
|
||||||
|
#include <mach/board_lge.h>
|
||||||
|
|
||||||
|
#include "devices.h"
|
||||||
|
#include <linux/android_vibrator.h>
|
||||||
|
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_ISA1200
|
||||||
|
#include <linux/lge_isa1200.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_SII8334_MHL_TX
|
||||||
|
#include <linux/platform_data/mhl_device.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_BU52031NVX
|
||||||
|
#include <linux/mfd/pm8xxx/cradle.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "board-mako.h"
|
||||||
|
/* gpio and clock control for vibrator */
|
||||||
|
|
||||||
|
#define REG_WRITEL(value, reg) writel(value, (MSM_CLK_CTL_BASE+reg))
|
||||||
|
#define REG_READL(reg) readl((MSM_CLK_CTL_BASE+reg))
|
||||||
|
|
||||||
|
#define GPn_MD_REG(n) (0x2D00+32*(n))
|
||||||
|
#define GPn_NS_REG(n) (0x2D24+32*(n))
|
||||||
|
|
||||||
|
/* When use SM100 with GP_CLK
|
||||||
|
170Hz motor : 22.4KHz - M=1, N=214 ,
|
||||||
|
230Hz motor : 29.4KHZ - M=1, N=163 ,
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if !defined(CONFIG_LGE_ISA1200) && !defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
/* temporal code due to build error.. */
|
||||||
|
#define GPIO_LIN_MOTOR_EN 0
|
||||||
|
#define GPIO_LIN_MOTOR_PWM 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Vibrator GPIOs */
|
||||||
|
#ifdef CONFIG_ANDROID_VIBRATOR
|
||||||
|
#define GPIO_LIN_MOTOR_EN 33
|
||||||
|
#define GPIO_LIN_MOTOR_PWR 47
|
||||||
|
#define GPIO_LIN_MOTOR_PWM 3
|
||||||
|
|
||||||
|
#define GP_CLK_ID 0 /* gp clk 0 */
|
||||||
|
#define GP_CLK_M_DEFAULT 1
|
||||||
|
#define GP_CLK_N_DEFAULT 166
|
||||||
|
#define GP_CLK_D_MAX GP_CLK_N_DEFAULT
|
||||||
|
#define GP_CLK_D_HALF (GP_CLK_N_DEFAULT >> 1)
|
||||||
|
|
||||||
|
#define MOTOR_AMP 120
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_LGE_ISA1200) || defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
static struct gpiomux_setting vibrator_suspend_cfg = {
|
||||||
|
.func = GPIOMUX_FUNC_GPIO,
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* gpio 3 */
|
||||||
|
static struct gpiomux_setting vibrator_active_cfg_gpio3 = {
|
||||||
|
.func = GPIOMUX_FUNC_2, /*gp_mn:2 */
|
||||||
|
.drv = GPIOMUX_DRV_2MA,
|
||||||
|
.pull = GPIOMUX_PULL_NONE,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_gpiomux_config gpio2_vibrator_configs[] = {
|
||||||
|
{
|
||||||
|
.gpio = 3,
|
||||||
|
.settings = {
|
||||||
|
[GPIOMUX_ACTIVE] = &vibrator_active_cfg_gpio3,
|
||||||
|
[GPIOMUX_SUSPENDED] = &vibrator_suspend_cfg,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static int gpio_vibrator_en = 33;
|
||||||
|
static int gpio_vibrator_pwm = 3;
|
||||||
|
static int gp_clk_id = 0;
|
||||||
|
|
||||||
|
static int vibrator_gpio_init(void)
|
||||||
|
{
|
||||||
|
gpio_vibrator_en = GPIO_LIN_MOTOR_EN;
|
||||||
|
gpio_vibrator_pwm = GPIO_LIN_MOTOR_PWM;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_ANDROID_VIBRATOR
|
||||||
|
static struct regulator *vreg_l16 = NULL;
|
||||||
|
static bool snddev_reg_8921_l16_status = false;
|
||||||
|
|
||||||
|
static int vibrator_power_set(int enable)
|
||||||
|
{
|
||||||
|
int rc = -EINVAL;
|
||||||
|
if (NULL == vreg_l16) {
|
||||||
|
vreg_l16 = regulator_get(NULL, "8921_l16"); //2.6 ~ 3V
|
||||||
|
INFO_MSG("enable=%d\n", enable);
|
||||||
|
|
||||||
|
if (IS_ERR(vreg_l16)) {
|
||||||
|
pr_err("%s: regulator get of 8921_lvs6 failed (%ld)\n"
|
||||||
|
, __func__, PTR_ERR(vreg_l16));
|
||||||
|
printk("woosock ERROR\n");
|
||||||
|
rc = PTR_ERR(vreg_l16);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rc = regulator_set_voltage(vreg_l16, 2800000, 2800000);
|
||||||
|
|
||||||
|
if (enable == snddev_reg_8921_l16_status)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (enable) {
|
||||||
|
rc = regulator_set_voltage(vreg_l16, 2800000, 2800000);
|
||||||
|
if (rc < 0)
|
||||||
|
pr_err("LGE: VIB %s: regulator_set_voltage(l1) failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
|
||||||
|
rc = regulator_enable(vreg_l16);
|
||||||
|
|
||||||
|
if (rc < 0)
|
||||||
|
pr_err("LGE: VIB %s: regulator_enable(l1) failed (%d)\n", __func__, rc);
|
||||||
|
snddev_reg_8921_l16_status = true;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
rc = regulator_disable(vreg_l16);
|
||||||
|
if (rc < 0)
|
||||||
|
pr_err("%s: regulator_disable(l1) failed (%d)\n", __func__, rc);
|
||||||
|
snddev_reg_8921_l16_status = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int vibrator_pwm_set(int enable, int amp, int n_value)
|
||||||
|
{
|
||||||
|
/* TODO: set clk for amp */
|
||||||
|
uint M_VAL = GP_CLK_M_DEFAULT;
|
||||||
|
uint D_VAL = GP_CLK_D_MAX;
|
||||||
|
uint D_INV = 0; /* QCT support invert bit for msm8960 */
|
||||||
|
uint clk_id = gp_clk_id;
|
||||||
|
|
||||||
|
INFO_MSG("amp=%d, n_value=%d\n", amp, n_value);
|
||||||
|
|
||||||
|
if (enable) {
|
||||||
|
D_VAL = ((GP_CLK_D_MAX * amp) >> 7);
|
||||||
|
if (D_VAL > GP_CLK_D_HALF) {
|
||||||
|
if (D_VAL == GP_CLK_D_MAX) { /* Max duty is 99% */
|
||||||
|
D_VAL = 2;
|
||||||
|
} else {
|
||||||
|
D_VAL = GP_CLK_D_MAX - D_VAL;
|
||||||
|
}
|
||||||
|
D_INV = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
REG_WRITEL(
|
||||||
|
(((M_VAL & 0xffU) << 16U) + /* M_VAL[23:16] */
|
||||||
|
((~(D_VAL << 1)) & 0xffU)), /* D_VAL[7:0] */
|
||||||
|
GPn_MD_REG(clk_id));
|
||||||
|
|
||||||
|
REG_WRITEL(
|
||||||
|
((((~(n_value-M_VAL)) & 0xffU) << 16U) + /* N_VAL[23:16] */
|
||||||
|
(1U << 11U) + /* CLK_ROOT_ENA[11] : Enable(1) */
|
||||||
|
((D_INV & 0x01U) << 10U) + /* CLK_INV[10] : Disable(0) */
|
||||||
|
(1U << 9U) + /* CLK_BRANCH_ENA[9] : Enable(1) */
|
||||||
|
(1U << 8U) + /* NMCNTR_EN[8] : Enable(1) */
|
||||||
|
(0U << 7U) + /* MNCNTR_RST[7] : Not Active(0) */
|
||||||
|
(2U << 5U) + /* MNCNTR_MODE[6:5] : Dual-edge mode(2) */
|
||||||
|
(3U << 3U) + /* PRE_DIV_SEL[4:3] : Div-4 (3) */
|
||||||
|
(5U << 0U)), /* SRC_SEL[2:0] : CXO (5) */
|
||||||
|
GPn_NS_REG(clk_id));
|
||||||
|
INFO_MSG("GPIO_LIN_MOTOR_PWM is enable with M=%d N=%d D=%d\n",
|
||||||
|
M_VAL, n_value, D_VAL);
|
||||||
|
} else {
|
||||||
|
REG_WRITEL(
|
||||||
|
((((~(n_value-M_VAL)) & 0xffU) << 16U) + /* N_VAL[23:16] */
|
||||||
|
(0U << 11U) + /* CLK_ROOT_ENA[11] : Disable(0) */
|
||||||
|
(0U << 10U) + /* CLK_INV[10] : Disable(0) */
|
||||||
|
(0U << 9U) + /* CLK_BRANCH_ENA[9] : Disable(0) */
|
||||||
|
(0U << 8U) + /* NMCNTR_EN[8] : Disable(0) */
|
||||||
|
(0U << 7U) + /* MNCNTR_RST[7] : Not Active(0) */
|
||||||
|
(2U << 5U) + /* MNCNTR_MODE[6:5] : Dual-edge mode(2) */
|
||||||
|
(3U << 3U) + /* PRE_DIV_SEL[4:3] : Div-4 (3) */
|
||||||
|
(5U << 0U)), /* SRC_SEL[2:0] : CXO (5) */
|
||||||
|
GPn_NS_REG(clk_id));
|
||||||
|
INFO_MSG("GPIO_LIN_MOTOR_PWM is disalbe \n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int vibrator_ic_enable_set(int enable)
|
||||||
|
{
|
||||||
|
int gpio_lin_motor_en = 0;
|
||||||
|
gpio_lin_motor_en = PM8921_GPIO_PM_TO_SYS(GPIO_LIN_MOTOR_EN);
|
||||||
|
|
||||||
|
INFO_MSG("enable=%d\n", enable);
|
||||||
|
|
||||||
|
if (enable)
|
||||||
|
gpio_direction_output(gpio_lin_motor_en, 1);
|
||||||
|
else
|
||||||
|
gpio_direction_output(gpio_lin_motor_en, 0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int vibrator_init(void)
|
||||||
|
{
|
||||||
|
int rc;
|
||||||
|
int gpio_motor_en = 0;
|
||||||
|
int gpio_motor_pwm = 0;
|
||||||
|
|
||||||
|
gpio_motor_en = gpio_vibrator_en;
|
||||||
|
gpio_motor_pwm = gpio_vibrator_pwm;
|
||||||
|
|
||||||
|
/* GPIO function setting */
|
||||||
|
msm_gpiomux_install(gpio2_vibrator_configs,
|
||||||
|
ARRAY_SIZE(gpio2_vibrator_configs));
|
||||||
|
|
||||||
|
/* GPIO setting for Motor EN in pmic8921 */
|
||||||
|
gpio_motor_en = PM8921_GPIO_PM_TO_SYS(GPIO_LIN_MOTOR_EN);
|
||||||
|
rc = gpio_request(gpio_motor_en, "lin_motor_en");
|
||||||
|
if (rc) {
|
||||||
|
ERR_MSG("GPIO_LIN_MOTOR_EN %d request failed\n", gpio_motor_en);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* gpio init */
|
||||||
|
rc = gpio_request(gpio_motor_pwm, "lin_motor_pwm");
|
||||||
|
if (unlikely(rc < 0))
|
||||||
|
ERR_MSG("not able to get gpio\n");
|
||||||
|
|
||||||
|
vibrator_ic_enable_set(0);
|
||||||
|
vibrator_pwm_set(0, 0, GP_CLK_N_DEFAULT);
|
||||||
|
vibrator_power_set(0);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static struct android_vibrator_platform_data vibrator_data = {
|
||||||
|
.enable_status = 0,
|
||||||
|
.amp = MOTOR_AMP,
|
||||||
|
.vibe_n_value = GP_CLK_N_DEFAULT,
|
||||||
|
.power_set = vibrator_power_set,
|
||||||
|
.pwm_set = vibrator_pwm_set,
|
||||||
|
.ic_enable_set = vibrator_ic_enable_set,
|
||||||
|
.vibrator_init = vibrator_init,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device android_vibrator_device = {
|
||||||
|
.name = "android-vibrator",
|
||||||
|
.id = -1,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &vibrator_data,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#endif /* CONFIG_ANDROID_VIBRATOR */
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_ISA1200
|
||||||
|
static int lge_isa1200_clock(int enable)
|
||||||
|
{
|
||||||
|
if (enable) {
|
||||||
|
REG_WRITEL(
|
||||||
|
(((0 & 0xffU) << 16U) + /* N_VAL[23:16] */
|
||||||
|
(1U << 11U) + /* CLK_ROOT_ENA[11] : Enable(1) */
|
||||||
|
(0U << 10U) + /* CLK_INV[10] : Disable(0) */
|
||||||
|
(1U << 9U) + /* CLK_BRANCH_ENA[9] : Enable(1) */
|
||||||
|
(0U << 8U) + /* NMCNTR_EN[8] : Enable(1) */
|
||||||
|
(0U << 7U) + /* MNCNTR_RST[7] : Not Active(0) */
|
||||||
|
(0U << 5U) + /* MNCNTR_MODE[6:5] : Dual-edge mode(2) */
|
||||||
|
(0U << 3U) + /* PRE_DIV_SEL[4:3] : Div-4 (3) */
|
||||||
|
(0U << 0U)), /* SRC_SEL[2:0] : pxo (0) */
|
||||||
|
GPn_NS_REG(1));
|
||||||
|
/* printk("GPIO_LIN_MOTOR_PWM is enabled. pxo clock."); */
|
||||||
|
} else {
|
||||||
|
REG_WRITEL(
|
||||||
|
(((0 & 0xffU) << 16U) + /* N_VAL[23:16] */
|
||||||
|
(0U << 11U) + /* CLK_ROOT_ENA[11] : Disable(0) */
|
||||||
|
(0U << 10U) + /* CLK_INV[10] : Disable(0) */
|
||||||
|
(0U << 9U) + /* CLK_BRANCH_ENA[9] : Disable(0) */
|
||||||
|
(0U << 8U) + /* NMCNTR_EN[8] : Disable(0) */
|
||||||
|
(1U << 7U) + /* MNCNTR_RST[7] : Not Active(0) */
|
||||||
|
(0U << 5U) + /* MNCNTR_MODE[6:5] : Dual-edge mode(2) */
|
||||||
|
(0U << 3U) + /* PRE_DIV_SEL[4:3] : Div-4 (3) */
|
||||||
|
(0U << 0U)), /* SRC_SEL[2:0] : pxo (0) */
|
||||||
|
GPn_NS_REG(1));
|
||||||
|
/* printk("GPIO_LIN_MOTOR_PWM is disabled."); */
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct isa1200_reg_cmd isa1200_init_seq[] = {
|
||||||
|
|
||||||
|
{LGE_ISA1200_HCTRL2, 0x00}, /* bk : release sw reset */
|
||||||
|
|
||||||
|
{LGE_ISA1200_SCTRL , 0x0F}, /* LDO:3V */
|
||||||
|
|
||||||
|
{LGE_ISA1200_HCTRL0, 0x10}, /* [4:3]10 : PWM Generation Mode [1:0]00 : Divider 1/128 */
|
||||||
|
{LGE_ISA1200_HCTRL1, 0xC0}, /* [7] 1 : Ext. Clock Selection, [5] 0:LRA, 1:ERM */
|
||||||
|
{LGE_ISA1200_HCTRL3, 0x33}, /* [6:4] 1:PWM/SE Generation PLL Clock Divider */
|
||||||
|
|
||||||
|
{LGE_ISA1200_HCTRL4, 0x81}, /* bk */
|
||||||
|
{LGE_ISA1200_HCTRL5, 0x99}, /* [7:0] PWM High Duty(PWM Gen) 0-6B-D6 */ /* TODO make it platform data? */
|
||||||
|
{LGE_ISA1200_HCTRL6, 0x9C}, /* [7:0] PWM Period(PWM Gen) */ /* TODO make it platform data? */
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct isa1200_reg_seq isa1200_init = {
|
||||||
|
.reg_cmd_list = isa1200_init_seq,
|
||||||
|
.number_of_reg_cmd_list = ARRAY_SIZE(isa1200_init_seq),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct lge_isa1200_platform_data lge_isa1200_platform_data = {
|
||||||
|
.vibrator_name = "vibrator",
|
||||||
|
|
||||||
|
.gpio_hen = GPIO_MOTOR_EN,
|
||||||
|
.gpio_len = GPIO_MOTOR_EN,
|
||||||
|
|
||||||
|
.clock = lge_isa1200_clock,
|
||||||
|
.max_timeout = 30000,
|
||||||
|
.default_vib_strength = 255, /* max strength value is 255 */
|
||||||
|
.init_seq = &isa1200_init,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info lge_i2c_isa1200_board_info[] = {
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("lge_isa1200", ISA1200_SLAVE_ADDR>>1),
|
||||||
|
.platform_data = &lge_isa1200_platform_data
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_LGE_ISA1200) || defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
static struct platform_device *misc_devices[] __initdata = {
|
||||||
|
#ifdef CONFIG_ANDROID_VIBRATOR
|
||||||
|
&android_vibrator_device,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_SII8334_MHL_TX)
|
||||||
|
|
||||||
|
#define MHL_RESET_N 31
|
||||||
|
#define MHL_INT_N 43
|
||||||
|
|
||||||
|
static int mhl_gpio_init(void)
|
||||||
|
{
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
rc = gpio_request(MHL_INT_N, "mhl_int_n");
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("failed to request mhl_int_n gpio\n");
|
||||||
|
goto error1;
|
||||||
|
}
|
||||||
|
gpio_export(MHL_INT_N, 1);
|
||||||
|
|
||||||
|
rc = gpio_request(MHL_RESET_N, "mhl_reset_n");
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("failed to request mhl_reset_n gpio\n");
|
||||||
|
goto error2;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = gpio_direction_output(MHL_RESET_N, 0);
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("failed to request mhl_reset_n gpio\n");
|
||||||
|
goto error3;
|
||||||
|
}
|
||||||
|
|
||||||
|
error3:
|
||||||
|
gpio_free(MHL_RESET_N);
|
||||||
|
error2:
|
||||||
|
gpio_free(MHL_INT_N);
|
||||||
|
error1:
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct regulator *vreg_l18_mhl;
|
||||||
|
|
||||||
|
static int mhl_power_onoff(bool on, bool pm_ctrl)
|
||||||
|
{
|
||||||
|
static bool power_state=0;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
|
if (power_state == on) {
|
||||||
|
pr_info("sii_power_state is already %s \n",
|
||||||
|
power_state ? "on" : "off");
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
power_state = on;
|
||||||
|
|
||||||
|
if (!vreg_l18_mhl)
|
||||||
|
vreg_l18_mhl = regulator_get(NULL, "8921_l18");
|
||||||
|
|
||||||
|
if (IS_ERR(vreg_l18_mhl)) {
|
||||||
|
rc = PTR_ERR(vreg_l18_mhl);
|
||||||
|
pr_err("%s: vreg_l18_mhl get failed (%d)\n", __func__, rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (on) {
|
||||||
|
|
||||||
|
gpio_set_value(MHL_RESET_N, 0);
|
||||||
|
|
||||||
|
rc = regulator_set_optimum_mode(vreg_l18_mhl, 100000);
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("%s : set optimum mode 100000,\
|
||||||
|
vreg_l18_mhl failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = regulator_set_voltage(vreg_l18_mhl, 1200000, 1200000);
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("%s : set voltage 1200000,\
|
||||||
|
vreg_l18_mhl failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = regulator_enable(vreg_l18_mhl);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s : vreg_l18_mhl enable failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
msleep(100);
|
||||||
|
gpio_set_value(MHL_RESET_N, 1);
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
rc = regulator_set_optimum_mode(vreg_l18_mhl, 100);
|
||||||
|
if (rc < 0) {
|
||||||
|
pr_err("%s : set optimum mode 100,\
|
||||||
|
vreg_l18_mhl failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = regulator_disable(vreg_l18_mhl);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s : vreg_l18_mhl disable failed (%d)\n",
|
||||||
|
__func__, rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpio_set_value(MHL_RESET_N, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct mhl_platform_data mhl_pdata = {
|
||||||
|
.power = mhl_power_onoff,
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#define I2C_SURF 1
|
||||||
|
#define I2C_FFA (1 << 1)
|
||||||
|
#define I2C_RUMI (1 << 2)
|
||||||
|
#define I2C_SIM (1 << 3)
|
||||||
|
#define I2C_LIQUID (1 << 4)
|
||||||
|
#define I2C_J1V (1 << 5)
|
||||||
|
|
||||||
|
struct i2c_registry {
|
||||||
|
u8 machs;
|
||||||
|
int bus;
|
||||||
|
struct i2c_board_info *info;
|
||||||
|
int len;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct i2c_board_info i2c_mhl_info[] = {
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("Sil-833x", 0x72 >> 1), /* 0x39 */
|
||||||
|
.irq = MSM_GPIO_TO_INT(MHL_INT_N),
|
||||||
|
.platform_data = &mhl_pdata,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("Sil-833x", 0x7A >> 1), /* 0x3D */
|
||||||
|
},
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("Sil-833x", 0x92 >> 1), /* 0x49 */
|
||||||
|
},
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("Sil-833x", 0x9A >> 1), /* 0x4D */
|
||||||
|
},
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("Sil-833x", 0xC8 >> 1), /* 0x64 */
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_registry i2c_mhl_devices __initdata = {
|
||||||
|
I2C_SURF | I2C_FFA | I2C_RUMI | I2C_SIM | I2C_LIQUID | I2C_J1V,
|
||||||
|
APQ_8064_GSBI1_QUP_I2C_BUS_ID,
|
||||||
|
i2c_mhl_info,
|
||||||
|
ARRAY_SIZE(i2c_mhl_info),
|
||||||
|
};
|
||||||
|
|
||||||
|
static void __init lge_add_i2c_mhl_device(void)
|
||||||
|
{
|
||||||
|
i2c_register_board_info(i2c_mhl_devices.bus,
|
||||||
|
i2c_mhl_devices.info,
|
||||||
|
i2c_mhl_devices.len);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CONFIG_SII8334_MHL_TX */
|
||||||
|
|
||||||
|
#ifdef CONFIG_BU52031NVX
|
||||||
|
#define GPIO_POUCH_INT 22
|
||||||
|
#define GPIO_CARKIT_INT 23
|
||||||
|
|
||||||
|
static unsigned hall_ic_int_gpio[] = {GPIO_POUCH_INT, GPIO_CARKIT_INT};
|
||||||
|
|
||||||
|
static unsigned hall_ic_gpio[] = {
|
||||||
|
GPIO_CFG(22, 0, GPIO_CFG_INPUT, GPIO_CFG_NO_PULL, GPIO_CFG_2MA),
|
||||||
|
GPIO_CFG(23, 0, GPIO_CFG_INPUT, GPIO_CFG_NO_PULL, GPIO_CFG_2MA),
|
||||||
|
};
|
||||||
|
|
||||||
|
static void __init hall_ic_init(void)
|
||||||
|
{
|
||||||
|
int rc = 0;
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
printk(KERN_INFO "%s, line: %d\n", __func__, __LINE__);
|
||||||
|
|
||||||
|
rc = gpio_request(GPIO_POUCH_INT, "cradle_detect_s");
|
||||||
|
if (rc) {
|
||||||
|
printk(KERN_ERR "%s: pouch_int %d request failed\n",
|
||||||
|
__func__, GPIO_POUCH_INT);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = gpio_request(GPIO_CARKIT_INT, "cradle_detect_n");
|
||||||
|
if (rc) {
|
||||||
|
printk(KERN_ERR "%s: pouch_int %d request failed\n",
|
||||||
|
__func__, GPIO_CARKIT_INT);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i=0; i<ARRAY_SIZE(hall_ic_gpio); i++) {
|
||||||
|
rc = gpio_tlmm_config(hall_ic_gpio[i], GPIO_CFG_ENABLE);
|
||||||
|
gpio_direction_input(hall_ic_int_gpio[i]);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
printk(KERN_ERR "%s: gpio_tlmm_config(%#x)=fg%d\n",
|
||||||
|
__func__, hall_ic_gpio[i], rc);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
printk(KERN_INFO "yoogyeong.lee@%s_END\n", __func__);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pm8xxx_cradle_platform_data cradle_data = {
|
||||||
|
#if defined(CONFIG_BU52031NVX_POUCHDETECT)
|
||||||
|
.pouch_detect_pin = GPIO_POUCH_INT,
|
||||||
|
.pouch_irq = MSM_GPIO_TO_INT(GPIO_POUCH_INT),
|
||||||
|
#endif
|
||||||
|
.carkit_detect_pin = GPIO_CARKIT_INT,
|
||||||
|
.carkit_irq = MSM_GPIO_TO_INT(GPIO_CARKIT_INT),
|
||||||
|
.irq_flags = IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device cradle_device = {
|
||||||
|
.name = PM8XXX_CRADLE_DEV_NAME,
|
||||||
|
.id = -1,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &cradle_data,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void __init apq8064_init_misc(void)
|
||||||
|
{
|
||||||
|
#if defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
int vib_flag = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
INFO_MSG("%s\n", __func__);
|
||||||
|
|
||||||
|
#if defined(CONFIG_LGE_ISA1200) || defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
vibrator_gpio_init();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_ANDROID_VIBRATOR)
|
||||||
|
if (vib_flag == 0)
|
||||||
|
platform_add_devices(misc_devices, ARRAY_SIZE(misc_devices));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_SII8334_MHL_TX)
|
||||||
|
mhl_gpio_init();
|
||||||
|
lge_add_i2c_mhl_device();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_BU52031NVX
|
||||||
|
hall_ic_init();
|
||||||
|
platform_device_register(&cradle_device);
|
||||||
|
#endif
|
||||||
|
}
|
78
arch/arm/mach-msm/lge/mako/board-mako-nfc.c
Normal file
78
arch/arm/mach-msm/lge/mako/board-mako-nfc.c
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
/* Copyright(c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <mach/board_lge.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
#include <linux/regulator/consumer.h>
|
||||||
|
#include "devices.h"
|
||||||
|
|
||||||
|
#include "board-mako.h"
|
||||||
|
#include "board-8064.h"
|
||||||
|
|
||||||
|
#if defined(CONFIG_LGE_NFC_PN544)
|
||||||
|
#include <linux/nfc/pn544_lge.h>
|
||||||
|
|
||||||
|
#define I2C_SURF 1
|
||||||
|
#define I2C_FFA (1 << 1)
|
||||||
|
#define I2C_RUMI (1 << 2)
|
||||||
|
#define I2C_SIM (1 << 3)
|
||||||
|
#define I2C_LIQUID (1 << 4)
|
||||||
|
#define I2C_J1V (1 << 5)
|
||||||
|
|
||||||
|
struct i2c_registry {
|
||||||
|
u8 machs;
|
||||||
|
int bus;
|
||||||
|
struct i2c_board_info *info;
|
||||||
|
int len;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef void (gpio_i2c_init_func_t)(int bus_num);
|
||||||
|
|
||||||
|
static struct pn544_i2c_platform_data pn544_i2c_platform_data[] = {
|
||||||
|
{
|
||||||
|
.ven_gpio = NFC_GPIO_VEN,
|
||||||
|
.irq_gpio = NFC_GPIO_IRQ,
|
||||||
|
.firm_gpio = NFC_GPIO_FIRM,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info msm_i2c_nxp_nfc_info[] = {
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("pn544", NFC_I2C_SLAVE_ADDR),
|
||||||
|
.platform_data = &pn544_i2c_platform_data,
|
||||||
|
.irq = MSM_GPIO_TO_INT(NFC_GPIO_IRQ),
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct i2c_registry apq8064_i2c_devices __initdata = {
|
||||||
|
I2C_SURF | I2C_FFA | I2C_RUMI | I2C_SIM | I2C_LIQUID | I2C_J1V,
|
||||||
|
APQ_8064_GSBI1_QUP_I2C_BUS_ID,
|
||||||
|
msm_i2c_nxp_nfc_info,
|
||||||
|
ARRAY_SIZE(msm_i2c_nxp_nfc_info),
|
||||||
|
};
|
||||||
|
|
||||||
|
static void __init lge_add_i2c_nfc_devices(void)
|
||||||
|
{
|
||||||
|
i2c_register_board_info(apq8064_i2c_devices.bus,
|
||||||
|
apq8064_i2c_devices.info,
|
||||||
|
apq8064_i2c_devices.len);
|
||||||
|
}
|
||||||
|
|
||||||
|
void __init lge_add_nfc_devices(void)
|
||||||
|
{
|
||||||
|
lge_add_i2c_nfc_devices();
|
||||||
|
}
|
||||||
|
#endif
|
578
arch/arm/mach-msm/lge/mako/board-mako-pmic.c
Normal file
578
arch/arm/mach-msm/lge/mako/board-mako-pmic.c
Normal file
|
@ -0,0 +1,578 @@
|
||||||
|
/* Copyright (c) 2011-2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <linux/ioport.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/bootmem.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
#include <linux/leds.h>
|
||||||
|
#include <linux/leds-pm8xxx.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8xxx-adc.h>
|
||||||
|
#include <asm/mach-types.h>
|
||||||
|
#include <asm/mach/mmc.h>
|
||||||
|
#include <mach/msm_bus_board.h>
|
||||||
|
#include <mach/board.h>
|
||||||
|
#include <mach/gpio.h>
|
||||||
|
#include <mach/gpiomux.h>
|
||||||
|
#include <mach/restart.h>
|
||||||
|
#include <mach/board_lge.h>
|
||||||
|
#include "devices.h"
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
struct pm8xxx_gpio_init {
|
||||||
|
unsigned gpio;
|
||||||
|
struct pm_gpio config;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pm8xxx_mpp_init {
|
||||||
|
unsigned mpp;
|
||||||
|
struct pm8xxx_mpp_config_data config;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define PM8921_GPIO_INIT(_gpio, _dir, _buf, _val, _pull, _vin, _out_strength, \
|
||||||
|
_func, _inv, _disable) \
|
||||||
|
{ \
|
||||||
|
.gpio = PM8921_GPIO_PM_TO_SYS(_gpio), \
|
||||||
|
.config = { \
|
||||||
|
.direction = _dir, \
|
||||||
|
.output_buffer = _buf, \
|
||||||
|
.output_value = _val, \
|
||||||
|
.pull = _pull, \
|
||||||
|
.vin_sel = _vin, \
|
||||||
|
.out_strength = _out_strength, \
|
||||||
|
.function = _func, \
|
||||||
|
.inv_int_pol = _inv, \
|
||||||
|
.disable_pin = _disable, \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define PM8921_MPP_INIT(_mpp, _type, _level, _control) \
|
||||||
|
{ \
|
||||||
|
.mpp = PM8921_MPP_PM_TO_SYS(_mpp), \
|
||||||
|
.config = { \
|
||||||
|
.type = PM8XXX_MPP_TYPE_##_type, \
|
||||||
|
.level = _level, \
|
||||||
|
.control = PM8XXX_MPP_##_control, \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define PM8821_MPP_INIT(_mpp, _type, _level, _control) \
|
||||||
|
{ \
|
||||||
|
.mpp = PM8821_MPP_PM_TO_SYS(_mpp), \
|
||||||
|
.config = { \
|
||||||
|
.type = PM8XXX_MPP_TYPE_##_type, \
|
||||||
|
.level = _level, \
|
||||||
|
.control = PM8XXX_MPP_##_control, \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define PM8921_GPIO_DISABLE(_gpio) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_IN, 0, 0, 0, PM_GPIO_VIN_S4, \
|
||||||
|
0, 0, 0, 1)
|
||||||
|
|
||||||
|
#define PM8921_GPIO_OUTPUT(_gpio, _val, _strength) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_OUT, PM_GPIO_OUT_BUF_CMOS, _val, \
|
||||||
|
PM_GPIO_PULL_NO, PM_GPIO_VIN_S4, \
|
||||||
|
PM_GPIO_STRENGTH_##_strength, \
|
||||||
|
PM_GPIO_FUNC_NORMAL, 0, 0)
|
||||||
|
|
||||||
|
#define PM8921_GPIO_OUTPUT_BUFCONF(_gpio, _val, _strength, _bufconf) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_OUT,\
|
||||||
|
PM_GPIO_OUT_BUF_##_bufconf, _val, \
|
||||||
|
PM_GPIO_PULL_NO, PM_GPIO_VIN_S4, \
|
||||||
|
PM_GPIO_STRENGTH_##_strength, \
|
||||||
|
PM_GPIO_FUNC_NORMAL, 0, 0)
|
||||||
|
|
||||||
|
#define PM8921_GPIO_INPUT(_gpio, _pull) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_IN, PM_GPIO_OUT_BUF_CMOS, 0, \
|
||||||
|
_pull, PM_GPIO_VIN_S4, \
|
||||||
|
PM_GPIO_STRENGTH_NO, \
|
||||||
|
PM_GPIO_FUNC_NORMAL, 0, 0)
|
||||||
|
|
||||||
|
#define PM8921_GPIO_OUTPUT_FUNC(_gpio, _val, _func) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_OUT, PM_GPIO_OUT_BUF_CMOS, _val, \
|
||||||
|
PM_GPIO_PULL_NO, PM_GPIO_VIN_S4, \
|
||||||
|
PM_GPIO_STRENGTH_HIGH, \
|
||||||
|
_func, 0, 0)
|
||||||
|
|
||||||
|
#define PM8921_GPIO_OUTPUT_VIN(_gpio, _val, _vin) \
|
||||||
|
PM8921_GPIO_INIT(_gpio, PM_GPIO_DIR_OUT, PM_GPIO_OUT_BUF_CMOS, _val, \
|
||||||
|
PM_GPIO_PULL_NO, _vin, \
|
||||||
|
PM_GPIO_STRENGTH_HIGH, \
|
||||||
|
PM_GPIO_FUNC_NORMAL, 0, 0)
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
/* Initial PM8921 GPIO configurations */
|
||||||
|
static struct pm8xxx_gpio_init pm8921_gpios[] __initdata = {
|
||||||
|
PM8921_GPIO_OUTPUT(17, 0, HIGH), /* CAM_VCM_EN */
|
||||||
|
PM8921_GPIO_OUTPUT(19, 0, HIGH), /* AMP_EN_AMP */
|
||||||
|
PM8921_GPIO_OUTPUT(31, 0, HIGH), /* PMIC - FSA8008_EAR_MIC_EN */
|
||||||
|
PM8921_GPIO_INPUT(32, PM_GPIO_PULL_UP_1P5), /* PMIC - FSA8008_EARPOL_DETECT */
|
||||||
|
PM8921_GPIO_OUTPUT(33, 0, HIGH), /* HAPTIC_EN */
|
||||||
|
PM8921_GPIO_OUTPUT(34, 0, HIGH), /* WCD_RESET_N */
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
/* Initial PM8921 GPIO configurations */
|
||||||
|
static struct pm8xxx_gpio_init pm8921_gpios[] __initdata = {
|
||||||
|
PM8921_GPIO_OUTPUT(14, 1, HIGH), /* HDMI Mux Selector */
|
||||||
|
PM8921_GPIO_OUTPUT(23, 0, HIGH), /* touchscreen power FET */
|
||||||
|
PM8921_GPIO_OUTPUT_BUFCONF(25, 0, LOW, CMOS), /* DISP_RESET_N */
|
||||||
|
PM8921_GPIO_OUTPUT_FUNC(26, 0, PM_GPIO_FUNC_2), /* Bl: Off, PWM mode */
|
||||||
|
PM8921_GPIO_OUTPUT_VIN(30, 1, PM_GPIO_VIN_VPH), /* SMB349 susp line */
|
||||||
|
PM8921_GPIO_OUTPUT_BUFCONF(36, 1, LOW, OPEN_DRAIN),
|
||||||
|
PM8921_GPIO_OUTPUT_FUNC(44, 0, PM_GPIO_FUNC_2),
|
||||||
|
PM8921_GPIO_OUTPUT(33, 0, HIGH),
|
||||||
|
PM8921_GPIO_OUTPUT(20, 0, HIGH),
|
||||||
|
PM8921_GPIO_INPUT(35, PM_GPIO_PULL_UP_30),
|
||||||
|
PM8921_GPIO_INPUT(38, PM_GPIO_PULL_UP_30),
|
||||||
|
/* TABLA CODEC RESET */
|
||||||
|
PM8921_GPIO_OUTPUT(34, 1, MED),
|
||||||
|
PM8921_GPIO_INPUT(31, PM_GPIO_PULL_NO),
|
||||||
|
PM8921_GPIO_OUTPUT(13, 0, HIGH), /* PCIE_CLK_PWR_EN */
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_LGE_PM
|
||||||
|
static struct pm8xxx_gpio_init pm8921_mtp_kp_gpios[] __initdata = {
|
||||||
|
PM8921_GPIO_INPUT(3, PM_GPIO_PULL_UP_30),
|
||||||
|
PM8921_GPIO_INPUT(4, PM_GPIO_PULL_UP_30),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_gpio_init pm8921_cdp_kp_gpios[] __initdata = {
|
||||||
|
PM8921_GPIO_INPUT(27, PM_GPIO_PULL_UP_30),
|
||||||
|
PM8921_GPIO_INPUT(42, PM_GPIO_PULL_UP_30),
|
||||||
|
PM8921_GPIO_INPUT(17, PM_GPIO_PULL_UP_1P5), /* SD_WP */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Initial PM8XXX MPP configurations */
|
||||||
|
static struct pm8xxx_mpp_init pm8xxx_mpps[] __initdata = {
|
||||||
|
PM8921_MPP_INIT(3, D_OUTPUT, PM8921_MPP_DIG_LEVEL_VPH, DOUT_CTRL_LOW),
|
||||||
|
PM8921_MPP_INIT(8, D_OUTPUT, PM8921_MPP_DIG_LEVEL_S4, DOUT_CTRL_LOW),
|
||||||
|
/*MPP9 is used to detect docking station connection/removal on Liquid*/
|
||||||
|
PM8921_MPP_INIT(9, D_INPUT, PM8921_MPP_DIG_LEVEL_S4, DIN_TO_INT),
|
||||||
|
/* PCIE_RESET_N */
|
||||||
|
PM8921_MPP_INIT(1, D_OUTPUT, PM8921_MPP_DIG_LEVEL_VPH, DOUT_CTRL_HIGH),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void __init apq8064_pm8xxx_gpio_mpp_init(void)
|
||||||
|
{
|
||||||
|
int i, rc;
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(pm8921_gpios); i++) {
|
||||||
|
rc = pm8xxx_gpio_config(pm8921_gpios[i].gpio,
|
||||||
|
&pm8921_gpios[i].config);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: pm8xxx_gpio_config: rc=%d\n", __func__, rc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#ifndef CONFIG_LGE_PM
|
||||||
|
if (machine_is_apq8064_cdp() || machine_is_apq8064_liquid())
|
||||||
|
for (i = 0; i < ARRAY_SIZE(pm8921_cdp_kp_gpios); i++) {
|
||||||
|
rc = pm8xxx_gpio_config(pm8921_cdp_kp_gpios[i].gpio,
|
||||||
|
&pm8921_cdp_kp_gpios[i].config);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: pm8xxx_gpio_config: rc=%d\n",
|
||||||
|
__func__, rc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (machine_is_apq8064_mtp())
|
||||||
|
for (i = 0; i < ARRAY_SIZE(pm8921_mtp_kp_gpios); i++) {
|
||||||
|
rc = pm8xxx_gpio_config(pm8921_mtp_kp_gpios[i].gpio,
|
||||||
|
&pm8921_mtp_kp_gpios[i].config);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: pm8xxx_gpio_config: rc=%d\n",
|
||||||
|
__func__, rc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(pm8xxx_mpps); i++) {
|
||||||
|
rc = pm8xxx_mpp_config(pm8xxx_mpps[i].mpp,
|
||||||
|
&pm8xxx_mpps[i].config);
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: pm8xxx_mpp_config: rc=%d\n", __func__, rc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pm8xxx_pwrkey_platform_data apq8064_pm8921_pwrkey_pdata = {
|
||||||
|
.pull_up = 1,
|
||||||
|
.kpd_trigger_delay_us = 15625,
|
||||||
|
.wakeup = 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_misc_platform_data apq8064_pm8921_misc_pdata = {
|
||||||
|
.priority = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
#define PM8921_LC_LED_MAX_CURRENT 4 /* I = 4mA */
|
||||||
|
#define PM8921_LC_LED_LOW_CURRENT 1 /* I = 1mA */
|
||||||
|
#define PM8XXX_LED_PWM_PERIOD 1000
|
||||||
|
#define PM8XXX_LED_PWM_DUTY_MS 20
|
||||||
|
/**
|
||||||
|
* PM8XXX_PWM_CHANNEL_NONE shall be used when LED shall not be
|
||||||
|
* driven using PWM feature.
|
||||||
|
*/
|
||||||
|
#define PM8XXX_PWM_CHANNEL_NONE -1
|
||||||
|
|
||||||
|
static struct led_info pm8921_led_info[] = {
|
||||||
|
#if defined(CONFIG_LGE_PM)
|
||||||
|
[0] = {
|
||||||
|
.name = "led:red",
|
||||||
|
},
|
||||||
|
#else
|
||||||
|
|
||||||
|
[0] = {
|
||||||
|
.name = "led:red",
|
||||||
|
.default_trigger = "ac-online",
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
[1] = {
|
||||||
|
.name = "button-backlight",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct led_platform_data pm8921_led_core_pdata = {
|
||||||
|
.num_leds = ARRAY_SIZE(pm8921_led_info),
|
||||||
|
.leds = pm8921_led_info,
|
||||||
|
};
|
||||||
|
|
||||||
|
#if !defined(CONFIG_LGE_PM)
|
||||||
|
static int pm8921_led0_pwm_duty_pcts[56] = {
|
||||||
|
1, 4, 8, 12, 16, 20, 24, 28, 32, 36,
|
||||||
|
40, 44, 46, 52, 56, 60, 64, 68, 72, 76,
|
||||||
|
80, 84, 88, 92, 96, 100, 100, 100, 98, 95,
|
||||||
|
92, 88, 84, 82, 78, 74, 70, 66, 62, 58,
|
||||||
|
58, 54, 50, 48, 42, 38, 34, 30, 26, 22,
|
||||||
|
14, 10, 6, 4, 1
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_pwm_duty_cycles pm8921_led0_pwm_duty_cycles = {
|
||||||
|
.duty_pcts = (int *)&pm8921_led0_pwm_duty_pcts,
|
||||||
|
.num_duty_pcts = ARRAY_SIZE(pm8921_led0_pwm_duty_pcts),
|
||||||
|
.duty_ms = PM8XXX_LED_PWM_DUTY_MS,
|
||||||
|
.start_idx = 0,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct pm8xxx_led_config pm8921_led_configs[] = {
|
||||||
|
#if defined(CONFIG_LGE_PM)
|
||||||
|
[0] = {
|
||||||
|
.id = PM8XXX_ID_LED_0,
|
||||||
|
.mode = PM8XXX_LED_MODE_MANUAL,
|
||||||
|
.max_current = PM8921_LC_LED_MAX_CURRENT,
|
||||||
|
},
|
||||||
|
#else
|
||||||
|
[0] = {
|
||||||
|
.id = PM8XXX_ID_LED_0,
|
||||||
|
.mode = PM8XXX_LED_MODE_PWM2,
|
||||||
|
.max_current = PM8921_LC_LED_MAX_CURRENT,
|
||||||
|
.pwm_channel = 5,
|
||||||
|
.pwm_period_us = PM8XXX_LED_PWM_PERIOD,
|
||||||
|
.pwm_duty_cycles = &pm8921_led0_pwm_duty_cycles,
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
[1] = {
|
||||||
|
.id = PM8XXX_ID_LED_1,
|
||||||
|
.mode = PM8XXX_LED_MODE_MANUAL,
|
||||||
|
.max_current = PM8921_LC_LED_MAX_CURRENT,
|
||||||
|
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_led_platform_data apq8064_pm8921_leds_pdata = {
|
||||||
|
.led_core = &pm8921_led_core_pdata,
|
||||||
|
.configs = pm8921_led_configs,
|
||||||
|
.num_configs = ARRAY_SIZE(pm8921_led_configs),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_adc_amux apq8064_pm8921_adc_channels_data[] = {
|
||||||
|
{"vcoin", CHANNEL_VCOIN, CHAN_PATH_SCALING2, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"vbat", CHANNEL_VBAT, CHAN_PATH_SCALING2, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"dcin", CHANNEL_DCIN, CHAN_PATH_SCALING4, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"ichg", CHANNEL_ICHG, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"vph_pwr", CHANNEL_VPH_PWR, CHAN_PATH_SCALING2, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"ibat", CHANNEL_IBAT, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"batt_therm", CHANNEL_BATT_THERM, CHAN_PATH_SCALING1, AMUX_RSV2,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_BATT_THERM},
|
||||||
|
{"batt_id", CHANNEL_BATT_ID, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"usbin", CHANNEL_USBIN, CHAN_PATH_SCALING3, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"pmic_therm", CHANNEL_DIE_TEMP, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_PMIC_THERM},
|
||||||
|
{"625mv", CHANNEL_625MV, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"125v", CHANNEL_125V, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"chg_temp", CHANNEL_CHG_TEMP, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
{"xo_therm", CHANNEL_MUXOFF, CHAN_PATH_SCALING1, AMUX_RSV0,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_XOTHERM},
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
{"usb_id", ADC_MPP_1_AMUX6, CHAN_PATH_SCALING1, AMUX_RSV1,
|
||||||
|
ADC_DECIMATION_TYPE2, ADC_SCALE_DEFAULT},
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_adc_properties apq8064_pm8921_adc_data = {
|
||||||
|
.adc_vdd_reference = 1800, /* milli-voltage for this adc */
|
||||||
|
.bitresolution = 15,
|
||||||
|
.bipolar = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_adc_platform_data apq8064_pm8921_adc_pdata = {
|
||||||
|
.adc_channel = apq8064_pm8921_adc_channels_data,
|
||||||
|
.adc_num_board_channel = ARRAY_SIZE(apq8064_pm8921_adc_channels_data),
|
||||||
|
.adc_prop = &apq8064_pm8921_adc_data,
|
||||||
|
.adc_mpp_base = PM8921_MPP_PM_TO_SYS(1),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_mpp_platform_data
|
||||||
|
apq8064_pm8921_mpp_pdata __devinitdata = {
|
||||||
|
.mpp_base = PM8921_MPP_PM_TO_SYS(1),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_gpio_platform_data
|
||||||
|
apq8064_pm8921_gpio_pdata __devinitdata = {
|
||||||
|
.gpio_base = PM8921_GPIO_PM_TO_SYS(1),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_irq_platform_data
|
||||||
|
apq8064_pm8921_irq_pdata __devinitdata = {
|
||||||
|
.irq_base = PM8921_IRQ_BASE,
|
||||||
|
.devirq = MSM_GPIO_TO_INT(74),
|
||||||
|
.irq_trigger_flag = IRQF_TRIGGER_LOW,
|
||||||
|
.dev_id = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_rtc_platform_data
|
||||||
|
apq8064_pm8921_rtc_pdata = {
|
||||||
|
.rtc_write_enable = false,
|
||||||
|
.rtc_alarm_powerup = false,
|
||||||
|
};
|
||||||
|
|
||||||
|
static int apq8064_pm8921_therm_mitigation[] = {
|
||||||
|
1100,
|
||||||
|
700,
|
||||||
|
600,
|
||||||
|
325,
|
||||||
|
};
|
||||||
|
|
||||||
|
#if (defined(CONFIG_LGE_PM) && defined(CONFIG_LGE_PM_435V_BATT))
|
||||||
|
/*
|
||||||
|
* J1 battery characteristic
|
||||||
|
* Typ.1900mAh capacity, Li-Ion Polymer 3.8V
|
||||||
|
* Battery/VDD voltage programmable range, 20mV steps.
|
||||||
|
* it will be changed in future
|
||||||
|
*/
|
||||||
|
#define MAX_VOLTAGE_MV 4360
|
||||||
|
|
||||||
|
static struct pm8921_charger_platform_data apq8064_pm8921_chg_pdata __devinitdata = {
|
||||||
|
|
||||||
|
/* max charging time in minutes incl. fast and trkl. it will be changed in future */
|
||||||
|
.safety_time = 512, /* 300 change max value for charging time */
|
||||||
|
.update_time = 60000,
|
||||||
|
.max_voltage = MAX_VOLTAGE_MV,
|
||||||
|
|
||||||
|
/* the voltage (mV) where charging method switches from trickle to fast.
|
||||||
|
* This is also the minimum voltage the system operates at */
|
||||||
|
.min_voltage = 3200,
|
||||||
|
/* the (mV) drop to wait for before resume charging after the battery has been fully charged */
|
||||||
|
.resume_voltage_delta = 50,
|
||||||
|
.term_current = 100,
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_CHARGER_TEMP_SCENARIO
|
||||||
|
/* Configuration of cool and warm thresholds (JEITA compliance only) */
|
||||||
|
.cool_temp = 0, /* 10 */ /* 10 degree celsius */
|
||||||
|
.warm_temp = 0, /* 40 */ /* 40 degree celsius */
|
||||||
|
.cool_bat_chg_current = 350, /* 350 mA (max value = 2A) */
|
||||||
|
.warm_bat_chg_current = 350,
|
||||||
|
.temp_level_1 = 550,
|
||||||
|
.temp_level_2 = 450,
|
||||||
|
.temp_level_3 = 420,
|
||||||
|
.temp_level_4 = -50,
|
||||||
|
.temp_level_5 = -100,
|
||||||
|
/* Temperature Thresholds (JEITA compliance) (-10'C ~ 60'C) */
|
||||||
|
.cold_thr = 1, /* 80% */
|
||||||
|
.hot_thr = 0, /* 20% */
|
||||||
|
#else /* qualcomm original value */
|
||||||
|
.cool_temp = 10,
|
||||||
|
.warm_temp = 40,
|
||||||
|
.cool_bat_chg_current = 350,
|
||||||
|
.warm_bat_chg_current = 350,
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.temp_check_period = 1,
|
||||||
|
|
||||||
|
/* Battery charge current programmable range 50mA steps */
|
||||||
|
/* max_bat_chg_current:
|
||||||
|
* Max charge current of the battery in mA
|
||||||
|
* Usually 70% of full charge capacity
|
||||||
|
*/
|
||||||
|
.max_bat_chg_current = 1350,
|
||||||
|
|
||||||
|
.cool_bat_voltage = 4100,
|
||||||
|
.warm_bat_voltage = 4100,
|
||||||
|
.thermal_mitigation = apq8064_pm8921_therm_mitigation,
|
||||||
|
.thermal_levels = ARRAY_SIZE(apq8064_pm8921_therm_mitigation),
|
||||||
|
/* for led on, off control */
|
||||||
|
.led_src_config = LED_SRC_MIN_VPH_5V,
|
||||||
|
};
|
||||||
|
#else /* qualcomm original code */
|
||||||
|
#define MAX_VOLTAGE_MV 4200
|
||||||
|
static struct pm8921_charger_platform_data
|
||||||
|
apq8064_pm8921_chg_pdata __devinitdata = {
|
||||||
|
.safety_time = 180,
|
||||||
|
.update_time = 60000,
|
||||||
|
.max_voltage = MAX_VOLTAGE_MV,
|
||||||
|
.min_voltage = 3200,
|
||||||
|
.resume_voltage_delta = 100,
|
||||||
|
.term_current = 100,
|
||||||
|
.cool_temp = 10,
|
||||||
|
.warm_temp = 40,
|
||||||
|
.temp_check_period = 1,
|
||||||
|
.max_bat_chg_current = 1100,
|
||||||
|
.cool_bat_chg_current = 350,
|
||||||
|
.warm_bat_chg_current = 350,
|
||||||
|
.cool_bat_voltage = 4100,
|
||||||
|
.warm_bat_voltage = 4100,
|
||||||
|
.thermal_mitigation = apq8064_pm8921_therm_mitigation,
|
||||||
|
.thermal_levels = ARRAY_SIZE(apq8064_pm8921_therm_mitigation),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct pm8xxx_ccadc_platform_data
|
||||||
|
apq8064_pm8xxx_ccadc_pdata = {
|
||||||
|
.r_sense = 10,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8921_bms_platform_data
|
||||||
|
apq8064_pm8921_bms_pdata __devinitdata = {
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
.battery_type = BATT_G_LGE,
|
||||||
|
#else
|
||||||
|
.battery_type = BATT_UNKNOWN,
|
||||||
|
#endif
|
||||||
|
.r_sense = 10,
|
||||||
|
.i_test = 834,
|
||||||
|
.v_failure = 3300,
|
||||||
|
.calib_delay_ms = 600000,
|
||||||
|
.max_voltage_uv = MAX_VOLTAGE_MV * 1000,
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
static unsigned int keymap[] = {
|
||||||
|
KEY(0, 0, KEY_VOLUMEUP),
|
||||||
|
KEY(0, 1, KEY_VOLUMEDOWN),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct matrix_keymap_data keymap_data = {
|
||||||
|
.keymap_size = ARRAY_SIZE(keymap),
|
||||||
|
.keymap = keymap,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_keypad_platform_data keypad_data = {
|
||||||
|
.input_name = "keypad_8064",
|
||||||
|
.input_phys_device = "keypad_8064/input0",
|
||||||
|
.num_rows = 1,
|
||||||
|
.num_cols = 5,
|
||||||
|
.rows_gpio_start = PM8921_GPIO_PM_TO_SYS(9),
|
||||||
|
.cols_gpio_start = PM8921_GPIO_PM_TO_SYS(1),
|
||||||
|
.debounce_ms = 15,
|
||||||
|
.scan_delay_ms = 32,
|
||||||
|
.row_hold_ns = 91500,
|
||||||
|
.wakeup = 1,
|
||||||
|
.keymap_data = &keymap_data,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct pm8921_platform_data
|
||||||
|
apq8064_pm8921_platform_data __devinitdata = {
|
||||||
|
.regulator_pdatas = msm8064_pm8921_regulator_pdata,
|
||||||
|
.irq_pdata = &apq8064_pm8921_irq_pdata,
|
||||||
|
.gpio_pdata = &apq8064_pm8921_gpio_pdata,
|
||||||
|
.mpp_pdata = &apq8064_pm8921_mpp_pdata,
|
||||||
|
.rtc_pdata = &apq8064_pm8921_rtc_pdata,
|
||||||
|
.pwrkey_pdata = &apq8064_pm8921_pwrkey_pdata,
|
||||||
|
#ifdef CONFIG_LGE_PM
|
||||||
|
.keypad_pdata = &keypad_data,
|
||||||
|
#endif
|
||||||
|
.misc_pdata = &apq8064_pm8921_misc_pdata,
|
||||||
|
.leds_pdata = &apq8064_pm8921_leds_pdata,
|
||||||
|
.adc_pdata = &apq8064_pm8921_adc_pdata,
|
||||||
|
.charger_pdata = &apq8064_pm8921_chg_pdata,
|
||||||
|
.bms_pdata = &apq8064_pm8921_bms_pdata,
|
||||||
|
.ccadc_pdata = &apq8064_pm8xxx_ccadc_pdata,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_irq_platform_data
|
||||||
|
apq8064_pm8821_irq_pdata __devinitdata = {
|
||||||
|
.irq_base = PM8821_IRQ_BASE,
|
||||||
|
.devirq = PM8821_SEC_IRQ_N,
|
||||||
|
.irq_trigger_flag = IRQF_TRIGGER_HIGH,
|
||||||
|
.dev_id = 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8xxx_mpp_platform_data
|
||||||
|
apq8064_pm8821_mpp_pdata __devinitdata = {
|
||||||
|
.mpp_base = PM8821_MPP_PM_TO_SYS(1),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct pm8821_platform_data
|
||||||
|
apq8064_pm8821_platform_data __devinitdata = {
|
||||||
|
.irq_pdata = &apq8064_pm8821_irq_pdata,
|
||||||
|
.mpp_pdata = &apq8064_pm8821_mpp_pdata,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_ssbi_platform_data apq8064_ssbi_pm8921_pdata __devinitdata = {
|
||||||
|
.controller_type = MSM_SBI_CTRL_PMIC_ARBITER,
|
||||||
|
.slave = {
|
||||||
|
.name = "pm8921-core",
|
||||||
|
.platform_data = &apq8064_pm8921_platform_data,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_ssbi_platform_data apq8064_ssbi_pm8821_pdata __devinitdata = {
|
||||||
|
.controller_type = MSM_SBI_CTRL_PMIC_ARBITER,
|
||||||
|
.slave = {
|
||||||
|
.name = "pm8821-core",
|
||||||
|
.platform_data = &apq8064_pm8821_platform_data,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init apq8064_init_pmic(void)
|
||||||
|
{
|
||||||
|
pmic_reset_irq = PM8921_IRQ_BASE + PM8921_RESOUT_IRQ;
|
||||||
|
|
||||||
|
apq8064_device_ssbi_pmic1.dev.platform_data =
|
||||||
|
&apq8064_ssbi_pm8921_pdata;
|
||||||
|
apq8064_device_ssbi_pmic2.dev.platform_data =
|
||||||
|
&apq8064_ssbi_pm8821_pdata;
|
||||||
|
apq8064_pm8921_platform_data.num_regulators =
|
||||||
|
msm8064_pm8921_regulator_pdata_len;
|
||||||
|
}
|
598
arch/arm/mach-msm/lge/mako/board-mako-regulator.c
Normal file
598
arch/arm/mach-msm/lge/mako/board-mako-regulator.c
Normal file
|
@ -0,0 +1,598 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2011-2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/regulator/pm8xxx-regulator.h>
|
||||||
|
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
#define VREG_CONSUMERS(_id) \
|
||||||
|
static struct regulator_consumer_supply vreg_consumers_##_id[]
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Consumer specific regulator names:
|
||||||
|
* regulator name consumer dev_name
|
||||||
|
*/
|
||||||
|
VREG_CONSUMERS(L1) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l1", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L2) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l2", NULL),
|
||||||
|
REGULATOR_SUPPLY("dsi_vdda", "mipi_dsi.1"),
|
||||||
|
REGULATOR_SUPPLY("mipi_csi_vdd", "msm_csid.0"),
|
||||||
|
REGULATOR_SUPPLY("mipi_csi_vdd", "msm_csid.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L3) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l3", NULL),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_3p3", "msm_otg"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_3p3", "msm_ehci_host.0"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_3p3", "msm_ehci_host.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L4) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l4", NULL),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_1p8", "msm_otg"),
|
||||||
|
REGULATOR_SUPPLY("iris_vddxo", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L5) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l5", NULL),
|
||||||
|
REGULATOR_SUPPLY("sdc_vdd", "msm_sdcc.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L6) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l6", NULL),
|
||||||
|
REGULATOR_SUPPLY("sdc_vdd", "msm_sdcc.3"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L7) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l7", NULL),
|
||||||
|
REGULATOR_SUPPLY("sdc_vdd_io", "msm_sdcc.3"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L8) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l8", NULL),
|
||||||
|
REGULATOR_SUPPLY("cam_vana", "4-001a"),
|
||||||
|
REGULATOR_SUPPLY("cam_vana", "4-0048"),
|
||||||
|
REGULATOR_SUPPLY("cam_vana", "4-006c"),
|
||||||
|
REGULATOR_SUPPLY("cam_vana", "4-0034"),
|
||||||
|
REGULATOR_SUPPLY("cam_vana", "4-0020"),
|
||||||
|
REGULATOR_SUPPLY("dsi_vci", "mipi_dsi.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L9) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l9", NULL),
|
||||||
|
REGULATOR_SUPPLY("vdd", "3-0024"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L10) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l10", NULL),
|
||||||
|
REGULATOR_SUPPLY("iris_vddpa", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L11) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l11", NULL),
|
||||||
|
REGULATOR_SUPPLY("dsi1_avdd", "mipi_dsi.1"),
|
||||||
|
REGULATOR_SUPPLY("cam1_vana", "4-000d"), /* GSBI4, Slave Addr: 0x0d, imx111 */
|
||||||
|
REGULATOR_SUPPLY("cam2_vana", "4-006e"), /* GSBI4, Slave Addr: 0x6e, imx119 */
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L12) = {
|
||||||
|
REGULATOR_SUPPLY("cam1_vdig", "4-000d"), /* GSBI4, Slave Addr: 0x0d, imx111 */
|
||||||
|
REGULATOR_SUPPLY("cam2_vdig", "4-006e"), /* GSBI4, Slave Addr: 0x6e, imx119 */
|
||||||
|
REGULATOR_SUPPLY("8921_l12", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L14) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l14", NULL),
|
||||||
|
REGULATOR_SUPPLY("pa_therm", "pm8xxx-adc"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L15) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l15", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L16) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l16", NULL),
|
||||||
|
REGULATOR_SUPPLY("cam_vaf", "4-001a"),
|
||||||
|
REGULATOR_SUPPLY("cam_vaf", "4-0048"),
|
||||||
|
REGULATOR_SUPPLY("cam_vaf", "4-006c"),
|
||||||
|
REGULATOR_SUPPLY("cam_vaf", "4-0034"),
|
||||||
|
REGULATOR_SUPPLY("cam_vaf", "4-0020"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L17) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l17", NULL),
|
||||||
|
#if defined(CONFIG_IMX111)
|
||||||
|
REGULATOR_SUPPLY("cam1_vaf", "4-000d"), /* GSBI4, Slave Addr: 0x0d, imx111 */
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L18) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l18", NULL),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Power setting for 13M AF */
|
||||||
|
#if defined(CONFIG_IMX091)
|
||||||
|
VREG_CONSUMERS(L21) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l21", NULL),
|
||||||
|
REGULATOR_SUPPLY("cam1_vaf", "4-000d"), /* GSBI4, Slave Addr: 0x0d, imx091 */
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
VREG_CONSUMERS(L21) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l21", NULL),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
VREG_CONSUMERS(L22) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l22", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L23) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l23", NULL),
|
||||||
|
REGULATOR_SUPPLY("dsi_vddio", "mipi_dsi.1"),
|
||||||
|
REGULATOR_SUPPLY("pll_vdd", "pil_qdsp6v4.1"),
|
||||||
|
REGULATOR_SUPPLY("pll_vdd", "pil_qdsp6v4.2"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_1p8", "msm_ehci_host.0"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_1p8", "msm_ehci_host.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L24) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l24", NULL),
|
||||||
|
REGULATOR_SUPPLY("riva_vddmx", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L25) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l25", NULL),
|
||||||
|
REGULATOR_SUPPLY("VDDD_CDC_D", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_A_1P2V", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("VDDD_CDC_D", "tabla2x-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_A_1P2V", "tabla2x-slim"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L26) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l26", NULL),
|
||||||
|
REGULATOR_SUPPLY("core_vdd", "pil_qdsp6v4.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L27) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l27", NULL),
|
||||||
|
REGULATOR_SUPPLY("core_vdd", "pil_qdsp6v4.2"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L28) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l28", NULL),
|
||||||
|
REGULATOR_SUPPLY("core_vdd", "pil_qdsp6v4.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(L29) = {
|
||||||
|
REGULATOR_SUPPLY("8921_l29", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S1) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s1", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S2) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s2", NULL),
|
||||||
|
REGULATOR_SUPPLY("iris_vddrfa", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S3) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s3", NULL),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_VDDCX", "msm_otg"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_VDDCX", "msm_ehci_host.0"),
|
||||||
|
REGULATOR_SUPPLY("HSUSB_VDDCX", "msm_ehci_host.1"),
|
||||||
|
REGULATOR_SUPPLY("HSIC_VDDCX", "msm_hsic_host"),
|
||||||
|
REGULATOR_SUPPLY("riva_vddcx", "wcnss_wlan.0"),
|
||||||
|
REGULATOR_SUPPLY("vp_pcie", "msm_pcie"),
|
||||||
|
REGULATOR_SUPPLY("vptx_pcie", "msm_pcie"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S4) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s4", NULL),
|
||||||
|
REGULATOR_SUPPLY("sdc_vdd_io", "msm_sdcc.1"),
|
||||||
|
REGULATOR_SUPPLY("VDDIO_CDC", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDD_CP", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_TX", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_RX", "tabla-slim"),
|
||||||
|
REGULATOR_SUPPLY("VDDIO_CDC", "tabla2x-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDD_CP", "tabla2x-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_TX", "tabla2x-slim"),
|
||||||
|
REGULATOR_SUPPLY("CDC_VDDA_RX", "tabla2x-slim"),
|
||||||
|
REGULATOR_SUPPLY("riva_vddpx", "wcnss_wlan.0"),
|
||||||
|
REGULATOR_SUPPLY("vcc_i2c", "3-005b"),
|
||||||
|
REGULATOR_SUPPLY("vcc_i2c", "3-0024"),
|
||||||
|
REGULATOR_SUPPLY("vddp", "0-0048"),
|
||||||
|
REGULATOR_SUPPLY("hdmi_lvl_tsl", "hdmi_msm.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S5) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s5", NULL),
|
||||||
|
REGULATOR_SUPPLY("krait0", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S6) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s6", NULL),
|
||||||
|
REGULATOR_SUPPLY("krait1", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(S7) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s7", NULL),
|
||||||
|
};
|
||||||
|
#if defined(CONFIG_IMX091)
|
||||||
|
VREG_CONSUMERS(S8) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s8", NULL),
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
VREG_CONSUMERS(S8) = {
|
||||||
|
REGULATOR_SUPPLY("8921_s8", NULL),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
VREG_CONSUMERS(LVS1) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs1", NULL),
|
||||||
|
REGULATOR_SUPPLY("iris_vddio", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS2) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs2", NULL),
|
||||||
|
REGULATOR_SUPPLY("iris_vdddig", "wcnss_wlan.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS3) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs3", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS4) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs4", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS5) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs5", NULL),
|
||||||
|
REGULATOR_SUPPLY("cam1_vio", "4-000d"), /* GSBI4, Slave Addr: 0x0d, imx111 */
|
||||||
|
REGULATOR_SUPPLY("cam2_vio", "4-006e"), /* GSBI4, Slave Addr: 0x6e, imx119 */
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS6) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs6", NULL),
|
||||||
|
REGULATOR_SUPPLY("vdd_pcie_vph", "msm_pcie"),
|
||||||
|
REGULATOR_SUPPLY("dsi_iovcc", "mipi_dsi.1"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(LVS7) = {
|
||||||
|
REGULATOR_SUPPLY("8921_lvs7", NULL),
|
||||||
|
REGULATOR_SUPPLY("pll_vdd", "pil_riva"),
|
||||||
|
REGULATOR_SUPPLY("lvds_vdda", "lvds.0"),
|
||||||
|
REGULATOR_SUPPLY("dsi1_vddio", "mipi_dsi.1"),
|
||||||
|
REGULATOR_SUPPLY("hdmi_vdda", "hdmi_msm.0"),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(NCP) = {
|
||||||
|
REGULATOR_SUPPLY("8921_ncp", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(8821_S0) = {
|
||||||
|
REGULATOR_SUPPLY("8821_s0", NULL),
|
||||||
|
REGULATOR_SUPPLY("krait2", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(8821_S1) = {
|
||||||
|
REGULATOR_SUPPLY("8821_s1", NULL),
|
||||||
|
REGULATOR_SUPPLY("krait3", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(FRC_5V) = {
|
||||||
|
REGULATOR_SUPPLY("frc_5v", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(AVC_1P2V) = {
|
||||||
|
REGULATOR_SUPPLY("avc_1p2v", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(AVC_1P8V) = {
|
||||||
|
REGULATOR_SUPPLY("avc_1p8v", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(AVC_2P2V) = {
|
||||||
|
REGULATOR_SUPPLY("avc_2p2v", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(AVC_5V) = {
|
||||||
|
REGULATOR_SUPPLY("avc_5v", NULL),
|
||||||
|
};
|
||||||
|
VREG_CONSUMERS(AVC_3P3V) = {
|
||||||
|
REGULATOR_SUPPLY("avc_3p3v", NULL),
|
||||||
|
};
|
||||||
|
|
||||||
|
#define PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, _modes, _ops, \
|
||||||
|
_apply_uV, _pull_down, _always_on, _supply_regulator, \
|
||||||
|
_system_uA, _enable_time, _reg_id) \
|
||||||
|
{ \
|
||||||
|
.init_data = { \
|
||||||
|
.constraints = { \
|
||||||
|
.valid_modes_mask = _modes, \
|
||||||
|
.valid_ops_mask = _ops, \
|
||||||
|
.min_uV = _min_uV, \
|
||||||
|
.max_uV = _max_uV, \
|
||||||
|
.input_uV = _max_uV, \
|
||||||
|
.apply_uV = _apply_uV, \
|
||||||
|
.always_on = _always_on, \
|
||||||
|
.name = _name, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = \
|
||||||
|
ARRAY_SIZE(vreg_consumers_##_id), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id, \
|
||||||
|
.supply_regulator = _supply_regulator, \
|
||||||
|
}, \
|
||||||
|
.id = _reg_id, \
|
||||||
|
.pull_down_enable = _pull_down, \
|
||||||
|
.system_uA = _system_uA, \
|
||||||
|
.enable_time = _enable_time, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define PM8XXX_LDO(_id, _name, _always_on, _pull_down, _min_uV, _max_uV, \
|
||||||
|
_enable_time, _supply_regulator, _system_uA, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, REGULATOR_MODE_NORMAL \
|
||||||
|
| REGULATOR_MODE_IDLE, REGULATOR_CHANGE_VOLTAGE | \
|
||||||
|
REGULATOR_CHANGE_STATUS | REGULATOR_CHANGE_MODE | \
|
||||||
|
REGULATOR_CHANGE_DRMS, 0, _pull_down, _always_on, \
|
||||||
|
_supply_regulator, _system_uA, _enable_time, _reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_NLDO1200(_id, _name, _always_on, _pull_down, _min_uV, \
|
||||||
|
_max_uV, _enable_time, _supply_regulator, _system_uA, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, REGULATOR_MODE_NORMAL \
|
||||||
|
| REGULATOR_MODE_IDLE, REGULATOR_CHANGE_VOLTAGE | \
|
||||||
|
REGULATOR_CHANGE_STATUS | REGULATOR_CHANGE_MODE | \
|
||||||
|
REGULATOR_CHANGE_DRMS, 0, _pull_down, _always_on, \
|
||||||
|
_supply_regulator, _system_uA, _enable_time, _reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_SMPS(_id, _name, _always_on, _pull_down, _min_uV, _max_uV, \
|
||||||
|
_enable_time, _supply_regulator, _system_uA, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, REGULATOR_MODE_NORMAL \
|
||||||
|
| REGULATOR_MODE_IDLE, REGULATOR_CHANGE_VOLTAGE | \
|
||||||
|
REGULATOR_CHANGE_STATUS | REGULATOR_CHANGE_MODE | \
|
||||||
|
REGULATOR_CHANGE_DRMS, 0, _pull_down, _always_on, \
|
||||||
|
_supply_regulator, _system_uA, _enable_time, _reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_FTSMPS(_id, _name, _always_on, _pull_down, _min_uV, _max_uV, \
|
||||||
|
_enable_time, _supply_regulator, _system_uA, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, REGULATOR_MODE_NORMAL, \
|
||||||
|
REGULATOR_CHANGE_VOLTAGE | REGULATOR_CHANGE_STATUS \
|
||||||
|
| REGULATOR_CHANGE_MODE, 0, _pull_down, _always_on, \
|
||||||
|
_supply_regulator, _system_uA, _enable_time, _reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_VS(_id, _name, _always_on, _pull_down, _enable_time, \
|
||||||
|
_supply_regulator, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, 0, 0, 0, REGULATOR_CHANGE_STATUS, 0, \
|
||||||
|
_pull_down, _always_on, _supply_regulator, 0, _enable_time, \
|
||||||
|
_reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_VS300(_id, _name, _always_on, _pull_down, _enable_time, \
|
||||||
|
_supply_regulator, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, 0, 0, 0, REGULATOR_CHANGE_STATUS, 0, \
|
||||||
|
_pull_down, _always_on, _supply_regulator, 0, _enable_time, \
|
||||||
|
_reg_id)
|
||||||
|
|
||||||
|
#define PM8XXX_NCP(_id, _name, _always_on, _min_uV, _max_uV, _enable_time, \
|
||||||
|
_supply_regulator, _reg_id) \
|
||||||
|
PM8XXX_VREG_INIT(_id, _name, _min_uV, _max_uV, 0, \
|
||||||
|
REGULATOR_CHANGE_VOLTAGE | REGULATOR_CHANGE_STATUS, 0, 0, \
|
||||||
|
_always_on, _supply_regulator, 0, _enable_time, _reg_id)
|
||||||
|
|
||||||
|
/* Pin control initialization */
|
||||||
|
#define PM8XXX_PC(_id, _name, _always_on, _pin_fn, _pin_ctrl, \
|
||||||
|
_supply_regulator, _reg_id) \
|
||||||
|
{ \
|
||||||
|
.init_data = { \
|
||||||
|
.constraints = { \
|
||||||
|
.valid_ops_mask = REGULATOR_CHANGE_STATUS, \
|
||||||
|
.always_on = _always_on, \
|
||||||
|
.name = _name, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = \
|
||||||
|
ARRAY_SIZE(vreg_consumers_##_id##_PC), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id##_PC, \
|
||||||
|
.supply_regulator = _supply_regulator, \
|
||||||
|
}, \
|
||||||
|
.id = _reg_id, \
|
||||||
|
.pin_fn = PM8XXX_VREG_PIN_FN_##_pin_fn, \
|
||||||
|
.pin_ctrl = _pin_ctrl, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define GPIO_VREG(_id, _reg_name, _gpio_label, _gpio, _supply_regulator) \
|
||||||
|
[GPIO_VREG_ID_##_id] = { \
|
||||||
|
.init_data = { \
|
||||||
|
.constraints = { \
|
||||||
|
.valid_ops_mask = REGULATOR_CHANGE_STATUS, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = \
|
||||||
|
ARRAY_SIZE(vreg_consumers_##_id), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id, \
|
||||||
|
.supply_regulator = _supply_regulator, \
|
||||||
|
}, \
|
||||||
|
.regulator_name = _reg_name, \
|
||||||
|
.gpio_label = _gpio_label, \
|
||||||
|
.gpio = _gpio, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define SAW_VREG_INIT(_id, _name, _min_uV, _max_uV) \
|
||||||
|
{ \
|
||||||
|
.constraints = { \
|
||||||
|
.name = _name, \
|
||||||
|
.valid_ops_mask = REGULATOR_CHANGE_VOLTAGE, \
|
||||||
|
.min_uV = _min_uV, \
|
||||||
|
.max_uV = _max_uV, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = ARRAY_SIZE(vreg_consumers_##_id), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define RPM_INIT(_id, _min_uV, _max_uV, _modes, _ops, _apply_uV, _default_uV, \
|
||||||
|
_peak_uA, _avg_uA, _pull_down, _pin_ctrl, _freq, _pin_fn, \
|
||||||
|
_force_mode, _sleep_set_force_mode, _power_mode, _state, \
|
||||||
|
_sleep_selectable, _always_on, _supply_regulator, _system_uA) \
|
||||||
|
{ \
|
||||||
|
.init_data = { \
|
||||||
|
.constraints = { \
|
||||||
|
.valid_modes_mask = _modes, \
|
||||||
|
.valid_ops_mask = _ops, \
|
||||||
|
.min_uV = _min_uV, \
|
||||||
|
.max_uV = _max_uV, \
|
||||||
|
.input_uV = _min_uV, \
|
||||||
|
.apply_uV = _apply_uV, \
|
||||||
|
.always_on = _always_on, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = \
|
||||||
|
ARRAY_SIZE(vreg_consumers_##_id), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id, \
|
||||||
|
.supply_regulator = _supply_regulator, \
|
||||||
|
}, \
|
||||||
|
.id = RPM_VREG_ID_PM8921_##_id, \
|
||||||
|
.default_uV = _default_uV, \
|
||||||
|
.peak_uA = _peak_uA, \
|
||||||
|
.avg_uA = _avg_uA, \
|
||||||
|
.pull_down_enable = _pull_down, \
|
||||||
|
.pin_ctrl = _pin_ctrl, \
|
||||||
|
.freq = RPM_VREG_FREQ_##_freq, \
|
||||||
|
.pin_fn = _pin_fn, \
|
||||||
|
.force_mode = _force_mode, \
|
||||||
|
.sleep_set_force_mode = _sleep_set_force_mode, \
|
||||||
|
.power_mode = _power_mode, \
|
||||||
|
.state = _state, \
|
||||||
|
.sleep_selectable = _sleep_selectable, \
|
||||||
|
.system_uA = _system_uA, \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define RPM_LDO(_id, _always_on, _pd, _sleep_selectable, _min_uV, _max_uV, \
|
||||||
|
_supply_regulator, _system_uA, _init_peak_uA) \
|
||||||
|
RPM_INIT(_id, _min_uV, _max_uV, REGULATOR_MODE_NORMAL \
|
||||||
|
| REGULATOR_MODE_IDLE, REGULATOR_CHANGE_VOLTAGE \
|
||||||
|
| REGULATOR_CHANGE_STATUS | REGULATOR_CHANGE_MODE \
|
||||||
|
| REGULATOR_CHANGE_DRMS, 0, _max_uV, _init_peak_uA, 0, _pd, \
|
||||||
|
RPM_VREG_PIN_CTRL_NONE, NONE, RPM_VREG_PIN_FN_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, RPM_VREG_POWER_MODE_8960_PWM, \
|
||||||
|
RPM_VREG_STATE_OFF, _sleep_selectable, _always_on, \
|
||||||
|
_supply_regulator, _system_uA)
|
||||||
|
|
||||||
|
#define RPM_SMPS(_id, _always_on, _pd, _sleep_selectable, _min_uV, _max_uV, \
|
||||||
|
_supply_regulator, _system_uA, _freq, _force_mode, \
|
||||||
|
_sleep_set_force_mode) \
|
||||||
|
RPM_INIT(_id, _min_uV, _max_uV, REGULATOR_MODE_NORMAL \
|
||||||
|
| REGULATOR_MODE_IDLE, REGULATOR_CHANGE_VOLTAGE \
|
||||||
|
| REGULATOR_CHANGE_STATUS | REGULATOR_CHANGE_MODE \
|
||||||
|
| REGULATOR_CHANGE_DRMS, 0, _max_uV, _system_uA, 0, _pd, \
|
||||||
|
RPM_VREG_PIN_CTRL_NONE, _freq, RPM_VREG_PIN_FN_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_##_force_mode, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_##_sleep_set_force_mode, \
|
||||||
|
RPM_VREG_POWER_MODE_8960_PWM, RPM_VREG_STATE_OFF, \
|
||||||
|
_sleep_selectable, _always_on, _supply_regulator, _system_uA)
|
||||||
|
|
||||||
|
#define RPM_VS(_id, _always_on, _pd, _sleep_selectable, _supply_regulator) \
|
||||||
|
RPM_INIT(_id, 0, 0, 0, REGULATOR_CHANGE_STATUS, 0, 0, 1000, 1000, _pd, \
|
||||||
|
RPM_VREG_PIN_CTRL_NONE, NONE, RPM_VREG_PIN_FN_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, RPM_VREG_POWER_MODE_8960_PWM, \
|
||||||
|
RPM_VREG_STATE_OFF, _sleep_selectable, _always_on, \
|
||||||
|
_supply_regulator, 0)
|
||||||
|
|
||||||
|
#define RPM_NCP(_id, _always_on, _sleep_selectable, _min_uV, _max_uV, \
|
||||||
|
_supply_regulator, _freq) \
|
||||||
|
RPM_INIT(_id, _min_uV, _max_uV, 0, REGULATOR_CHANGE_VOLTAGE \
|
||||||
|
| REGULATOR_CHANGE_STATUS, 0, _max_uV, 1000, 1000, 0, \
|
||||||
|
RPM_VREG_PIN_CTRL_NONE, _freq, RPM_VREG_PIN_FN_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, \
|
||||||
|
RPM_VREG_FORCE_MODE_8960_NONE, RPM_VREG_POWER_MODE_8960_PWM, \
|
||||||
|
RPM_VREG_STATE_OFF, _sleep_selectable, _always_on, \
|
||||||
|
_supply_regulator, 0)
|
||||||
|
|
||||||
|
/* Pin control initialization */
|
||||||
|
#define RPM_PC_INIT(_id, _always_on, _pin_fn, _pin_ctrl, _supply_regulator) \
|
||||||
|
{ \
|
||||||
|
.init_data = { \
|
||||||
|
.constraints = { \
|
||||||
|
.valid_ops_mask = REGULATOR_CHANGE_STATUS, \
|
||||||
|
.always_on = _always_on, \
|
||||||
|
}, \
|
||||||
|
.num_consumer_supplies = \
|
||||||
|
ARRAY_SIZE(vreg_consumers_##_id##_PC), \
|
||||||
|
.consumer_supplies = vreg_consumers_##_id##_PC, \
|
||||||
|
.supply_regulator = _supply_regulator, \
|
||||||
|
}, \
|
||||||
|
.id = RPM_VREG_ID_PM8921_##_id##_PC, \
|
||||||
|
.pin_fn = RPM_VREG_PIN_FN_8960_##_pin_fn, \
|
||||||
|
.pin_ctrl = _pin_ctrl, \
|
||||||
|
}
|
||||||
|
|
||||||
|
struct gpio_regulator_platform_data
|
||||||
|
mpq8064_gpio_regulator_pdata[] __devinitdata = {
|
||||||
|
GPIO_VREG(FRC_5V, "frc_5v", "frc_5v_en", SX150X_GPIO(4, 10), NULL),
|
||||||
|
GPIO_VREG(AVC_1P2V, "avc_1p2v", "avc_1p2v_en", SX150X_GPIO(4, 2), NULL),
|
||||||
|
GPIO_VREG(AVC_1P8V, "avc_1p8v", "avc_1p8v_en", SX150X_GPIO(4, 4), NULL),
|
||||||
|
GPIO_VREG(AVC_2P2V, "avc_2p2v", "avc_2p2v_en",
|
||||||
|
SX150X_GPIO(4, 14), NULL),
|
||||||
|
GPIO_VREG(AVC_5V, "avc_5v", "avc_5v_en", SX150X_GPIO(4, 3), NULL),
|
||||||
|
GPIO_VREG(AVC_3P3V, "avc_3p3v", "avc_3p3v_en",
|
||||||
|
SX150X_GPIO(4, 15), "avc_5v"),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SAW regulator constraints */
|
||||||
|
struct regulator_init_data msm8064_saw_regulator_pdata_8921_s5 =
|
||||||
|
/* ID vreg_name min_uV max_uV */
|
||||||
|
SAW_VREG_INIT(S5, "8921_s5", 950000, 1300000);
|
||||||
|
struct regulator_init_data msm8064_saw_regulator_pdata_8921_s6 =
|
||||||
|
SAW_VREG_INIT(S6, "8921_s6", 950000, 1300000);
|
||||||
|
|
||||||
|
struct regulator_init_data msm8064_saw_regulator_pdata_8821_s0 =
|
||||||
|
/* ID vreg_name min_uV max_uV */
|
||||||
|
SAW_VREG_INIT(8821_S0, "8821_s0", 950000, 1300000);
|
||||||
|
struct regulator_init_data msm8064_saw_regulator_pdata_8821_s1 =
|
||||||
|
SAW_VREG_INIT(8821_S1, "8821_s1", 950000, 1300000);
|
||||||
|
|
||||||
|
/* PM8921 regulator constraints */
|
||||||
|
struct pm8xxx_regulator_platform_data
|
||||||
|
msm8064_pm8921_regulator_pdata[] __devinitdata = {
|
||||||
|
/*
|
||||||
|
* ID name always_on pd min_uV max_uV en_t supply
|
||||||
|
* system_uA reg_ID
|
||||||
|
*/
|
||||||
|
PM8XXX_NLDO1200(L26, "8921_l26", 0, 1, 375000, 1050000, 200, "8921_s7",
|
||||||
|
0, 1),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct rpm_regulator_init_data
|
||||||
|
apq8064_rpm_regulator_init_data[] __devinitdata = {
|
||||||
|
/* ID a_on pd ss min_uV max_uV supply sys_uA freq fm ss_fm */
|
||||||
|
RPM_SMPS(S1, 1, 1, 0, 1225000, 1225000, NULL, 100000, 3p20, NONE, NONE),
|
||||||
|
RPM_SMPS(S2, 0, 1, 0, 1300000, 1300000, NULL, 0, 1p60, NONE, NONE),
|
||||||
|
RPM_SMPS(S3, 0, 1, 1, 500000, 1150000, NULL, 100000, 4p80, NONE, NONE),
|
||||||
|
RPM_SMPS(S4, 1, 1, 0, 1800000, 1800000, NULL, 100000, 1p60, AUTO, AUTO),
|
||||||
|
RPM_SMPS(S7, 0, 1, 0, 1300000, 1300000, NULL, 100000, 3p20, NONE, NONE),
|
||||||
|
#if defined(CONFIG_IMX091)
|
||||||
|
RPM_SMPS(S8, 0, 1, 0, 1800000, 1800000, NULL, 100000, 1p60, NONE, NONE),
|
||||||
|
#else
|
||||||
|
RPM_SMPS(S8, 0, 1, 0, 2200000, 2200000, NULL, 0, 1p60, NONE, NONE),
|
||||||
|
#endif
|
||||||
|
/* ID a_on pd ss min_uV max_uV supply sys_uA init_ip */
|
||||||
|
RPM_LDO(L1, 1, 1, 0, 1100000, 1100000, "8921_s4", 0, 1000),
|
||||||
|
RPM_LDO(L2, 0, 1, 0, 1200000, 1200000, "8921_s4", 0, 0),
|
||||||
|
/* HSUSB 3p3: max 3.5v */
|
||||||
|
RPM_LDO(L3, 0, 1, 0, 3075000, 3500000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L4, 1, 1, 0, 1800000, 1800000, NULL, 0, 10000),
|
||||||
|
RPM_LDO(L5, 0, 1, 0, 2950000, 2950000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L6, 0, 1, 0, 2950000, 2950000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L7, 0, 1, 0, 1850000, 2950000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L8, 0, 1, 0, 2800000, 3000000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L9, 0, 1, 0, 3000000, 3000000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L10, 0, 1, 0, 2900000, 2900000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L11, 0, 1, 0, 2850000, 2850000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L12, 0, 1, 0, 1200000, 1200000, "8921_s4", 0, 0),
|
||||||
|
RPM_LDO(L14, 0, 1, 0, 1800000, 1800000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L15, 0, 1, 0, 3300000, 3300000, NULL, 0, 19),
|
||||||
|
RPM_LDO(L16, 0, 1, 0, 2800000, 2800000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L17, 0, 1, 0, 2800000, 2800000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L18, 0, 1, 0, 1100000, 1300000, NULL, 0, 0),
|
||||||
|
#if defined(CONFIG_IMX091)
|
||||||
|
RPM_LDO(L21, 0, 1, 0, 1800000, 1800000, "8921_s8", 0, 0),
|
||||||
|
#else
|
||||||
|
RPM_LDO(L21, 0, 1, 0, 1050000, 1050000, NULL, 0, 0),
|
||||||
|
#endif
|
||||||
|
RPM_LDO(L22, 0, 1, 0, 1800000, 1800000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L23, 0, 1, 0, 1800000, 1800000, NULL, 0, 0),
|
||||||
|
RPM_LDO(L24, 0, 1, 1, 750000, 1150000, "8921_s1", 10000, 10000),
|
||||||
|
RPM_LDO(L25, 1, 1, 0, 1225000, 1225000, "8921_s1", 10000, 10000),
|
||||||
|
RPM_LDO(L27, 0, 1, 0, 1100000, 1100000, "8921_s7", 0, 0),
|
||||||
|
RPM_LDO(L28, 0, 1, 0, 1050000, 1050000, "8921_s7", 0, 0),
|
||||||
|
RPM_LDO(L29, 0, 1, 0, 2000000, 2000000, NULL, 0, 0),
|
||||||
|
|
||||||
|
/* ID a_on pd ss supply */
|
||||||
|
RPM_VS(LVS1, 0, 1, 0, "8921_s4"),
|
||||||
|
RPM_VS(LVS2, 0, 1, 0, "8921_s1"),
|
||||||
|
RPM_VS(LVS3, 0, 1, 0, "8921_s4"),
|
||||||
|
RPM_VS(LVS4, 0, 1, 0, "8921_s4"),
|
||||||
|
RPM_VS(LVS5, 0, 1, 0, "8921_s4"),
|
||||||
|
RPM_VS(LVS6, 0, 1, 0, "8921_s4"),
|
||||||
|
RPM_VS(LVS7, 0, 1, 1, "8921_s4"),
|
||||||
|
|
||||||
|
/* ID a_on ss min_uV max_uV supply freq */
|
||||||
|
RPM_NCP(NCP, 0, 0, 1800000, 1800000, "8921_l6", 1p60),
|
||||||
|
};
|
||||||
|
|
||||||
|
int msm8064_pm8921_regulator_pdata_len __devinitdata =
|
||||||
|
ARRAY_SIZE(msm8064_pm8921_regulator_pdata);
|
||||||
|
|
||||||
|
struct rpm_regulator_platform_data apq8064_rpm_regulator_pdata __devinitdata = {
|
||||||
|
.init_data = apq8064_rpm_regulator_init_data,
|
||||||
|
.num_regulators = ARRAY_SIZE(apq8064_rpm_regulator_init_data),
|
||||||
|
.version = RPM_VREG_VERSION_8960,
|
||||||
|
.vreg_id_vdd_mem = RPM_VREG_ID_PM8921_L24,
|
||||||
|
.vreg_id_vdd_dig = RPM_VREG_ID_PM8921_S3,
|
||||||
|
};
|
218
arch/arm/mach-msm/lge/mako/board-mako-sound.c
Normal file
218
arch/arm/mach-msm/lge/mako/board-mako-sound.c
Normal file
|
@ -0,0 +1,218 @@
|
||||||
|
/* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
#include <linux/regulator/consumer.h>
|
||||||
|
#include "devices.h"
|
||||||
|
|
||||||
|
#include "board-8064.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_SWITCH_FSA8008
|
||||||
|
#include "../../../../sound/soc/codecs/wcd9310.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_AUDIO_TPA2028D
|
||||||
|
#include <sound/tpa2028d.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "board-mako.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define TPA2028D_ADDRESS (0xB0>>1)
|
||||||
|
#define MSM_AMP_EN (PM8921_GPIO_PM_TO_SYS(19))
|
||||||
|
#define AGC_COMPRESIION_RATE 0
|
||||||
|
#define AGC_OUTPUT_LIMITER_DISABLE 1
|
||||||
|
#define AGC_FIXED_GAIN 12
|
||||||
|
|
||||||
|
|
||||||
|
#define GPIO_EAR_SENSE_N 82
|
||||||
|
#define GPIO_EAR_MIC_EN PM8921_GPIO_PM_TO_SYS(31)
|
||||||
|
#define GPIO_EARPOL_DETECT PM8921_GPIO_PM_TO_SYS(32)
|
||||||
|
#define GPIO_EAR_KEY_INT 83
|
||||||
|
|
||||||
|
|
||||||
|
#define I2C_SURF 1
|
||||||
|
#define I2C_FFA (1 << 1)
|
||||||
|
#define I2C_RUMI (1 << 2)
|
||||||
|
#define I2C_SIM (1 << 3)
|
||||||
|
#define I2C_LIQUID (1 << 4)
|
||||||
|
#define I2C_J1V (1 << 5)
|
||||||
|
|
||||||
|
struct i2c_registry {
|
||||||
|
u8 machs;
|
||||||
|
int bus;
|
||||||
|
struct i2c_board_info *info;
|
||||||
|
int len;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct fsa8008_platform_data {
|
||||||
|
const char *switch_name; /* switch device name */
|
||||||
|
const char *keypad_name; /* keypad device name */
|
||||||
|
|
||||||
|
unsigned int key_code; /* key code for hook */
|
||||||
|
|
||||||
|
unsigned int gpio_detect; /* DET : to detect jack inserted or not */
|
||||||
|
unsigned int gpio_mic_en; /* EN : to enable mic */
|
||||||
|
unsigned int gpio_jpole; /* JPOLE : 3pole or 4pole */
|
||||||
|
unsigned int gpio_key; /* S/E button */
|
||||||
|
|
||||||
|
/* callback function which is initialized while probing */
|
||||||
|
void (*set_headset_mic_bias)(int enable);
|
||||||
|
|
||||||
|
/* latency for pole (3 or 4)detection (in ms) */
|
||||||
|
unsigned int latency_for_detection;
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_LGE_AUDIO_TPA2028D
|
||||||
|
int amp_power(bool on)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int amp_enable(int on_state)
|
||||||
|
{
|
||||||
|
int err = 0;
|
||||||
|
static int init_status = 0;
|
||||||
|
struct pm_gpio param = {
|
||||||
|
.direction = PM_GPIO_DIR_OUT,
|
||||||
|
.output_buffer = PM_GPIO_OUT_BUF_CMOS,
|
||||||
|
.output_value = 1,
|
||||||
|
.pull = PM_GPIO_PULL_NO,
|
||||||
|
.vin_sel = PM_GPIO_VIN_S4,
|
||||||
|
.out_strength = PM_GPIO_STRENGTH_MED,
|
||||||
|
.function = PM_GPIO_FUNC_NORMAL,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (init_status == 0) {
|
||||||
|
err = gpio_request(MSM_AMP_EN, "AMP_EN");
|
||||||
|
if (err)
|
||||||
|
pr_err("%s: Error requesting GPIO %d\n",
|
||||||
|
__func__, MSM_AMP_EN);
|
||||||
|
|
||||||
|
err = pm8xxx_gpio_config(MSM_AMP_EN, ¶m);
|
||||||
|
if (err)
|
||||||
|
pr_err("%s: Failed to configure gpio %d\n",
|
||||||
|
__func__, MSM_AMP_EN);
|
||||||
|
else
|
||||||
|
init_status++;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (on_state) {
|
||||||
|
case 0:
|
||||||
|
err = gpio_direction_output(MSM_AMP_EN, 0);
|
||||||
|
printk(KERN_INFO "%s: AMP_EN is set to 0\n", __func__);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
err = gpio_direction_output(MSM_AMP_EN, 1);
|
||||||
|
printk(KERN_INFO "%s: AMP_EN is set to 1\n", __func__);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
printk(KERN_INFO "%s: amp enable bypass(%d)\n", __func__, on_state);
|
||||||
|
err = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
pr_err("amp enable fail\n");
|
||||||
|
err = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct audio_amp_platform_data amp_platform_data = {
|
||||||
|
.enable = amp_enable,
|
||||||
|
.power = amp_power,
|
||||||
|
.agc_compression_rate = AGC_COMPRESIION_RATE,
|
||||||
|
.agc_output_limiter_disable = AGC_OUTPUT_LIMITER_DISABLE,
|
||||||
|
.agc_fixed_gain = AGC_FIXED_GAIN,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct i2c_board_info msm_i2c_audiosubsystem_info[] = {
|
||||||
|
#ifdef CONFIG_LGE_AUDIO_TPA2028D
|
||||||
|
{
|
||||||
|
I2C_BOARD_INFO("tpa2028d_amp", TPA2028D_ADDRESS),
|
||||||
|
.platform_data = &_platform_data,
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
static struct i2c_registry msm_i2c_audiosubsystem __initdata = {
|
||||||
|
/* Add the I2C driver for Audio Amp */
|
||||||
|
I2C_SURF | I2C_FFA | I2C_RUMI | I2C_SIM | I2C_LIQUID | I2C_J1V,
|
||||||
|
APQ_8064_GSBI1_QUP_I2C_BUS_ID,
|
||||||
|
msm_i2c_audiosubsystem_info,
|
||||||
|
ARRAY_SIZE(msm_i2c_audiosubsystem_info),
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
static void __init lge_add_i2c_tpa2028d_devices(void)
|
||||||
|
{
|
||||||
|
/* Run the array and install devices as appropriate */
|
||||||
|
i2c_register_board_info(msm_i2c_audiosubsystem.bus,
|
||||||
|
msm_i2c_audiosubsystem.info,
|
||||||
|
msm_i2c_audiosubsystem.len);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_SWITCH_FSA8008
|
||||||
|
static struct fsa8008_platform_data lge_hs_pdata = {
|
||||||
|
.switch_name = "h2w",
|
||||||
|
.keypad_name = "hs_detect",
|
||||||
|
|
||||||
|
.key_code = KEY_MEDIA,
|
||||||
|
|
||||||
|
.gpio_detect = GPIO_EAR_SENSE_N,
|
||||||
|
.gpio_mic_en = GPIO_EAR_MIC_EN,
|
||||||
|
.gpio_jpole = GPIO_EARPOL_DETECT,
|
||||||
|
.gpio_key = GPIO_EAR_KEY_INT,
|
||||||
|
|
||||||
|
.latency_for_detection = 75,
|
||||||
|
.set_headset_mic_bias = tabla_codec_micbias2_ctl,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device lge_hsd_device = {
|
||||||
|
.name = "fsa8008",
|
||||||
|
.id = -1,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &lge_hs_pdata,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static int __init lge_hsd_fsa8008_init(void)
|
||||||
|
{
|
||||||
|
printk(KERN_INFO "lge_hsd_fsa8008_init\n");
|
||||||
|
return platform_device_register(&lge_hsd_device);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __exit lge_hsd_fsa8008_exit(void)
|
||||||
|
{
|
||||||
|
printk(KERN_INFO "lge_hsd_fsa8008_exit\n");
|
||||||
|
platform_device_unregister(&lge_hsd_device);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void __init lge_add_sound_devices(void)
|
||||||
|
{
|
||||||
|
lge_add_i2c_tpa2028d_devices();
|
||||||
|
|
||||||
|
#ifdef CONFIG_SWITCH_FSA8008
|
||||||
|
lge_hsd_fsa8008_init();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
290
arch/arm/mach-msm/lge/mako/board-mako-storage.c
Normal file
290
arch/arm/mach-msm/lge/mako/board-mako-storage.c
Normal file
|
@ -0,0 +1,290 @@
|
||||||
|
/* Copyright (c) 2011, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012, LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <linux/ioport.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/gpio.h>
|
||||||
|
#include <linux/bootmem.h>
|
||||||
|
#include <asm/mach-types.h>
|
||||||
|
#include <asm/mach/mmc.h>
|
||||||
|
#include <mach/msm_bus_board.h>
|
||||||
|
#include <mach/board.h>
|
||||||
|
#include <mach/gpiomux.h>
|
||||||
|
#include "devices.h"
|
||||||
|
#include "board-mako.h"
|
||||||
|
#include "board-storage-common-a.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* APQ8064 has 4 SDCC controllers */
|
||||||
|
enum sdcc_controllers {
|
||||||
|
SDCC1,
|
||||||
|
SDCC2,
|
||||||
|
SDCC3,
|
||||||
|
SDCC4,
|
||||||
|
MAX_SDCC_CONTROLLER
|
||||||
|
};
|
||||||
|
|
||||||
|
/* All SDCC controllers require VDD/VCC voltage */
|
||||||
|
static struct msm_mmc_reg_data mmc_vdd_reg_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
/* SDCC1 : eMMC card connected */
|
||||||
|
[SDCC1] = {
|
||||||
|
.name = "sdc_vdd",
|
||||||
|
.high_vol_level = 2950000,
|
||||||
|
.low_vol_level = 2950000,
|
||||||
|
.always_on = 1,
|
||||||
|
.lpm_sup = 1,
|
||||||
|
.lpm_uA = 9000,
|
||||||
|
.hpm_uA = 200000, /* 200mA */
|
||||||
|
},
|
||||||
|
/* SDCC3 : External card slot connected */
|
||||||
|
[SDCC3] = {
|
||||||
|
.name = "sdc_vdd",
|
||||||
|
.high_vol_level = 2950000,
|
||||||
|
.low_vol_level = 2950000,
|
||||||
|
.hpm_uA = 800000, /* 800mA */
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SDCC controllers may require voting for VDD IO voltage */
|
||||||
|
static struct msm_mmc_reg_data mmc_vdd_io_reg_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
/* SDCC1 : eMMC card connected */
|
||||||
|
[SDCC1] = {
|
||||||
|
.name = "sdc_vdd_io",
|
||||||
|
.always_on = 1,
|
||||||
|
.high_vol_level = 1800000,
|
||||||
|
.low_vol_level = 1800000,
|
||||||
|
.hpm_uA = 200000, /* 200mA */
|
||||||
|
},
|
||||||
|
/* SDCC3 : External card slot connected */
|
||||||
|
[SDCC3] = {
|
||||||
|
.name = "sdc_vdd_io",
|
||||||
|
.high_vol_level = 2950000,
|
||||||
|
.low_vol_level = 1850000,
|
||||||
|
.always_on = 1,
|
||||||
|
.lpm_sup = 1,
|
||||||
|
/* Max. Active current required is 16 mA */
|
||||||
|
.hpm_uA = 16000,
|
||||||
|
/*
|
||||||
|
* Sleep current required is ~300 uA. But min. vote can be
|
||||||
|
* in terms of mA (min. 1 mA). So let's vote for 2 mA
|
||||||
|
* during sleep.
|
||||||
|
*/
|
||||||
|
.lpm_uA = 2000,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_slot_reg_data mmc_slot_vreg_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
/* SDCC1 : eMMC card connected */
|
||||||
|
[SDCC1] = {
|
||||||
|
.vdd_data = &mmc_vdd_reg_data[SDCC1],
|
||||||
|
.vdd_io_data = &mmc_vdd_io_reg_data[SDCC1],
|
||||||
|
},
|
||||||
|
/* SDCC3 : External card slot connected */
|
||||||
|
[SDCC3] = {
|
||||||
|
.vdd_data = &mmc_vdd_reg_data[SDCC3],
|
||||||
|
.vdd_io_data = &mmc_vdd_io_reg_data[SDCC3],
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SDC1 pad data */
|
||||||
|
static struct msm_mmc_pad_drv sdc1_pad_drv_on_cfg[] = {
|
||||||
|
{TLMM_HDRV_SDC1_CLK, GPIO_CFG_16MA},
|
||||||
|
{TLMM_HDRV_SDC1_CMD, GPIO_CFG_10MA},
|
||||||
|
{TLMM_HDRV_SDC1_DATA, GPIO_CFG_10MA}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_drv sdc1_pad_drv_off_cfg[] = {
|
||||||
|
{TLMM_HDRV_SDC1_CLK, GPIO_CFG_2MA},
|
||||||
|
{TLMM_HDRV_SDC1_CMD, GPIO_CFG_2MA},
|
||||||
|
{TLMM_HDRV_SDC1_DATA, GPIO_CFG_2MA}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_pull sdc1_pad_pull_on_cfg[] = {
|
||||||
|
{TLMM_PULL_SDC1_CLK, GPIO_CFG_NO_PULL},
|
||||||
|
{TLMM_PULL_SDC1_CMD, GPIO_CFG_PULL_UP},
|
||||||
|
{TLMM_PULL_SDC1_DATA, GPIO_CFG_PULL_UP}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_pull sdc1_pad_pull_off_cfg[] = {
|
||||||
|
{TLMM_PULL_SDC1_CLK, GPIO_CFG_NO_PULL},
|
||||||
|
{TLMM_PULL_SDC1_CMD, GPIO_CFG_PULL_UP},
|
||||||
|
{TLMM_PULL_SDC1_DATA, GPIO_CFG_PULL_UP}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SDC3 pad data */
|
||||||
|
static struct msm_mmc_pad_drv sdc3_pad_drv_on_cfg[] = {
|
||||||
|
{TLMM_HDRV_SDC3_CLK, GPIO_CFG_8MA},
|
||||||
|
{TLMM_HDRV_SDC3_CMD, GPIO_CFG_8MA},
|
||||||
|
{TLMM_HDRV_SDC3_DATA, GPIO_CFG_8MA}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_drv sdc3_pad_drv_off_cfg[] = {
|
||||||
|
{TLMM_HDRV_SDC3_CLK, GPIO_CFG_2MA},
|
||||||
|
{TLMM_HDRV_SDC3_CMD, GPIO_CFG_2MA},
|
||||||
|
{TLMM_HDRV_SDC3_DATA, GPIO_CFG_2MA}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_pull sdc3_pad_pull_on_cfg[] = {
|
||||||
|
{TLMM_PULL_SDC3_CLK, GPIO_CFG_NO_PULL},
|
||||||
|
{TLMM_PULL_SDC3_CMD, GPIO_CFG_PULL_UP},
|
||||||
|
{TLMM_PULL_SDC3_DATA, GPIO_CFG_PULL_UP}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_pull sdc3_pad_pull_off_cfg[] = {
|
||||||
|
{TLMM_PULL_SDC3_CLK, GPIO_CFG_NO_PULL},
|
||||||
|
{TLMM_PULL_SDC3_CMD, GPIO_CFG_PULL_UP},
|
||||||
|
{TLMM_PULL_SDC3_DATA, GPIO_CFG_PULL_UP}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_pull_data mmc_pad_pull_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
[SDCC1] = {
|
||||||
|
.on = sdc1_pad_pull_on_cfg,
|
||||||
|
.off = sdc1_pad_pull_off_cfg,
|
||||||
|
.size = ARRAY_SIZE(sdc1_pad_pull_on_cfg)
|
||||||
|
},
|
||||||
|
[SDCC3] = {
|
||||||
|
.on = sdc3_pad_pull_on_cfg,
|
||||||
|
.off = sdc3_pad_pull_off_cfg,
|
||||||
|
.size = ARRAY_SIZE(sdc3_pad_pull_on_cfg)
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_drv_data mmc_pad_drv_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
[SDCC1] = {
|
||||||
|
.on = sdc1_pad_drv_on_cfg,
|
||||||
|
.off = sdc1_pad_drv_off_cfg,
|
||||||
|
.size = ARRAY_SIZE(sdc1_pad_drv_on_cfg)
|
||||||
|
},
|
||||||
|
[SDCC3] = {
|
||||||
|
.on = sdc3_pad_drv_on_cfg,
|
||||||
|
.off = sdc3_pad_drv_off_cfg,
|
||||||
|
.size = ARRAY_SIZE(sdc3_pad_drv_on_cfg)
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pad_data mmc_pad_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
[SDCC1] = {
|
||||||
|
.pull = &mmc_pad_pull_data[SDCC1],
|
||||||
|
.drv = &mmc_pad_drv_data[SDCC1]
|
||||||
|
},
|
||||||
|
[SDCC3] = {
|
||||||
|
.pull = &mmc_pad_pull_data[SDCC3],
|
||||||
|
.drv = &mmc_pad_drv_data[SDCC3]
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct msm_mmc_pin_data mmc_slot_pin_data[MAX_SDCC_CONTROLLER] = {
|
||||||
|
[SDCC1] = {
|
||||||
|
.pad_data = &mmc_pad_data[SDCC1],
|
||||||
|
},
|
||||||
|
[SDCC3] = {
|
||||||
|
.pad_data = &mmc_pad_data[SDCC3],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
#define MSM_MPM_PIN_SDC1_DAT1 17
|
||||||
|
#define MSM_MPM_PIN_SDC3_DAT1 21
|
||||||
|
|
||||||
|
#ifdef CONFIG_MMC_MSM_SDC1_SUPPORT
|
||||||
|
static unsigned int sdc1_sup_clk_rates[] = {
|
||||||
|
400000, 24000000, 48000000, 96000000
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct mmc_platform_data sdc1_data = {
|
||||||
|
.ocr_mask = MMC_VDD_27_28 | MMC_VDD_28_29,
|
||||||
|
#ifdef CONFIG_MMC_MSM_SDC1_8_BIT_SUPPORT
|
||||||
|
.mmc_bus_width = MMC_CAP_8_BIT_DATA,
|
||||||
|
#else
|
||||||
|
.mmc_bus_width = MMC_CAP_4_BIT_DATA,
|
||||||
|
#endif
|
||||||
|
.sup_clk_table = sdc1_sup_clk_rates,
|
||||||
|
.sup_clk_cnt = ARRAY_SIZE(sdc1_sup_clk_rates),
|
||||||
|
.pclk_src_dfab = 1,
|
||||||
|
.nonremovable = 1,
|
||||||
|
.pin_data = &mmc_slot_pin_data[SDCC1],
|
||||||
|
.vreg_data = &mmc_slot_vreg_data[SDCC1],
|
||||||
|
.uhs_caps = MMC_CAP_1_8V_DDR | MMC_CAP_UHS_DDR50,
|
||||||
|
.mpm_sdiowakeup_int = MSM_MPM_PIN_SDC1_DAT1,
|
||||||
|
.msm_bus_voting_data = &sps_to_ddr_bus_voting_data,
|
||||||
|
};
|
||||||
|
static struct mmc_platform_data *apq8064_sdc1_pdata = &sdc1_data;
|
||||||
|
#else
|
||||||
|
static struct mmc_platform_data *apq8064_sdc1_pdata;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_MMC_MSM_SDC3_SUPPORT
|
||||||
|
static unsigned int sdc3_sup_clk_rates[] = {
|
||||||
|
400000, 24000000, 48000000, 96000000, 192000000
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct mmc_platform_data sdc3_data = {
|
||||||
|
.ocr_mask = MMC_VDD_27_28 | MMC_VDD_28_29,
|
||||||
|
.mmc_bus_width = MMC_CAP_4_BIT_DATA,
|
||||||
|
.sup_clk_table = sdc3_sup_clk_rates,
|
||||||
|
.sup_clk_cnt = ARRAY_SIZE(sdc3_sup_clk_rates),
|
||||||
|
.pclk_src_dfab = 1,
|
||||||
|
.pin_data = &mmc_slot_pin_data[SDCC3],
|
||||||
|
.vreg_data = &mmc_slot_vreg_data[SDCC3],
|
||||||
|
.status_gpio = 26,
|
||||||
|
.status_irq = MSM_GPIO_TO_INT(26),
|
||||||
|
.irq_flags = IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
||||||
|
.is_status_gpio_active_low = 1,
|
||||||
|
.xpc_cap = 1,
|
||||||
|
.uhs_caps = (MMC_CAP_UHS_SDR12 | MMC_CAP_UHS_SDR25 |
|
||||||
|
MMC_CAP_UHS_SDR50 | MMC_CAP_UHS_DDR50 |
|
||||||
|
MMC_CAP_UHS_SDR104 | MMC_CAP_MAX_CURRENT_800),
|
||||||
|
.mpm_sdiowakeup_int = MSM_MPM_PIN_SDC3_DAT1,
|
||||||
|
.msm_bus_voting_data = &sps_to_ddr_bus_voting_data,
|
||||||
|
};
|
||||||
|
static struct mmc_platform_data *apq8064_sdc3_pdata = &sdc3_data;
|
||||||
|
#else
|
||||||
|
static struct mmc_platform_data *apq8064_sdc3_pdata;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void __init apq8064_init_mmc(void)
|
||||||
|
{
|
||||||
|
if ((machine_is_apq8064_rumi3()) || machine_is_apq8064_sim()) {
|
||||||
|
if (apq8064_sdc1_pdata) {
|
||||||
|
if (machine_is_apq8064_sim())
|
||||||
|
apq8064_sdc1_pdata->disable_bam = true;
|
||||||
|
apq8064_sdc1_pdata->disable_runtime_pm = true;
|
||||||
|
apq8064_sdc1_pdata->disable_cmd23 = true;
|
||||||
|
}
|
||||||
|
if (apq8064_sdc3_pdata) {
|
||||||
|
if (machine_is_apq8064_sim())
|
||||||
|
apq8064_sdc3_pdata->disable_bam = true;
|
||||||
|
apq8064_sdc3_pdata->disable_runtime_pm = true;
|
||||||
|
apq8064_sdc3_pdata->disable_cmd23 = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (apq8064_sdc1_pdata)
|
||||||
|
apq8064_add_sdcc(1, apq8064_sdc1_pdata);
|
||||||
|
|
||||||
|
if (apq8064_sdc3_pdata) {
|
||||||
|
if (!machine_is_apq8064_cdp()) {
|
||||||
|
apq8064_sdc3_pdata->wpswitch_gpio = 0;
|
||||||
|
apq8064_sdc3_pdata->wpswitch_polarity = 0;
|
||||||
|
}
|
||||||
|
if (machine_is_mpq8064_cdp() || machine_is_mpq8064_hrd() ||
|
||||||
|
machine_is_mpq8064_dtv()) {
|
||||||
|
apq8064_sdc3_pdata->status_gpio =
|
||||||
|
PM8921_GPIO_PM_TO_SYS(31);
|
||||||
|
apq8064_sdc3_pdata->status_irq =
|
||||||
|
PM8921_GPIO_IRQ(PM8921_IRQ_BASE, 31);
|
||||||
|
}
|
||||||
|
apq8064_add_sdcc(3, apq8064_sdc3_pdata);
|
||||||
|
}
|
||||||
|
}
|
2522
arch/arm/mach-msm/lge/mako/board-mako.c
Normal file
2522
arch/arm/mach-msm/lge/mako/board-mako.c
Normal file
File diff suppressed because it is too large
Load diff
185
arch/arm/mach-msm/lge/mako/board-mako.h
Normal file
185
arch/arm/mach-msm/lge/mako/board-mako.h
Normal file
|
@ -0,0 +1,185 @@
|
||||||
|
/* Copyright (c) 2011-2012, Code Aurora Forum. All rights reserved.
|
||||||
|
* Copyright (c) 2012 LGE Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
* only version 2 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ARCH_ARM_MACH_MSM_BOARD_APQ8064_H
|
||||||
|
#define __ARCH_ARM_MACH_MSM_BOARD_APQ8064_H
|
||||||
|
|
||||||
|
#include <linux/regulator/msm-gpio-regulator.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8921.h>
|
||||||
|
#include <linux/mfd/pm8xxx/pm8821.h>
|
||||||
|
#include <mach/msm_memtypes.h>
|
||||||
|
#include <mach/irqs.h>
|
||||||
|
#include <mach/rpm-regulator.h>
|
||||||
|
#include <mach/msm_rtb.h>
|
||||||
|
|
||||||
|
/* Macros assume PMIC GPIOs and MPPs start at 1 */
|
||||||
|
#define PM8921_GPIO_BASE NR_GPIO_IRQS
|
||||||
|
#define PM8921_GPIO_PM_TO_SYS(pm_gpio) (pm_gpio - 1 + PM8921_GPIO_BASE)
|
||||||
|
#define PM8921_MPP_BASE (PM8921_GPIO_BASE + PM8921_NR_GPIOS)
|
||||||
|
#define PM8921_MPP_PM_TO_SYS(pm_mpp) (pm_mpp - 1 + PM8921_MPP_BASE)
|
||||||
|
#define PM8921_IRQ_BASE (NR_MSM_IRQS + NR_GPIO_IRQS)
|
||||||
|
|
||||||
|
#define PM8821_MPP_BASE (PM8921_MPP_BASE + PM8921_NR_MPPS)
|
||||||
|
#define PM8821_MPP_PM_TO_SYS(pm_mpp) (pm_mpp - 1 + PM8821_MPP_BASE)
|
||||||
|
#define PM8821_IRQ_BASE (PM8921_IRQ_BASE + PM8921_NR_IRQS)
|
||||||
|
|
||||||
|
#define TABLA_INTERRUPT_BASE (PM8821_IRQ_BASE + PM8821_NR_IRQS)
|
||||||
|
|
||||||
|
extern struct pm8xxx_regulator_platform_data
|
||||||
|
msm8064_pm8921_regulator_pdata[] __devinitdata;
|
||||||
|
|
||||||
|
extern int msm8064_pm8921_regulator_pdata_len __devinitdata;
|
||||||
|
|
||||||
|
#define GPIO_VREG_ID_EXT_5V 0
|
||||||
|
#define GPIO_VREG_ID_EXT_3P3V 1
|
||||||
|
#define GPIO_VREG_ID_EXT_TS_SW 2
|
||||||
|
#define GPIO_VREG_ID_EXT_MPP8 3
|
||||||
|
|
||||||
|
#define GPIO_VREG_ID_FRC_5V 0
|
||||||
|
#define GPIO_VREG_ID_AVC_1P2V 1
|
||||||
|
#define GPIO_VREG_ID_AVC_1P8V 2
|
||||||
|
#define GPIO_VREG_ID_AVC_2P2V 3
|
||||||
|
#define GPIO_VREG_ID_AVC_5V 4
|
||||||
|
#define GPIO_VREG_ID_AVC_3P3V 5
|
||||||
|
|
||||||
|
#define APQ8064_EXT_3P3V_REG_EN_GPIO 77
|
||||||
|
|
||||||
|
extern struct gpio_regulator_platform_data
|
||||||
|
apq8064_gpio_regulator_pdata[] __devinitdata;
|
||||||
|
|
||||||
|
extern struct gpio_regulator_platform_data
|
||||||
|
mpq8064_gpio_regulator_pdata[] __devinitdata;
|
||||||
|
|
||||||
|
extern struct rpm_regulator_platform_data
|
||||||
|
apq8064_rpm_regulator_pdata __devinitdata;
|
||||||
|
|
||||||
|
extern struct regulator_init_data msm8064_saw_regulator_pdata_8921_s5;
|
||||||
|
extern struct regulator_init_data msm8064_saw_regulator_pdata_8921_s6;
|
||||||
|
extern struct regulator_init_data msm8064_saw_regulator_pdata_8821_s0;
|
||||||
|
extern struct regulator_init_data msm8064_saw_regulator_pdata_8821_s1;
|
||||||
|
|
||||||
|
struct mmc_platform_data;
|
||||||
|
int __init apq8064_add_sdcc(unsigned int controller,
|
||||||
|
struct mmc_platform_data *plat);
|
||||||
|
extern void __init register_i2c_backlight_devices(void);
|
||||||
|
extern void __init lge_add_sound_devices(void);
|
||||||
|
void apq8064_init_mmc(void);
|
||||||
|
void apq8064_init_gpiomux(void);
|
||||||
|
void apq8064_init_pmic(void);
|
||||||
|
|
||||||
|
extern struct msm_camera_board_info apq8064_camera_board_info;
|
||||||
|
/* Enabling flash LED for camera */
|
||||||
|
extern struct msm_camera_board_info apq8064_lge_camera_board_info;
|
||||||
|
|
||||||
|
void apq8064_init_cam(void);
|
||||||
|
|
||||||
|
#define APQ_8064_GSBI1_QUP_I2C_BUS_ID 0
|
||||||
|
#define APQ_8064_GSBI2_QUP_I2C_BUS_ID 2
|
||||||
|
#define APQ_8064_GSBI3_QUP_I2C_BUS_ID 3
|
||||||
|
#define APQ_8064_GSBI4_QUP_I2C_BUS_ID 4
|
||||||
|
#define APQ_8064_GSBI5_QUP_I2C_BUS_ID 5
|
||||||
|
|
||||||
|
#ifndef CONFIG_MACH_LGE
|
||||||
|
unsigned char apq8064_hdmi_as_primary_selected(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Camera GPIO Settings */
|
||||||
|
#define GPIO_CAM_MCLK0 (5)
|
||||||
|
|
||||||
|
/* FIXME: for old HW (LGU Rev.A,B VZW Rev.A,B ATT Rev.A) */
|
||||||
|
#if 1
|
||||||
|
#define GPIO_CAM_MCLK2 (2)
|
||||||
|
#define GPIO_CAM_FLASH_EN (7)
|
||||||
|
#else
|
||||||
|
#define GPIO_CAM_MCLK1 (4)
|
||||||
|
#define GPIO_CAM_FLASH_EN (2)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define GPIO_CAM_I2C_SDA (12)
|
||||||
|
#define GPIO_CAM_I2C_SCL (13)
|
||||||
|
#define GPIO_CAM1_RST_N (32)
|
||||||
|
#define GPIO_CAM2_RST_N (34)
|
||||||
|
|
||||||
|
#define GPIO_CAM_FLASH_I2C_SDA (20)
|
||||||
|
#define GPIO_CAM_FLASH_I2C_SCL (21)
|
||||||
|
|
||||||
|
#define I2C_SLAVE_ADDR_IMX111 (0x0D)
|
||||||
|
#define I2C_SLAVE_ADDR_IMX111_ACT (0x18)
|
||||||
|
#define I2C_SLAVE_ADDR_IMX091 (0x0D)
|
||||||
|
#define I2C_SLAVE_ADDR_IMX091_ACT (0x18)
|
||||||
|
#define I2C_SLAVE_ADDR_IMX119 (0x6E)
|
||||||
|
#define I2C_SLAVE_ADDR_FLASH (0xA6 >> 1)
|
||||||
|
|
||||||
|
void apq8064_init_fb(void);
|
||||||
|
void apq8064_allocate_fb_region(void);
|
||||||
|
void apq8064_mdp_writeback(struct memtype_reserve *reserve_table);
|
||||||
|
void __init apq8064_set_display_params(char *prim_panel, char *ext_panel);
|
||||||
|
|
||||||
|
void apq8064_init_gpu(void);
|
||||||
|
void apq8064_pm8xxx_gpio_mpp_init(void);
|
||||||
|
|
||||||
|
#define PLATFORM_IS_MPQ8064() \
|
||||||
|
(machine_is_mpq8064_hrd() || \
|
||||||
|
machine_is_mpq8064_dtv() || \
|
||||||
|
machine_is_mpq8064_cdp() \
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
#define GPIO_EXPANDER_IRQ_BASE (TABLA_INTERRUPT_BASE + \
|
||||||
|
NR_TABLA_IRQS)
|
||||||
|
#define GPIO_EXPANDER_GPIO_BASE (PM8821_MPP_BASE + PM8821_NR_MPPS)
|
||||||
|
|
||||||
|
#define GPIO_EPM_EXPANDER_BASE GPIO_EXPANDER_GPIO_BASE
|
||||||
|
#define SX150X_EPM_NR_GPIOS 16
|
||||||
|
#define SX150X_EPM_NR_IRQS 8
|
||||||
|
|
||||||
|
#define SX150X_EXP1_GPIO_BASE (GPIO_EPM_EXPANDER_BASE + \
|
||||||
|
SX150X_EPM_NR_GPIOS)
|
||||||
|
#define SX150X_EXP1_IRQ_BASE (GPIO_EXPANDER_IRQ_BASE + \
|
||||||
|
SX150X_EPM_NR_IRQS)
|
||||||
|
#define SX150X_EXP1_NR_IRQS 16
|
||||||
|
#define SX150X_EXP1_NR_GPIOS 16
|
||||||
|
|
||||||
|
#define SX150X_EXP2_GPIO_BASE (SX150X_EXP1_GPIO_BASE + \
|
||||||
|
SX150X_EXP1_NR_GPIOS)
|
||||||
|
#define SX150X_EXP2_IRQ_BASE (SX150X_EXP1_IRQ_BASE + SX150X_EXP1_NR_IRQS)
|
||||||
|
#define SX150X_EXP2_NR_IRQS 8
|
||||||
|
#define SX150X_EXP2_NR_GPIOS 8
|
||||||
|
|
||||||
|
#define SX150X_EXP3_GPIO_BASE (SX150X_EXP2_GPIO_BASE + \
|
||||||
|
SX150X_EXP2_NR_GPIOS)
|
||||||
|
#define SX150X_EXP3_IRQ_BASE (SX150X_EXP2_IRQ_BASE + SX150X_EXP2_NR_IRQS)
|
||||||
|
#define SX150X_EXP3_NR_IRQS 8
|
||||||
|
#define SX150X_EXP3_NR_GPIOS 8
|
||||||
|
|
||||||
|
#define SX150X_EXP4_GPIO_BASE (SX150X_EXP3_GPIO_BASE + \
|
||||||
|
SX150X_EXP3_NR_GPIOS)
|
||||||
|
#define SX150X_EXP4_IRQ_BASE (SX150X_EXP3_IRQ_BASE + SX150X_EXP3_NR_IRQS)
|
||||||
|
#define SX150X_EXP4_NR_IRQS 16
|
||||||
|
#define SX150X_EXP4_NR_GPIOS 16
|
||||||
|
|
||||||
|
#define SX150X_GPIO(_expander, _pin) (SX150X_EXP##_expander##_GPIO_BASE + _pin)
|
||||||
|
|
||||||
|
enum {
|
||||||
|
SX150X_EPM,
|
||||||
|
SX150X_EXP1,
|
||||||
|
SX150X_EXP2,
|
||||||
|
SX150X_EXP3,
|
||||||
|
SX150X_EXP4,
|
||||||
|
};
|
||||||
|
|
||||||
|
extern struct msm_rtb_platform_data apq8064_rtb_pdata;
|
||||||
|
|
||||||
|
void apq8064_init_input(void);
|
||||||
|
void __init apq8064_init_misc(void);
|
||||||
|
#endif
|
60
include/linux/android_vibrator.h
Normal file
60
include/linux/android_vibrator.h
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2011 LGE, Inc.
|
||||||
|
*
|
||||||
|
* This software is licensed under the terms of the GNU General Public
|
||||||
|
* License version 2, as published by the Free Software Foundation, and
|
||||||
|
* may be copied, distributed, and modified under those terms.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __LINUX_ANDROID_VIBRATOR_H
|
||||||
|
#define __LINUX_ANDROID_VIBRATOR_H
|
||||||
|
|
||||||
|
/* android vibrator platform data */
|
||||||
|
struct android_vibrator_platform_data {
|
||||||
|
int enable_status;
|
||||||
|
int amp;
|
||||||
|
int vibe_n_value;
|
||||||
|
int (*power_set)(int enable); /* LDO Power Set Function */
|
||||||
|
int (*pwm_set)(int enable, int gain, int n_value); /* PWM Set Function */
|
||||||
|
int (*ic_enable_set)(int enable); /* Motor IC Set Function */
|
||||||
|
int (*vibrator_init)(void);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* Debug Mask setting */
|
||||||
|
#define VIBRATOR_DEBUG_PRINT (1)
|
||||||
|
#define VIBRATOR_ERROR_PRINT (1)
|
||||||
|
#define VIBRATOR_INFO_PRINT (0)
|
||||||
|
|
||||||
|
#if (VIBRATOR_INFO_PRINT)
|
||||||
|
#define INFO_MSG(fmt, args...) \
|
||||||
|
printk(KERN_INFO "[%s] " \
|
||||||
|
fmt, __FUNCTION__, ##args);
|
||||||
|
#else
|
||||||
|
#define INFO_MSG(fmt, args...)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (VIBRATOR_DEBUG_PRINT)
|
||||||
|
#define DEBUG_MSG(fmt, args...) \
|
||||||
|
printk(KERN_INFO "[%s %d] " \
|
||||||
|
fmt, __FUNCTION__, __LINE__, ##args);
|
||||||
|
#else
|
||||||
|
#define DEBUG_MSG(fmt, args...)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (VIBRATOR_ERROR_PRINT)
|
||||||
|
#define ERR_MSG(fmt, args...) \
|
||||||
|
printk(KERN_ERR "[%s %d] " \
|
||||||
|
fmt, __FUNCTION__, __LINE__, ##args);
|
||||||
|
#else
|
||||||
|
#define ERR_MSG(fmt, args...)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -148,7 +148,7 @@ config SND_SOC_MSM8960
|
||||||
select SND_SOC_WCD9304
|
select SND_SOC_WCD9304
|
||||||
select SND_SOC_MSM_HOSTLESS_PCM
|
select SND_SOC_MSM_HOSTLESS_PCM
|
||||||
select SND_SOC_MSM_QDSP6_HDMI_AUDIO
|
select SND_SOC_MSM_QDSP6_HDMI_AUDIO
|
||||||
select SND_SOC_CS8427
|
#select SND_SOC_CS8427
|
||||||
default n
|
default n
|
||||||
help
|
help
|
||||||
To add support for SoC audio on MSM8960 and APQ8064 boards
|
To add support for SoC audio on MSM8960 and APQ8064 boards
|
||||||
|
|
Loading…
Reference in a new issue