Move Odroid XU4 DEV branch to 5.6.y
Also update all patches and configs
This commit is contained in:
parent
7aacfb8824
commit
9f441a3d14
@ -1,6 +1,6 @@
|
||||
#
|
||||
# Automatically generated file; DO NOT EDIT.
|
||||
# Linux/arm 5.4.28 Kernel Configuration
|
||||
# Linux/arm 5.4.30 Kernel Configuration
|
||||
#
|
||||
|
||||
#
|
||||
@ -2337,6 +2337,8 @@ CONFIG_RTL8822BU=m
|
||||
CONFIG_RTL8188EU=m
|
||||
CONFIG_RTL8821CU=m
|
||||
CONFIG_88XXAU=m
|
||||
CONFIG_RTL8189FS=m
|
||||
CONFIG_RTL8189ES=m
|
||||
CONFIG_WLAN_VENDOR_ZYDAS=y
|
||||
CONFIG_USB_ZD1201=m
|
||||
CONFIG_ZD1211RW=m
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
#
|
||||
# Automatically generated file; DO NOT EDIT.
|
||||
# Linux/arm 5.5.1 Kernel Configuration
|
||||
# Linux/arm 5.6.2 Kernel Configuration
|
||||
#
|
||||
|
||||
#
|
||||
@ -14,7 +14,7 @@ CONFIG_CC_HAS_ASM_GOTO=y
|
||||
CONFIG_CC_HAS_ASM_INLINE=y
|
||||
CONFIG_CC_HAS_WARN_MAYBE_UNINITIALIZED=y
|
||||
CONFIG_IRQ_WORK=y
|
||||
CONFIG_BUILDTIME_EXTABLE_SORT=y
|
||||
CONFIG_BUILDTIME_TABLE_SORT=y
|
||||
|
||||
#
|
||||
# General setup
|
||||
@ -109,6 +109,7 @@ CONFIG_CPU_ISOLATION=y
|
||||
#
|
||||
# RCU Subsystem
|
||||
#
|
||||
CONFIG_TREE_RCU=y
|
||||
CONFIG_PREEMPT_RCU=y
|
||||
# CONFIG_RCU_EXPERT is not set
|
||||
CONFIG_SRCU=y
|
||||
@ -172,6 +173,7 @@ CONFIG_RD_LZMA=y
|
||||
CONFIG_RD_XZ=y
|
||||
CONFIG_RD_LZO=y
|
||||
CONFIG_RD_LZ4=y
|
||||
# CONFIG_BOOT_CONFIG is not set
|
||||
CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y
|
||||
# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set
|
||||
CONFIG_SYSCTL=y
|
||||
@ -295,7 +297,7 @@ CONFIG_ARCH_EXYNOS4=y
|
||||
CONFIG_ARCH_EXYNOS5=y
|
||||
|
||||
#
|
||||
# EXYNOS SoCs
|
||||
# Exynos SoCs
|
||||
#
|
||||
CONFIG_SOC_EXYNOS3250=y
|
||||
CONFIG_CPU_EXYNOS4210=y
|
||||
@ -733,6 +735,7 @@ CONFIG_BLK_CGROUP_RWSTAT=y
|
||||
CONFIG_BLK_DEV_BSG=y
|
||||
CONFIG_BLK_DEV_BSGLIB=y
|
||||
CONFIG_BLK_DEV_INTEGRITY=y
|
||||
CONFIG_BLK_DEV_INTEGRITY_T10=m
|
||||
CONFIG_BLK_DEV_ZONED=y
|
||||
CONFIG_BLK_DEV_THROTTLING=y
|
||||
CONFIG_BLK_DEV_THROTTLING_LOW=y
|
||||
@ -863,8 +866,6 @@ CONFIG_NET_KEY=y
|
||||
CONFIG_NET_KEY_MIGRATE=y
|
||||
# CONFIG_XDP_SOCKETS is not set
|
||||
CONFIG_INET=y
|
||||
CONFIG_WIREGUARD=m
|
||||
# CONFIG_WIREGUARD_DEBUG is not set
|
||||
CONFIG_IP_MULTICAST=y
|
||||
CONFIG_IP_ADVANCED_ROUTER=y
|
||||
CONFIG_IP_FIB_TRIE_STATS=y
|
||||
@ -894,6 +895,7 @@ CONFIG_NET_FOU_IP_TUNNELS=y
|
||||
CONFIG_INET_AH=m
|
||||
CONFIG_INET_ESP=m
|
||||
# CONFIG_INET_ESP_OFFLOAD is not set
|
||||
# CONFIG_INET_ESPINTCP is not set
|
||||
CONFIG_INET_IPCOMP=m
|
||||
CONFIG_INET_XFRM_TUNNEL=m
|
||||
CONFIG_INET_TUNNEL=m
|
||||
@ -951,6 +953,7 @@ CONFIG_IPV6_PIMSM_V2=y
|
||||
# CONFIG_IPV6_SEG6_LWTUNNEL is not set
|
||||
# CONFIG_IPV6_SEG6_HMAC is not set
|
||||
# CONFIG_NETLABEL is not set
|
||||
# CONFIG_MPTCP is not set
|
||||
CONFIG_NETWORK_SECMARK=y
|
||||
CONFIG_NET_PTP_CLASSIFY=y
|
||||
CONFIG_NETWORK_PHY_TIMESTAMPING=y
|
||||
@ -1416,8 +1419,10 @@ CONFIG_NET_SCH_CAKE=m
|
||||
CONFIG_NET_SCH_FQ=m
|
||||
CONFIG_NET_SCH_HHF=m
|
||||
CONFIG_NET_SCH_PIE=m
|
||||
CONFIG_NET_SCH_FQ_PIE=m
|
||||
CONFIG_NET_SCH_INGRESS=m
|
||||
CONFIG_NET_SCH_PLUG=m
|
||||
CONFIG_NET_SCH_ETS=m
|
||||
CONFIG_NET_SCH_DEFAULT=y
|
||||
CONFIG_DEFAULT_FQ=y
|
||||
# CONFIG_DEFAULT_CODEL is not set
|
||||
@ -1497,6 +1502,8 @@ CONFIG_OPENVSWITCH_GRE=m
|
||||
CONFIG_OPENVSWITCH_VXLAN=m
|
||||
CONFIG_VSOCKETS=m
|
||||
CONFIG_VSOCKETS_DIAG=m
|
||||
CONFIG_VSOCKETS_LOOPBACK=m
|
||||
CONFIG_VIRTIO_VSOCKETS_COMMON=m
|
||||
CONFIG_NETLINK_DIAG=m
|
||||
CONFIG_MPLS=y
|
||||
CONFIG_NET_MPLS_GSO=m
|
||||
@ -1687,6 +1694,7 @@ CONFIG_LWTUNNEL_BPF=y
|
||||
CONFIG_DST_CACHE=y
|
||||
CONFIG_GRO_CELLS=y
|
||||
# CONFIG_FAILOVER is not set
|
||||
CONFIG_ETHTOOL_NETLINK=y
|
||||
CONFIG_HAVE_EBPF_JIT=y
|
||||
|
||||
#
|
||||
@ -1946,6 +1954,8 @@ CONFIG_MII=y
|
||||
CONFIG_NET_CORE=y
|
||||
CONFIG_BONDING=m
|
||||
CONFIG_DUMMY=m
|
||||
CONFIG_WIREGUARD=m
|
||||
# CONFIG_WIREGUARD_DEBUG is not set
|
||||
# CONFIG_EQUALIZER is not set
|
||||
# CONFIG_IFB is not set
|
||||
CONFIG_NET_TEAM=m
|
||||
@ -2091,6 +2101,7 @@ CONFIG_AX88796B_PHY=m
|
||||
# CONFIG_BCM7XXX_PHY is not set
|
||||
# CONFIG_BCM87XX_PHY is not set
|
||||
# CONFIG_BROADCOM_PHY is not set
|
||||
# CONFIG_BCM84881_PHY is not set
|
||||
# CONFIG_CICADA_PHY is not set
|
||||
# CONFIG_CORTINA_PHY is not set
|
||||
# CONFIG_DAVICOM_PHY is not set
|
||||
@ -2299,10 +2310,13 @@ CONFIG_WLAN_VENDOR_TI=y
|
||||
# CONFIG_WL12XX is not set
|
||||
# CONFIG_WL18XX is not set
|
||||
# CONFIG_WLCORE is not set
|
||||
CONFIG_RTL8723DS=m
|
||||
CONFIG_RTL8822BU=m
|
||||
CONFIG_RTL8188EU=m
|
||||
CONFIG_RTL8821CU=m
|
||||
CONFIG_RTL8812AU=m
|
||||
CONFIG_88XXAU=m
|
||||
CONFIG_RTL8189FS=m
|
||||
CONFIG_RTL8189ES=m
|
||||
CONFIG_WLAN_VENDOR_ZYDAS=y
|
||||
CONFIG_USB_ZD1201=m
|
||||
CONFIG_ZD1211RW=m
|
||||
@ -2631,6 +2645,7 @@ CONFIG_DEVMEM=y
|
||||
CONFIG_SERIAL_EARLYCON=y
|
||||
CONFIG_SERIAL_8250=y
|
||||
CONFIG_SERIAL_8250_DEPRECATED_OPTIONS=y
|
||||
# CONFIG_SERIAL_8250_16550A_VARIANTS is not set
|
||||
# CONFIG_SERIAL_8250_FINTEK is not set
|
||||
# CONFIG_SERIAL_8250_CONSOLE is not set
|
||||
CONFIG_SERIAL_8250_DMA=y
|
||||
@ -2752,7 +2767,6 @@ CONFIG_I2C_S3C2410=y
|
||||
#
|
||||
# CONFIG_I2C_DIOLAN_U2C is not set
|
||||
# CONFIG_I2C_PARPORT is not set
|
||||
# CONFIG_I2C_PARPORT_LIGHT is not set
|
||||
# CONFIG_I2C_ROBOTFUZZ_OSIF is not set
|
||||
# CONFIG_I2C_TAOS_EVM is not set
|
||||
CONFIG_I2C_TINY_USB=m
|
||||
@ -2851,10 +2865,12 @@ CONFIG_GPIO_GENERIC=m
|
||||
# CONFIG_GPIO_GENERIC_PLATFORM is not set
|
||||
# CONFIG_GPIO_GRGPIO is not set
|
||||
# CONFIG_GPIO_HLWD is not set
|
||||
CONFIG_GPIO_LOGICVC=m
|
||||
# CONFIG_GPIO_MB86S7X is not set
|
||||
# CONFIG_GPIO_MPC8XXX is not set
|
||||
# CONFIG_GPIO_PL061 is not set
|
||||
CONFIG_GPIO_SAMA5D2_PIOBU=m
|
||||
# CONFIG_GPIO_SIFIVE is not set
|
||||
CONFIG_GPIO_SYSCON=m
|
||||
# CONFIG_GPIO_XILINX is not set
|
||||
# CONFIG_GPIO_ZEVIO is not set
|
||||
@ -2878,6 +2894,7 @@ CONFIG_GPIO_GW_PLD=m
|
||||
# MFD GPIO expanders
|
||||
#
|
||||
CONFIG_GPIO_BD70528=m
|
||||
CONFIG_GPIO_BD71828=m
|
||||
# CONFIG_HTC_EGPIO is not set
|
||||
CONFIG_GPIO_TQMX86=m
|
||||
# CONFIG_GPIO_WM8994 is not set
|
||||
@ -3005,6 +3022,7 @@ CONFIG_HWMON=y
|
||||
# CONFIG_SENSORS_ADM1026 is not set
|
||||
# CONFIG_SENSORS_ADM1029 is not set
|
||||
# CONFIG_SENSORS_ADM1031 is not set
|
||||
CONFIG_SENSORS_ADM1177=m
|
||||
# CONFIG_SENSORS_ADM9240 is not set
|
||||
# CONFIG_SENSORS_ADT7310 is not set
|
||||
# CONFIG_SENSORS_ADT7410 is not set
|
||||
@ -3050,6 +3068,7 @@ CONFIG_SENSORS_LTC2947_SPI=m
|
||||
# CONFIG_SENSORS_MAX1668 is not set
|
||||
# CONFIG_SENSORS_MAX197 is not set
|
||||
# CONFIG_SENSORS_MAX31722 is not set
|
||||
CONFIG_SENSORS_MAX31730=m
|
||||
# CONFIG_SENSORS_MAX6621 is not set
|
||||
# CONFIG_SENSORS_MAX6639 is not set
|
||||
# CONFIG_SENSORS_MAX6642 is not set
|
||||
@ -3143,6 +3162,7 @@ CONFIG_THERMAL_GOV_STEP_WISE=y
|
||||
# CONFIG_THERMAL_GOV_BANG_BANG is not set
|
||||
# CONFIG_THERMAL_GOV_USER_SPACE is not set
|
||||
CONFIG_CPU_THERMAL=y
|
||||
CONFIG_CPU_FREQ_THERMAL=y
|
||||
# CONFIG_CLOCK_THERMAL is not set
|
||||
# CONFIG_DEVFREQ_THERMAL is not set
|
||||
CONFIG_THERMAL_EMULATION=y
|
||||
@ -3297,6 +3317,7 @@ CONFIG_MFD_TQMX86=m
|
||||
CONFIG_MFD_WM8994=y
|
||||
# CONFIG_MFD_ROHM_BD718XX is not set
|
||||
CONFIG_MFD_ROHM_BD70528=m
|
||||
CONFIG_MFD_ROHM_BD71828=m
|
||||
# CONFIG_MFD_STPMIC1 is not set
|
||||
CONFIG_MFD_STMFX=m
|
||||
# end of Multifunction device drivers
|
||||
@ -3311,6 +3332,7 @@ CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||
# CONFIG_REGULATOR_AD5398 is not set
|
||||
# CONFIG_REGULATOR_ANATOP is not set
|
||||
# CONFIG_REGULATOR_BD70528 is not set
|
||||
CONFIG_REGULATOR_BD71828=m
|
||||
# CONFIG_REGULATOR_DA9210 is not set
|
||||
# CONFIG_REGULATOR_DA9211 is not set
|
||||
# CONFIG_REGULATOR_FAN53555 is not set
|
||||
@ -3335,12 +3357,15 @@ CONFIG_REGULATOR_MAX77686=y
|
||||
CONFIG_REGULATOR_MAX77693=y
|
||||
CONFIG_REGULATOR_MAX77802=y
|
||||
# CONFIG_REGULATOR_MCP16502 is not set
|
||||
CONFIG_REGULATOR_MP8859=m
|
||||
CONFIG_REGULATOR_MPQ7920=m
|
||||
# CONFIG_REGULATOR_MT6311 is not set
|
||||
# CONFIG_REGULATOR_PFUZE100 is not set
|
||||
# CONFIG_REGULATOR_PV88060 is not set
|
||||
# CONFIG_REGULATOR_PV88080 is not set
|
||||
# CONFIG_REGULATOR_PV88090 is not set
|
||||
# CONFIG_REGULATOR_PWM is not set
|
||||
CONFIG_REGULATOR_ROHM=m
|
||||
CONFIG_REGULATOR_S2MPA01=y
|
||||
CONFIG_REGULATOR_S2MPS11=y
|
||||
CONFIG_REGULATOR_S5M8767=y
|
||||
@ -3961,7 +3986,6 @@ CONFIG_DRM_SCHED=y
|
||||
# CONFIG_DRM_HDLCD is not set
|
||||
# CONFIG_DRM_MALI_DISPLAY is not set
|
||||
CONFIG_DRM_KOMEDA=m
|
||||
# CONFIG_DRM_KOMEDA_ERROR_PRINT is not set
|
||||
# end of ARM devices
|
||||
|
||||
#
|
||||
@ -4011,6 +4035,7 @@ CONFIG_DRM_PANEL=y
|
||||
# Display Panels
|
||||
#
|
||||
# CONFIG_DRM_PANEL_ARM_VERSATILE is not set
|
||||
CONFIG_DRM_PANEL_BOE_HIMAX8279D=m
|
||||
# CONFIG_DRM_PANEL_LVDS is not set
|
||||
CONFIG_DRM_PANEL_SIMPLE=y
|
||||
# CONFIG_DRM_PANEL_FEIYANG_FY07024DI26A30D is not set
|
||||
@ -4019,6 +4044,7 @@ CONFIG_DRM_PANEL_SIMPLE=y
|
||||
# CONFIG_DRM_PANEL_INNOLUX_P079ZCA is not set
|
||||
# CONFIG_DRM_PANEL_JDI_LT070ME05000 is not set
|
||||
# CONFIG_DRM_PANEL_KINGDISPLAY_KD097D04 is not set
|
||||
CONFIG_DRM_PANEL_LEADTEK_LTK500HD1829=m
|
||||
CONFIG_DRM_PANEL_SAMSUNG_LD9040=y
|
||||
# CONFIG_DRM_PANEL_LG_LB035Q02 is not set
|
||||
# CONFIG_DRM_PANEL_LG_LG4573 is not set
|
||||
@ -4044,11 +4070,13 @@ CONFIG_DRM_PANEL_SAMSUNG_S6E8AA0=y
|
||||
# CONFIG_DRM_PANEL_SHARP_LS043T1LE01 is not set
|
||||
# CONFIG_DRM_PANEL_SITRONIX_ST7701 is not set
|
||||
# CONFIG_DRM_PANEL_SITRONIX_ST7789V is not set
|
||||
CONFIG_DRM_PANEL_SONY_ACX424AKP=m
|
||||
# CONFIG_DRM_PANEL_SONY_ACX565AKM is not set
|
||||
# CONFIG_DRM_PANEL_TPO_TD028TTEC1 is not set
|
||||
# CONFIG_DRM_PANEL_TPO_TD043MTEA1 is not set
|
||||
# CONFIG_DRM_PANEL_TPO_TPG110 is not set
|
||||
# CONFIG_DRM_PANEL_TRULY_NT35597_WQXGA is not set
|
||||
CONFIG_DRM_PANEL_XINPENG_XPP055C272=m
|
||||
# end of Display Panels
|
||||
|
||||
CONFIG_DRM_BRIDGE=y
|
||||
@ -4057,10 +4085,9 @@ CONFIG_DRM_PANEL_BRIDGE=y
|
||||
#
|
||||
# Display Interface Bridges
|
||||
#
|
||||
# CONFIG_DRM_ANALOGIX_ANX78XX is not set
|
||||
# CONFIG_DRM_CDNS_DSI is not set
|
||||
# CONFIG_DRM_DUMB_VGA_DAC is not set
|
||||
# CONFIG_DRM_LVDS_ENCODER is not set
|
||||
CONFIG_DRM_LVDS_CODEC=m
|
||||
# CONFIG_DRM_MEGACHIPS_STDPXXXX_GE_B850V3_FW is not set
|
||||
CONFIG_DRM_NXP_PTN3460=y
|
||||
CONFIG_DRM_PARADE_PS8622=y
|
||||
@ -4072,6 +4099,8 @@ CONFIG_DRM_TOSHIBA_TC358764=y
|
||||
# CONFIG_DRM_TOSHIBA_TC358767 is not set
|
||||
# CONFIG_DRM_TI_TFP410 is not set
|
||||
# CONFIG_DRM_TI_SN65DSI86 is not set
|
||||
CONFIG_DRM_ANALOGIX_ANX6345=m
|
||||
# CONFIG_DRM_ANALOGIX_ANX78XX is not set
|
||||
CONFIG_DRM_ANALOGIX_DP=y
|
||||
# CONFIG_DRM_I2C_ADV7511 is not set
|
||||
# end of Display Interface Bridges
|
||||
@ -4159,6 +4188,7 @@ CONFIG_BACKLIGHT_QCOM_WLED=m
|
||||
# CONFIG_BACKLIGHT_LV5207LP is not set
|
||||
# CONFIG_BACKLIGHT_BD6107 is not set
|
||||
# CONFIG_BACKLIGHT_ARCXCNN is not set
|
||||
CONFIG_BACKLIGHT_LED=m
|
||||
# end of Backlight & LCD device support
|
||||
|
||||
CONFIG_VIDEOMODE_HELPERS=y
|
||||
@ -4428,6 +4458,7 @@ CONFIG_SND_SOC_WM8994=m
|
||||
# CONFIG_SND_SOC_MAX9759 is not set
|
||||
# CONFIG_SND_SOC_MT6351 is not set
|
||||
CONFIG_SND_SOC_MT6358=m
|
||||
CONFIG_SND_SOC_MT6660=m
|
||||
# CONFIG_SND_SOC_NAU8540 is not set
|
||||
# CONFIG_SND_SOC_NAU8810 is not set
|
||||
CONFIG_SND_SOC_NAU8822=m
|
||||
@ -5079,6 +5110,7 @@ CONFIG_SYNC_FILE=y
|
||||
# CONFIG_SW_SYNC is not set
|
||||
# CONFIG_UDMABUF is not set
|
||||
# CONFIG_DMABUF_SELFTESTS is not set
|
||||
# CONFIG_DMABUF_HEAPS is not set
|
||||
# end of DMABUF options
|
||||
|
||||
# CONFIG_AUXDISPLAY is not set
|
||||
@ -5150,6 +5182,7 @@ CONFIG_ARM_ARCH_TIMER=y
|
||||
CONFIG_ARM_ARCH_TIMER_EVTSTREAM=y
|
||||
CONFIG_CLKSRC_EXYNOS_MCT=y
|
||||
CONFIG_CLKSRC_SAMSUNG_PWM=y
|
||||
# CONFIG_MICROCHIP_PIT64B is not set
|
||||
# end of Clock Source drivers
|
||||
|
||||
# CONFIG_MAILBOX is not set
|
||||
@ -5209,6 +5242,7 @@ CONFIG_EXYNOS_IOMMU=y
|
||||
#
|
||||
# NXP/Freescale QorIQ SoC drivers
|
||||
#
|
||||
# CONFIG_QUICC_ENGINE is not set
|
||||
# CONFIG_FSL_RCPM is not set
|
||||
# end of NXP/Freescale QorIQ SoC drivers
|
||||
|
||||
@ -5303,6 +5337,8 @@ CONFIG_IIO_CONSUMERS_PER_TRIGGER=2
|
||||
# CONFIG_ADXL372_I2C is not set
|
||||
# CONFIG_BMA180 is not set
|
||||
# CONFIG_BMA220 is not set
|
||||
CONFIG_BMA400=m
|
||||
CONFIG_BMA400_I2C=m
|
||||
# CONFIG_BMC150_ACCEL is not set
|
||||
# CONFIG_DA280 is not set
|
||||
# CONFIG_DA311 is not set
|
||||
@ -5330,6 +5366,7 @@ CONFIG_HID_SENSOR_ACCEL_3D=m
|
||||
#
|
||||
# Analog to digital converters
|
||||
#
|
||||
CONFIG_AD7091R5=m
|
||||
# CONFIG_AD7124 is not set
|
||||
# CONFIG_AD7266 is not set
|
||||
# CONFIG_AD7291 is not set
|
||||
@ -5354,6 +5391,7 @@ CONFIG_EXYNOS_ADC=y
|
||||
# CONFIG_HX711 is not set
|
||||
# CONFIG_LTC2471 is not set
|
||||
# CONFIG_LTC2485 is not set
|
||||
CONFIG_LTC2496=m
|
||||
# CONFIG_LTC2497 is not set
|
||||
# CONFIG_MAX1027 is not set
|
||||
# CONFIG_MAX11100 is not set
|
||||
@ -5659,6 +5697,7 @@ CONFIG_HID_SENSOR_DEVICE_ROTATION=m
|
||||
CONFIG_BMP280=m
|
||||
CONFIG_BMP280_I2C=m
|
||||
CONFIG_BMP280_SPI=m
|
||||
CONFIG_DLHL60D=m
|
||||
CONFIG_DPS310=m
|
||||
CONFIG_HID_SENSOR_PRESS=m
|
||||
# CONFIG_HP03 is not set
|
||||
@ -5685,6 +5724,7 @@ CONFIG_HID_SENSOR_PRESS=m
|
||||
# CONFIG_ISL29501 is not set
|
||||
# CONFIG_LIDAR_LITE_V2 is not set
|
||||
# CONFIG_MB1232 is not set
|
||||
CONFIG_PING=m
|
||||
# CONFIG_RFD77402 is not set
|
||||
# CONFIG_SRF04 is not set
|
||||
# CONFIG_SX9500 is not set
|
||||
@ -5729,6 +5769,7 @@ CONFIG_ARM_GIC=y
|
||||
CONFIG_ARM_GIC_MAX_NR=1
|
||||
CONFIG_GIC_NON_BANKED=y
|
||||
# CONFIG_AL_FIC is not set
|
||||
CONFIG_EXYNOS_IRQ_COMBINER=y
|
||||
# end of IRQ chip support
|
||||
|
||||
# CONFIG_IPACK_BUS is not set
|
||||
@ -5757,6 +5798,7 @@ CONFIG_PHY_EXYNOS4X12_USB2=y
|
||||
CONFIG_PHY_EXYNOS5250_USB2=y
|
||||
CONFIG_PHY_EXYNOS5_USBDRD=y
|
||||
CONFIG_PHY_EXYNOS5250_SATA=y
|
||||
CONFIG_PHY_INTEL_EMMC=m
|
||||
# end of PHY Subsystem
|
||||
|
||||
# CONFIG_POWERCAP is not set
|
||||
@ -5859,12 +5901,15 @@ CONFIG_F2FS_FS_POSIX_ACL=y
|
||||
CONFIG_F2FS_FS_SECURITY=y
|
||||
CONFIG_F2FS_CHECK_FS=y
|
||||
# CONFIG_F2FS_FAULT_INJECTION is not set
|
||||
# CONFIG_F2FS_FS_COMPRESSION is not set
|
||||
CONFIG_ZONEFS_FS=m
|
||||
CONFIG_FS_POSIX_ACL=y
|
||||
CONFIG_EXPORTFS=y
|
||||
CONFIG_EXPORTFS_BLOCK_OPS=y
|
||||
CONFIG_FILE_LOCKING=y
|
||||
CONFIG_MANDATORY_FILE_LOCKING=y
|
||||
CONFIG_FS_ENCRYPTION=y
|
||||
CONFIG_FS_ENCRYPTION_ALGS=y
|
||||
# CONFIG_FS_VERITY is not set
|
||||
CONFIG_FSNOTIFY=y
|
||||
CONFIG_DNOTIFY=y
|
||||
@ -5887,7 +5932,6 @@ CONFIG_OVERLAY_FS=m
|
||||
# CONFIG_OVERLAY_FS_REDIRECT_DIR is not set
|
||||
CONFIG_OVERLAY_FS_REDIRECT_ALWAYS_FOLLOW=y
|
||||
# CONFIG_OVERLAY_FS_INDEX is not set
|
||||
# CONFIG_OVERLAY_FS_XINO_AUTO is not set
|
||||
# CONFIG_OVERLAY_FS_METACOPY is not set
|
||||
|
||||
#
|
||||
@ -6000,6 +6044,7 @@ CONFIG_NFS_V4_SECURITY_LABEL=y
|
||||
CONFIG_ROOT_NFS=y
|
||||
# CONFIG_NFS_USE_LEGACY_DNS is not set
|
||||
CONFIG_NFS_USE_KERNEL_DNS=y
|
||||
CONFIG_NFS_DISABLE_UDP_SUPPORT=y
|
||||
CONFIG_NFSD=m
|
||||
CONFIG_NFSD_V2_ACL=y
|
||||
CONFIG_NFSD_V3=y
|
||||
@ -6009,6 +6054,7 @@ CONFIG_NFSD_PNFS=y
|
||||
CONFIG_NFSD_BLOCKLAYOUT=y
|
||||
CONFIG_NFSD_SCSILAYOUT=y
|
||||
CONFIG_NFSD_FLEXFILELAYOUT=y
|
||||
# CONFIG_NFSD_V4_2_INTER_SSC is not set
|
||||
# CONFIG_NFSD_V4_SECURITY_LABEL is not set
|
||||
CONFIG_GRACE_PERIOD=y
|
||||
CONFIG_LOCKD=y
|
||||
@ -6118,6 +6164,8 @@ CONFIG_SECURITY_SELINUX_BOOTPARAM=y
|
||||
CONFIG_SECURITY_SELINUX_DEVELOP=y
|
||||
CONFIG_SECURITY_SELINUX_AVC_STATS=y
|
||||
CONFIG_SECURITY_SELINUX_CHECKREQPROT_VALUE=0
|
||||
CONFIG_SECURITY_SELINUX_SIDTAB_HASH_BITS=9
|
||||
CONFIG_SECURITY_SELINUX_SID2STR_CACHE_SIZE=256
|
||||
# CONFIG_SECURITY_SMACK is not set
|
||||
# CONFIG_SECURITY_TOMOYO is not set
|
||||
CONFIG_SECURITY_APPARMOR=y
|
||||
@ -6601,7 +6649,9 @@ CONFIG_CONTEXT_SWITCH_TRACER=y
|
||||
CONFIG_TRACING=y
|
||||
CONFIG_TRACING_SUPPORT=y
|
||||
CONFIG_FTRACE=y
|
||||
# CONFIG_BOOTTIME_TRACING is not set
|
||||
# CONFIG_FUNCTION_TRACER is not set
|
||||
# CONFIG_STACK_TRACER is not set
|
||||
# CONFIG_PREEMPTIRQ_EVENTS is not set
|
||||
# CONFIG_IRQSOFF_TRACER is not set
|
||||
# CONFIG_PREEMPT_TRACER is not set
|
||||
@ -6613,7 +6663,6 @@ CONFIG_FTRACE=y
|
||||
CONFIG_BRANCH_PROFILE_NONE=y
|
||||
# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set
|
||||
# CONFIG_PROFILE_ALL_BRANCHES is not set
|
||||
# CONFIG_STACK_TRACER is not set
|
||||
# CONFIG_BLK_DEV_IO_TRACE is not set
|
||||
CONFIG_UPROBE_EVENTS=y
|
||||
CONFIG_BPF_EVENTS=y
|
||||
@ -6622,9 +6671,9 @@ CONFIG_PROBE_EVENTS=y
|
||||
# CONFIG_TRACE_EVENT_INJECT is not set
|
||||
# CONFIG_TRACEPOINT_BENCHMARK is not set
|
||||
# CONFIG_RING_BUFFER_BENCHMARK is not set
|
||||
# CONFIG_TRACE_EVAL_MAP_FILE is not set
|
||||
# CONFIG_RING_BUFFER_STARTUP_TEST is not set
|
||||
# CONFIG_PREEMPTIRQ_DELAY_TEST is not set
|
||||
# CONFIG_TRACE_EVAL_MAP_FILE is not set
|
||||
# CONFIG_SAMPLES is not set
|
||||
CONFIG_ARCH_HAS_DEVMEM_IS_ALLOWED=y
|
||||
# CONFIG_STRICT_DEVMEM is not set
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
#
|
||||
# Automatically generated file; DO NOT EDIT.
|
||||
# Linux/arm 4.14.174 Kernel Configuration
|
||||
# Linux/arm 4.14.175 Kernel Configuration
|
||||
#
|
||||
CONFIG_ARM=y
|
||||
CONFIG_ARM_HAS_SG_CHAIN=y
|
||||
@ -2144,6 +2144,8 @@ CONFIG_RTL8822BU=m
|
||||
CONFIG_RTL8188EU=m
|
||||
# CONFIG_RTL8821CU is not set
|
||||
CONFIG_88XXAU=m
|
||||
CONFIG_RTL8189FS=m
|
||||
CONFIG_RTL8189ES=m
|
||||
CONFIG_WLAN_VENDOR_ZYDAS=y
|
||||
CONFIG_USB_ZD1201=m
|
||||
CONFIG_ZD1211RW=m
|
||||
|
||||
@ -25,7 +25,7 @@ case $BRANCH in
|
||||
;;
|
||||
|
||||
dev)
|
||||
KERNELBRANCH='branch:linux-5.5.y'
|
||||
KERNELBRANCH='branch:linux-5.6.y'
|
||||
;;
|
||||
|
||||
esac
|
||||
|
||||
5915
patch/kernel/odroidxu4-current/03-patch-5.4.28-29.patch
Normal file
5915
patch/kernel/odroidxu4-current/03-patch-5.4.28-29.patch
Normal file
File diff suppressed because it is too large
Load Diff
994
patch/kernel/odroidxu4-current/03-patch-5.4.29-30.patch
Normal file
994
patch/kernel/odroidxu4-current/03-patch-5.4.29-30.patch
Normal file
@ -0,0 +1,994 @@
|
||||
diff --git a/Makefile b/Makefile
|
||||
index 8cb72071a842..e1f41756f475 100644
|
||||
--- a/Makefile
|
||||
+++ b/Makefile
|
||||
@@ -1,7 +1,7 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
VERSION = 5
|
||||
PATCHLEVEL = 4
|
||||
-SUBLEVEL = 29
|
||||
+SUBLEVEL = 30
|
||||
EXTRAVERSION =
|
||||
NAME = Kleptomaniac Octopus
|
||||
|
||||
diff --git a/arch/arm/boot/dts/bcm2835-rpi-zero-w.dts b/arch/arm/boot/dts/bcm2835-rpi-zero-w.dts
|
||||
index b75af21069f9..4c3f606e5b8d 100644
|
||||
--- a/arch/arm/boot/dts/bcm2835-rpi-zero-w.dts
|
||||
+++ b/arch/arm/boot/dts/bcm2835-rpi-zero-w.dts
|
||||
@@ -112,6 +112,7 @@
|
||||
&sdhci {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
+ pinctrl-names = "default";
|
||||
pinctrl-0 = <&emmc_gpio34 &gpclk2_gpio43>;
|
||||
bus-width = <4>;
|
||||
mmc-pwrseq = <&wifi_pwrseq>;
|
||||
diff --git a/arch/arm/boot/dts/imx6qdl-phytec-phycore-som.dtsi b/arch/arm/boot/dts/imx6qdl-phytec-phycore-som.dtsi
|
||||
index 881cea0b61ba..31fa37d2fe47 100644
|
||||
--- a/arch/arm/boot/dts/imx6qdl-phytec-phycore-som.dtsi
|
||||
+++ b/arch/arm/boot/dts/imx6qdl-phytec-phycore-som.dtsi
|
||||
@@ -107,14 +107,14 @@
|
||||
regulators {
|
||||
vdd_arm: buck1 {
|
||||
regulator-name = "vdd_arm";
|
||||
- regulator-min-microvolt = <730000>;
|
||||
+ regulator-min-microvolt = <925000>;
|
||||
regulator-max-microvolt = <1380000>;
|
||||
regulator-always-on;
|
||||
};
|
||||
|
||||
vdd_soc: buck2 {
|
||||
regulator-name = "vdd_soc";
|
||||
- regulator-min-microvolt = <730000>;
|
||||
+ regulator-min-microvolt = <1150000>;
|
||||
regulator-max-microvolt = <1380000>;
|
||||
regulator-always-on;
|
||||
};
|
||||
diff --git a/arch/arm/boot/dts/omap3-n900.dts b/arch/arm/boot/dts/omap3-n900.dts
|
||||
index 63659880eeb3..7f2ddb78da5f 100644
|
||||
--- a/arch/arm/boot/dts/omap3-n900.dts
|
||||
+++ b/arch/arm/boot/dts/omap3-n900.dts
|
||||
@@ -849,34 +849,46 @@
|
||||
compatible = "ti,omap2-onenand";
|
||||
reg = <0 0 0x20000>; /* CS0, offset 0, IO size 128K */
|
||||
|
||||
+ /*
|
||||
+ * These timings are based on CONFIG_OMAP_GPMC_DEBUG=y reported
|
||||
+ * bootloader set values when booted with v5.1
|
||||
+ * (OneNAND Manufacturer: Samsung):
|
||||
+ *
|
||||
+ * cs0 GPMC_CS_CONFIG1: 0xfb001202
|
||||
+ * cs0 GPMC_CS_CONFIG2: 0x00111100
|
||||
+ * cs0 GPMC_CS_CONFIG3: 0x00020200
|
||||
+ * cs0 GPMC_CS_CONFIG4: 0x11001102
|
||||
+ * cs0 GPMC_CS_CONFIG5: 0x03101616
|
||||
+ * cs0 GPMC_CS_CONFIG6: 0x90060000
|
||||
+ */
|
||||
gpmc,sync-read;
|
||||
gpmc,sync-write;
|
||||
gpmc,burst-length = <16>;
|
||||
gpmc,burst-read;
|
||||
gpmc,burst-wrap;
|
||||
gpmc,burst-write;
|
||||
- gpmc,device-width = <2>; /* GPMC_DEVWIDTH_16BIT */
|
||||
- gpmc,mux-add-data = <2>; /* GPMC_MUX_AD */
|
||||
+ gpmc,device-width = <2>;
|
||||
+ gpmc,mux-add-data = <2>;
|
||||
gpmc,cs-on-ns = <0>;
|
||||
- gpmc,cs-rd-off-ns = <87>;
|
||||
- gpmc,cs-wr-off-ns = <87>;
|
||||
+ gpmc,cs-rd-off-ns = <102>;
|
||||
+ gpmc,cs-wr-off-ns = <102>;
|
||||
gpmc,adv-on-ns = <0>;
|
||||
- gpmc,adv-rd-off-ns = <10>;
|
||||
- gpmc,adv-wr-off-ns = <10>;
|
||||
- gpmc,oe-on-ns = <15>;
|
||||
- gpmc,oe-off-ns = <87>;
|
||||
+ gpmc,adv-rd-off-ns = <12>;
|
||||
+ gpmc,adv-wr-off-ns = <12>;
|
||||
+ gpmc,oe-on-ns = <12>;
|
||||
+ gpmc,oe-off-ns = <102>;
|
||||
gpmc,we-on-ns = <0>;
|
||||
- gpmc,we-off-ns = <87>;
|
||||
- gpmc,rd-cycle-ns = <112>;
|
||||
- gpmc,wr-cycle-ns = <112>;
|
||||
- gpmc,access-ns = <81>;
|
||||
- gpmc,page-burst-access-ns = <15>;
|
||||
+ gpmc,we-off-ns = <102>;
|
||||
+ gpmc,rd-cycle-ns = <132>;
|
||||
+ gpmc,wr-cycle-ns = <132>;
|
||||
+ gpmc,access-ns = <96>;
|
||||
+ gpmc,page-burst-access-ns = <18>;
|
||||
gpmc,bus-turnaround-ns = <0>;
|
||||
gpmc,cycle2cycle-delay-ns = <0>;
|
||||
gpmc,wait-monitoring-ns = <0>;
|
||||
- gpmc,clk-activation-ns = <5>;
|
||||
- gpmc,wr-data-mux-bus-ns = <30>;
|
||||
- gpmc,wr-access-ns = <81>;
|
||||
+ gpmc,clk-activation-ns = <6>;
|
||||
+ gpmc,wr-data-mux-bus-ns = <36>;
|
||||
+ gpmc,wr-access-ns = <96>;
|
||||
gpmc,sync-clk-ps = <15000>;
|
||||
|
||||
/*
|
||||
diff --git a/arch/arm/boot/dts/ox810se.dtsi b/arch/arm/boot/dts/ox810se.dtsi
|
||||
index 9f6c2b660ed3..0755e5864c4a 100644
|
||||
--- a/arch/arm/boot/dts/ox810se.dtsi
|
||||
+++ b/arch/arm/boot/dts/ox810se.dtsi
|
||||
@@ -323,8 +323,8 @@
|
||||
interrupt-controller;
|
||||
reg = <0 0x200>;
|
||||
#interrupt-cells = <1>;
|
||||
- valid-mask = <0xFFFFFFFF>;
|
||||
- clear-mask = <0>;
|
||||
+ valid-mask = <0xffffffff>;
|
||||
+ clear-mask = <0xffffffff>;
|
||||
};
|
||||
|
||||
timer0: timer@200 {
|
||||
diff --git a/arch/arm/boot/dts/ox820.dtsi b/arch/arm/boot/dts/ox820.dtsi
|
||||
index c9b327732063..90846a7655b4 100644
|
||||
--- a/arch/arm/boot/dts/ox820.dtsi
|
||||
+++ b/arch/arm/boot/dts/ox820.dtsi
|
||||
@@ -240,8 +240,8 @@
|
||||
reg = <0 0x200>;
|
||||
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
||||
#interrupt-cells = <1>;
|
||||
- valid-mask = <0xFFFFFFFF>;
|
||||
- clear-mask = <0>;
|
||||
+ valid-mask = <0xffffffff>;
|
||||
+ clear-mask = <0xffffffff>;
|
||||
};
|
||||
|
||||
timer0: timer@200 {
|
||||
diff --git a/arch/arm/boot/dts/sun8i-r40.dtsi b/arch/arm/boot/dts/sun8i-r40.dtsi
|
||||
index c9c2688db66d..80f4dc34df34 100644
|
||||
--- a/arch/arm/boot/dts/sun8i-r40.dtsi
|
||||
+++ b/arch/arm/boot/dts/sun8i-r40.dtsi
|
||||
@@ -266,6 +266,16 @@
|
||||
#phy-cells = <1>;
|
||||
};
|
||||
|
||||
+ ahci: sata@1c18000 {
|
||||
+ compatible = "allwinner,sun8i-r40-ahci";
|
||||
+ reg = <0x01c18000 0x1000>;
|
||||
+ interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
|
||||
+ clocks = <&ccu CLK_BUS_SATA>, <&ccu CLK_SATA>;
|
||||
+ resets = <&ccu RST_BUS_SATA>;
|
||||
+ reset-names = "ahci";
|
||||
+ status = "disabled";
|
||||
+ };
|
||||
+
|
||||
ehci1: usb@1c19000 {
|
||||
compatible = "allwinner,sun8i-r40-ehci", "generic-ehci";
|
||||
reg = <0x01c19000 0x100>;
|
||||
@@ -557,17 +567,6 @@
|
||||
#size-cells = <0>;
|
||||
};
|
||||
|
||||
- ahci: sata@1c18000 {
|
||||
- compatible = "allwinner,sun8i-r40-ahci";
|
||||
- reg = <0x01c18000 0x1000>;
|
||||
- interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
|
||||
- clocks = <&ccu CLK_BUS_SATA>, <&ccu CLK_SATA>;
|
||||
- resets = <&ccu RST_BUS_SATA>;
|
||||
- reset-names = "ahci";
|
||||
- status = "disabled";
|
||||
-
|
||||
- };
|
||||
-
|
||||
gmac: ethernet@1c50000 {
|
||||
compatible = "allwinner,sun8i-r40-gmac";
|
||||
syscon = <&ccu>;
|
||||
diff --git a/arch/arm64/boot/dts/freescale/fsl-ls1043a-rdb.dts b/arch/arm64/boot/dts/freescale/fsl-ls1043a-rdb.dts
|
||||
index 4223a2352d45..dde50c88f5e3 100644
|
||||
--- a/arch/arm64/boot/dts/freescale/fsl-ls1043a-rdb.dts
|
||||
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1043a-rdb.dts
|
||||
@@ -119,12 +119,12 @@
|
||||
|
||||
ethernet@e4000 {
|
||||
phy-handle = <&rgmii_phy1>;
|
||||
- phy-connection-type = "rgmii-txid";
|
||||
+ phy-connection-type = "rgmii-id";
|
||||
};
|
||||
|
||||
ethernet@e6000 {
|
||||
phy-handle = <&rgmii_phy2>;
|
||||
- phy-connection-type = "rgmii-txid";
|
||||
+ phy-connection-type = "rgmii-id";
|
||||
};
|
||||
|
||||
ethernet@e8000 {
|
||||
diff --git a/arch/arm64/boot/dts/freescale/fsl-ls1046a-rdb.dts b/arch/arm64/boot/dts/freescale/fsl-ls1046a-rdb.dts
|
||||
index 6a6514d0e5a9..274339759114 100644
|
||||
--- a/arch/arm64/boot/dts/freescale/fsl-ls1046a-rdb.dts
|
||||
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1046a-rdb.dts
|
||||
@@ -127,12 +127,12 @@
|
||||
&fman0 {
|
||||
ethernet@e4000 {
|
||||
phy-handle = <&rgmii_phy1>;
|
||||
- phy-connection-type = "rgmii";
|
||||
+ phy-connection-type = "rgmii-id";
|
||||
};
|
||||
|
||||
ethernet@e6000 {
|
||||
phy-handle = <&rgmii_phy2>;
|
||||
- phy-connection-type = "rgmii";
|
||||
+ phy-connection-type = "rgmii-id";
|
||||
};
|
||||
|
||||
ethernet@e8000 {
|
||||
diff --git a/arch/arm64/include/asm/alternative.h b/arch/arm64/include/asm/alternative.h
|
||||
index 324e7d5ab37e..5e5dc05d63a0 100644
|
||||
--- a/arch/arm64/include/asm/alternative.h
|
||||
+++ b/arch/arm64/include/asm/alternative.h
|
||||
@@ -221,7 +221,7 @@ alternative_endif
|
||||
|
||||
.macro user_alt, label, oldinstr, newinstr, cond
|
||||
9999: alternative_insn "\oldinstr", "\newinstr", \cond
|
||||
- _ASM_EXTABLE 9999b, \label
|
||||
+ _asm_extable 9999b, \label
|
||||
.endm
|
||||
|
||||
/*
|
||||
diff --git a/drivers/clk/imx/clk-scu.c b/drivers/clk/imx/clk-scu.c
|
||||
index fbef740704d0..b8b2072742a5 100644
|
||||
--- a/drivers/clk/imx/clk-scu.c
|
||||
+++ b/drivers/clk/imx/clk-scu.c
|
||||
@@ -43,12 +43,12 @@ struct imx_sc_msg_req_set_clock_rate {
|
||||
__le32 rate;
|
||||
__le16 resource;
|
||||
u8 clk;
|
||||
-} __packed;
|
||||
+} __packed __aligned(4);
|
||||
|
||||
struct req_get_clock_rate {
|
||||
__le16 resource;
|
||||
u8 clk;
|
||||
-} __packed;
|
||||
+} __packed __aligned(4);
|
||||
|
||||
struct resp_get_clock_rate {
|
||||
__le32 rate;
|
||||
@@ -84,7 +84,7 @@ struct imx_sc_msg_get_clock_parent {
|
||||
struct req_get_clock_parent {
|
||||
__le16 resource;
|
||||
u8 clk;
|
||||
- } __packed req;
|
||||
+ } __packed __aligned(4) req;
|
||||
struct resp_get_clock_parent {
|
||||
u8 parent;
|
||||
} resp;
|
||||
@@ -121,7 +121,7 @@ struct imx_sc_msg_req_clock_enable {
|
||||
u8 clk;
|
||||
u8 enable;
|
||||
u8 autog;
|
||||
-} __packed;
|
||||
+} __packed __aligned(4);
|
||||
|
||||
static inline struct clk_scu *to_clk_scu(struct clk_hw *hw)
|
||||
{
|
||||
diff --git a/drivers/clk/ti/clk-43xx.c b/drivers/clk/ti/clk-43xx.c
|
||||
index 2782d91838ac..2cca1ced913d 100644
|
||||
--- a/drivers/clk/ti/clk-43xx.c
|
||||
+++ b/drivers/clk/ti/clk-43xx.c
|
||||
@@ -78,7 +78,7 @@ static const struct omap_clkctrl_reg_data am4_gfx_l3_clkctrl_regs[] __initconst
|
||||
};
|
||||
|
||||
static const struct omap_clkctrl_reg_data am4_l4_rtc_clkctrl_regs[] __initconst = {
|
||||
- { AM4_L4_RTC_RTC_CLKCTRL, NULL, CLKF_SW_SUP, "clk_32768_ck" },
|
||||
+ { AM4_L4_RTC_RTC_CLKCTRL, NULL, CLKF_SW_SUP, "clkdiv32k_ick" },
|
||||
{ 0 },
|
||||
};
|
||||
|
||||
diff --git a/drivers/gpio/gpiolib-acpi.c b/drivers/gpio/gpiolib-acpi.c
|
||||
index a3fb450a9ca8..b2e186047014 100644
|
||||
--- a/drivers/gpio/gpiolib-acpi.c
|
||||
+++ b/drivers/gpio/gpiolib-acpi.c
|
||||
@@ -1430,6 +1430,21 @@ static const struct dmi_system_id gpiolib_acpi_quirks[] = {
|
||||
.ignore_wake = "INT33FC:02@28",
|
||||
},
|
||||
},
|
||||
+ {
|
||||
+ /*
|
||||
+ * HP X2 10 models with Cherry Trail SoC + AXP288 PMIC use an
|
||||
+ * external embedded-controller connected via I2C + an ACPI GPIO
|
||||
+ * event handler on INT33FF:01 pin 0, causing spurious wakeups.
|
||||
+ */
|
||||
+ .matches = {
|
||||
+ DMI_MATCH(DMI_SYS_VENDOR, "HP"),
|
||||
+ DMI_MATCH(DMI_PRODUCT_NAME, "HP Pavilion x2 Detachable"),
|
||||
+ DMI_MATCH(DMI_BOARD_NAME, "813E"),
|
||||
+ },
|
||||
+ .driver_data = &(struct acpi_gpiolib_dmi_quirk) {
|
||||
+ .ignore_wake = "INT33FF:01@0",
|
||||
+ },
|
||||
+ },
|
||||
{} /* Terminating entry */
|
||||
};
|
||||
|
||||
diff --git a/drivers/net/ethernet/micrel/ks8851_mll.c b/drivers/net/ethernet/micrel/ks8851_mll.c
|
||||
index 58579baf3f7a..45cc840d8e2e 100644
|
||||
--- a/drivers/net/ethernet/micrel/ks8851_mll.c
|
||||
+++ b/drivers/net/ethernet/micrel/ks8851_mll.c
|
||||
@@ -156,6 +156,50 @@ static int msg_enable;
|
||||
* chip is busy transferring packet data (RX/TX FIFO accesses).
|
||||
*/
|
||||
|
||||
+/**
|
||||
+ * ks_check_endian - Check whether endianness of the bus is correct
|
||||
+ * @ks : The chip information
|
||||
+ *
|
||||
+ * The KS8851-16MLL EESK pin allows selecting the endianness of the 16bit
|
||||
+ * bus. To maintain optimum performance, the bus endianness should be set
|
||||
+ * such that it matches the endianness of the CPU.
|
||||
+ */
|
||||
+
|
||||
+static int ks_check_endian(struct ks_net *ks)
|
||||
+{
|
||||
+ u16 cider;
|
||||
+
|
||||
+ /*
|
||||
+ * Read CIDER register first, however read it the "wrong" way around.
|
||||
+ * If the endian strap on the KS8851-16MLL in incorrect and the chip
|
||||
+ * is operating in different endianness than the CPU, then the meaning
|
||||
+ * of BE[3:0] byte-enable bits is also swapped such that:
|
||||
+ * BE[3,2,1,0] becomes BE[1,0,3,2]
|
||||
+ *
|
||||
+ * Luckily for us, the byte-enable bits are the top four MSbits of
|
||||
+ * the address register and the CIDER register is at offset 0xc0.
|
||||
+ * Hence, by reading address 0xc0c0, which is not impacted by endian
|
||||
+ * swapping, we assert either BE[3:2] or BE[1:0] while reading the
|
||||
+ * CIDER register.
|
||||
+ *
|
||||
+ * If the bus configuration is correct, reading 0xc0c0 asserts
|
||||
+ * BE[3:2] and this read returns 0x0000, because to read register
|
||||
+ * with bottom two LSbits of address set to 0, BE[1:0] must be
|
||||
+ * asserted.
|
||||
+ *
|
||||
+ * If the bus configuration is NOT correct, reading 0xc0c0 asserts
|
||||
+ * BE[1:0] and this read returns non-zero 0x8872 value.
|
||||
+ */
|
||||
+ iowrite16(BE3 | BE2 | KS_CIDER, ks->hw_addr_cmd);
|
||||
+ cider = ioread16(ks->hw_addr);
|
||||
+ if (!cider)
|
||||
+ return 0;
|
||||
+
|
||||
+ netdev_err(ks->netdev, "incorrect EESK endian strap setting\n");
|
||||
+
|
||||
+ return -EINVAL;
|
||||
+}
|
||||
+
|
||||
/**
|
||||
* ks_rdreg16 - read 16 bit register from device
|
||||
* @ks : The chip information
|
||||
@@ -166,7 +210,7 @@ static int msg_enable;
|
||||
|
||||
static u16 ks_rdreg16(struct ks_net *ks, int offset)
|
||||
{
|
||||
- ks->cmd_reg_cache = (u16)offset | ((BE3 | BE2) >> (offset & 0x02));
|
||||
+ ks->cmd_reg_cache = (u16)offset | ((BE1 | BE0) << (offset & 0x02));
|
||||
iowrite16(ks->cmd_reg_cache, ks->hw_addr_cmd);
|
||||
return ioread16(ks->hw_addr);
|
||||
}
|
||||
@@ -181,7 +225,7 @@ static u16 ks_rdreg16(struct ks_net *ks, int offset)
|
||||
|
||||
static void ks_wrreg16(struct ks_net *ks, int offset, u16 value)
|
||||
{
|
||||
- ks->cmd_reg_cache = (u16)offset | ((BE3 | BE2) >> (offset & 0x02));
|
||||
+ ks->cmd_reg_cache = (u16)offset | ((BE1 | BE0) << (offset & 0x02));
|
||||
iowrite16(ks->cmd_reg_cache, ks->hw_addr_cmd);
|
||||
iowrite16(value, ks->hw_addr);
|
||||
}
|
||||
@@ -197,7 +241,7 @@ static inline void ks_inblk(struct ks_net *ks, u16 *wptr, u32 len)
|
||||
{
|
||||
len >>= 1;
|
||||
while (len--)
|
||||
- *wptr++ = be16_to_cpu(ioread16(ks->hw_addr));
|
||||
+ *wptr++ = (u16)ioread16(ks->hw_addr);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -211,7 +255,7 @@ static inline void ks_outblk(struct ks_net *ks, u16 *wptr, u32 len)
|
||||
{
|
||||
len >>= 1;
|
||||
while (len--)
|
||||
- iowrite16(cpu_to_be16(*wptr++), ks->hw_addr);
|
||||
+ iowrite16(*wptr++, ks->hw_addr);
|
||||
}
|
||||
|
||||
static void ks_disable_int(struct ks_net *ks)
|
||||
@@ -1218,6 +1262,10 @@ static int ks8851_probe(struct platform_device *pdev)
|
||||
goto err_free;
|
||||
}
|
||||
|
||||
+ err = ks_check_endian(ks);
|
||||
+ if (err)
|
||||
+ goto err_free;
|
||||
+
|
||||
netdev->irq = platform_get_irq(pdev, 0);
|
||||
|
||||
if ((int)netdev->irq < 0) {
|
||||
diff --git a/drivers/platform/x86/pmc_atom.c b/drivers/platform/x86/pmc_atom.c
|
||||
index 52ef1419b671..2b1a3a6ee8db 100644
|
||||
--- a/drivers/platform/x86/pmc_atom.c
|
||||
+++ b/drivers/platform/x86/pmc_atom.c
|
||||
@@ -383,6 +383,14 @@ static const struct dmi_system_id critclk_systems[] = {
|
||||
DMI_MATCH(DMI_PRODUCT_NAME, "3I380D"),
|
||||
},
|
||||
},
|
||||
+ {
|
||||
+ /* pmc_plt_clk* - are used for ethernet controllers */
|
||||
+ .ident = "Lex 2I385SW",
|
||||
+ .matches = {
|
||||
+ DMI_MATCH(DMI_SYS_VENDOR, "Lex BayTrail"),
|
||||
+ DMI_MATCH(DMI_PRODUCT_NAME, "2I385SW"),
|
||||
+ },
|
||||
+ },
|
||||
{
|
||||
/* pmc_plt_clk* - are used for ethernet controllers */
|
||||
.ident = "Beckhoff CB3163",
|
||||
diff --git a/drivers/tty/serial/sprd_serial.c b/drivers/tty/serial/sprd_serial.c
|
||||
index 494e2672ebd7..07573de70445 100644
|
||||
--- a/drivers/tty/serial/sprd_serial.c
|
||||
+++ b/drivers/tty/serial/sprd_serial.c
|
||||
@@ -1103,14 +1103,13 @@ static int sprd_remove(struct platform_device *dev)
|
||||
if (sup) {
|
||||
uart_remove_one_port(&sprd_uart_driver, &sup->port);
|
||||
sprd_port[sup->port.line] = NULL;
|
||||
+ sprd_rx_free_buf(sup);
|
||||
sprd_ports_num--;
|
||||
}
|
||||
|
||||
if (!sprd_ports_num)
|
||||
uart_unregister_driver(&sprd_uart_driver);
|
||||
|
||||
- sprd_rx_free_buf(sup);
|
||||
-
|
||||
return 0;
|
||||
}
|
||||
|
||||
diff --git a/drivers/tty/vt/selection.c b/drivers/tty/vt/selection.c
|
||||
index d7d2e4b844bc..7556139cd0da 100644
|
||||
--- a/drivers/tty/vt/selection.c
|
||||
+++ b/drivers/tty/vt/selection.c
|
||||
@@ -88,6 +88,11 @@ void clear_selection(void)
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(clear_selection);
|
||||
|
||||
+bool vc_is_sel(struct vc_data *vc)
|
||||
+{
|
||||
+ return vc == sel_cons;
|
||||
+}
|
||||
+
|
||||
/*
|
||||
* User settable table: what characters are to be considered alphabetic?
|
||||
* 128 bits. Locked by the console lock.
|
||||
diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c
|
||||
index e9e27ba69d5d..fa9433e6cdc7 100644
|
||||
--- a/drivers/tty/vt/vt.c
|
||||
+++ b/drivers/tty/vt/vt.c
|
||||
@@ -890,8 +890,9 @@ static void hide_softcursor(struct vc_data *vc)
|
||||
|
||||
static void hide_cursor(struct vc_data *vc)
|
||||
{
|
||||
- if (vc == sel_cons)
|
||||
+ if (vc_is_sel(vc))
|
||||
clear_selection();
|
||||
+
|
||||
vc->vc_sw->con_cursor(vc, CM_ERASE);
|
||||
hide_softcursor(vc);
|
||||
}
|
||||
@@ -901,7 +902,7 @@ static void set_cursor(struct vc_data *vc)
|
||||
if (!con_is_fg(vc) || console_blanked || vc->vc_mode == KD_GRAPHICS)
|
||||
return;
|
||||
if (vc->vc_deccm) {
|
||||
- if (vc == sel_cons)
|
||||
+ if (vc_is_sel(vc))
|
||||
clear_selection();
|
||||
add_softcursor(vc);
|
||||
if ((vc->vc_cursor_type & 0x0f) != 1)
|
||||
@@ -1074,6 +1075,17 @@ static void visual_deinit(struct vc_data *vc)
|
||||
module_put(vc->vc_sw->owner);
|
||||
}
|
||||
|
||||
+static void vc_port_destruct(struct tty_port *port)
|
||||
+{
|
||||
+ struct vc_data *vc = container_of(port, struct vc_data, port);
|
||||
+
|
||||
+ kfree(vc);
|
||||
+}
|
||||
+
|
||||
+static const struct tty_port_operations vc_port_ops = {
|
||||
+ .destruct = vc_port_destruct,
|
||||
+};
|
||||
+
|
||||
int vc_allocate(unsigned int currcons) /* return 0 on success */
|
||||
{
|
||||
struct vt_notifier_param param;
|
||||
@@ -1099,6 +1111,7 @@ int vc_allocate(unsigned int currcons) /* return 0 on success */
|
||||
|
||||
vc_cons[currcons].d = vc;
|
||||
tty_port_init(&vc->port);
|
||||
+ vc->port.ops = &vc_port_ops;
|
||||
INIT_WORK(&vc_cons[currcons].SAK_work, vc_SAK);
|
||||
|
||||
visual_init(vc, currcons, 1);
|
||||
@@ -1207,7 +1220,7 @@ static int vc_do_resize(struct tty_struct *tty, struct vc_data *vc,
|
||||
}
|
||||
}
|
||||
|
||||
- if (vc == sel_cons)
|
||||
+ if (vc_is_sel(vc))
|
||||
clear_selection();
|
||||
|
||||
old_rows = vc->vc_rows;
|
||||
@@ -3253,6 +3266,7 @@ static int con_install(struct tty_driver *driver, struct tty_struct *tty)
|
||||
|
||||
tty->driver_data = vc;
|
||||
vc->port.tty = tty;
|
||||
+ tty_port_get(&vc->port);
|
||||
|
||||
if (!tty->winsize.ws_row && !tty->winsize.ws_col) {
|
||||
tty->winsize.ws_row = vc_cons[currcons].d->vc_rows;
|
||||
@@ -3288,6 +3302,13 @@ static void con_shutdown(struct tty_struct *tty)
|
||||
console_unlock();
|
||||
}
|
||||
|
||||
+static void con_cleanup(struct tty_struct *tty)
|
||||
+{
|
||||
+ struct vc_data *vc = tty->driver_data;
|
||||
+
|
||||
+ tty_port_put(&vc->port);
|
||||
+}
|
||||
+
|
||||
static int default_color = 7; /* white */
|
||||
static int default_italic_color = 2; // green (ASCII)
|
||||
static int default_underline_color = 3; // cyan (ASCII)
|
||||
@@ -3412,7 +3433,8 @@ static const struct tty_operations con_ops = {
|
||||
.throttle = con_throttle,
|
||||
.unthrottle = con_unthrottle,
|
||||
.resize = vt_resize,
|
||||
- .shutdown = con_shutdown
|
||||
+ .shutdown = con_shutdown,
|
||||
+ .cleanup = con_cleanup,
|
||||
};
|
||||
|
||||
static struct cdev vc0_cdev;
|
||||
diff --git a/drivers/tty/vt/vt_ioctl.c b/drivers/tty/vt/vt_ioctl.c
|
||||
index ee6c91ef1f6c..daf61c28ba76 100644
|
||||
--- a/drivers/tty/vt/vt_ioctl.c
|
||||
+++ b/drivers/tty/vt/vt_ioctl.c
|
||||
@@ -39,11 +39,32 @@
|
||||
#include <linux/kbd_diacr.h>
|
||||
#include <linux/selection.h>
|
||||
|
||||
-char vt_dont_switch;
|
||||
-extern struct tty_driver *console_driver;
|
||||
+bool vt_dont_switch;
|
||||
|
||||
-#define VT_IS_IN_USE(i) (console_driver->ttys[i] && console_driver->ttys[i]->count)
|
||||
-#define VT_BUSY(i) (VT_IS_IN_USE(i) || i == fg_console || vc_cons[i].d == sel_cons)
|
||||
+static inline bool vt_in_use(unsigned int i)
|
||||
+{
|
||||
+ const struct vc_data *vc = vc_cons[i].d;
|
||||
+
|
||||
+ /*
|
||||
+ * console_lock must be held to prevent the vc from being deallocated
|
||||
+ * while we're checking whether it's in-use.
|
||||
+ */
|
||||
+ WARN_CONSOLE_UNLOCKED();
|
||||
+
|
||||
+ return vc && kref_read(&vc->port.kref) > 1;
|
||||
+}
|
||||
+
|
||||
+static inline bool vt_busy(int i)
|
||||
+{
|
||||
+ if (vt_in_use(i))
|
||||
+ return true;
|
||||
+ if (i == fg_console)
|
||||
+ return true;
|
||||
+ if (vc_is_sel(vc_cons[i].d))
|
||||
+ return true;
|
||||
+
|
||||
+ return false;
|
||||
+}
|
||||
|
||||
/*
|
||||
* Console (vt and kd) routines, as defined by USL SVR4 manual, and by
|
||||
@@ -289,16 +310,14 @@ static int vt_disallocate(unsigned int vc_num)
|
||||
int ret = 0;
|
||||
|
||||
console_lock();
|
||||
- if (VT_BUSY(vc_num))
|
||||
+ if (vt_busy(vc_num))
|
||||
ret = -EBUSY;
|
||||
else if (vc_num)
|
||||
vc = vc_deallocate(vc_num);
|
||||
console_unlock();
|
||||
|
||||
- if (vc && vc_num >= MIN_NR_CONSOLES) {
|
||||
- tty_port_destroy(&vc->port);
|
||||
- kfree(vc);
|
||||
- }
|
||||
+ if (vc && vc_num >= MIN_NR_CONSOLES)
|
||||
+ tty_port_put(&vc->port);
|
||||
|
||||
return ret;
|
||||
}
|
||||
@@ -311,17 +330,15 @@ static void vt_disallocate_all(void)
|
||||
|
||||
console_lock();
|
||||
for (i = 1; i < MAX_NR_CONSOLES; i++)
|
||||
- if (!VT_BUSY(i))
|
||||
+ if (!vt_busy(i))
|
||||
vc[i] = vc_deallocate(i);
|
||||
else
|
||||
vc[i] = NULL;
|
||||
console_unlock();
|
||||
|
||||
for (i = 1; i < MAX_NR_CONSOLES; i++) {
|
||||
- if (vc[i] && i >= MIN_NR_CONSOLES) {
|
||||
- tty_port_destroy(&vc[i]->port);
|
||||
- kfree(vc[i]);
|
||||
- }
|
||||
+ if (vc[i] && i >= MIN_NR_CONSOLES)
|
||||
+ tty_port_put(&vc[i]->port);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -335,22 +352,13 @@ int vt_ioctl(struct tty_struct *tty,
|
||||
{
|
||||
struct vc_data *vc = tty->driver_data;
|
||||
struct console_font_op op; /* used in multiple places here */
|
||||
- unsigned int console;
|
||||
+ unsigned int console = vc->vc_num;
|
||||
unsigned char ucval;
|
||||
unsigned int uival;
|
||||
void __user *up = (void __user *)arg;
|
||||
int i, perm;
|
||||
int ret = 0;
|
||||
|
||||
- console = vc->vc_num;
|
||||
-
|
||||
-
|
||||
- if (!vc_cons_allocated(console)) { /* impossible? */
|
||||
- ret = -ENOIOCTLCMD;
|
||||
- goto out;
|
||||
- }
|
||||
-
|
||||
-
|
||||
/*
|
||||
* To have permissions to do most of the vt ioctls, we either have
|
||||
* to be the owner of the tty, or have CAP_SYS_TTY_CONFIG.
|
||||
@@ -641,15 +649,16 @@ int vt_ioctl(struct tty_struct *tty,
|
||||
struct vt_stat __user *vtstat = up;
|
||||
unsigned short state, mask;
|
||||
|
||||
- /* Review: FIXME: Console lock ? */
|
||||
if (put_user(fg_console + 1, &vtstat->v_active))
|
||||
ret = -EFAULT;
|
||||
else {
|
||||
state = 1; /* /dev/tty0 is always open */
|
||||
+ console_lock(); /* required by vt_in_use() */
|
||||
for (i = 0, mask = 2; i < MAX_NR_CONSOLES && mask;
|
||||
++i, mask <<= 1)
|
||||
- if (VT_IS_IN_USE(i))
|
||||
+ if (vt_in_use(i))
|
||||
state |= mask;
|
||||
+ console_unlock();
|
||||
ret = put_user(state, &vtstat->v_state);
|
||||
}
|
||||
break;
|
||||
@@ -659,10 +668,11 @@ int vt_ioctl(struct tty_struct *tty,
|
||||
* Returns the first available (non-opened) console.
|
||||
*/
|
||||
case VT_OPENQRY:
|
||||
- /* FIXME: locking ? - but then this is a stupid API */
|
||||
+ console_lock(); /* required by vt_in_use() */
|
||||
for (i = 0; i < MAX_NR_CONSOLES; ++i)
|
||||
- if (! VT_IS_IN_USE(i))
|
||||
+ if (!vt_in_use(i))
|
||||
break;
|
||||
+ console_unlock();
|
||||
uival = i < MAX_NR_CONSOLES ? (i+1) : -1;
|
||||
goto setint;
|
||||
|
||||
@@ -1011,12 +1021,12 @@ int vt_ioctl(struct tty_struct *tty,
|
||||
case VT_LOCKSWITCH:
|
||||
if (!capable(CAP_SYS_TTY_CONFIG))
|
||||
return -EPERM;
|
||||
- vt_dont_switch = 1;
|
||||
+ vt_dont_switch = true;
|
||||
break;
|
||||
case VT_UNLOCKSWITCH:
|
||||
if (!capable(CAP_SYS_TTY_CONFIG))
|
||||
return -EPERM;
|
||||
- vt_dont_switch = 0;
|
||||
+ vt_dont_switch = false;
|
||||
break;
|
||||
case VT_GETHIFONTMASK:
|
||||
ret = put_user(vc->vc_hi_font_mask,
|
||||
@@ -1180,14 +1190,9 @@ long vt_compat_ioctl(struct tty_struct *tty,
|
||||
{
|
||||
struct vc_data *vc = tty->driver_data;
|
||||
struct console_font_op op; /* used in multiple places here */
|
||||
- unsigned int console = vc->vc_num;
|
||||
void __user *up = compat_ptr(arg);
|
||||
int perm;
|
||||
|
||||
-
|
||||
- if (!vc_cons_allocated(console)) /* impossible? */
|
||||
- return -ENOIOCTLCMD;
|
||||
-
|
||||
/*
|
||||
* To have permissions to do most of the vt ioctls, we either have
|
||||
* to be the owner of the tty, or have CAP_SYS_TTY_CONFIG.
|
||||
diff --git a/include/linux/ceph/messenger.h b/include/linux/ceph/messenger.h
|
||||
index c4458dc6a757..76371aaae2d1 100644
|
||||
--- a/include/linux/ceph/messenger.h
|
||||
+++ b/include/linux/ceph/messenger.h
|
||||
@@ -175,9 +175,10 @@ struct ceph_msg_data {
|
||||
#endif /* CONFIG_BLOCK */
|
||||
struct ceph_bvec_iter bvec_pos;
|
||||
struct {
|
||||
- struct page **pages; /* NOT OWNER. */
|
||||
+ struct page **pages;
|
||||
size_t length; /* total # bytes */
|
||||
unsigned int alignment; /* first page */
|
||||
+ bool own_pages;
|
||||
};
|
||||
struct ceph_pagelist *pagelist;
|
||||
};
|
||||
@@ -356,8 +357,8 @@ extern void ceph_con_keepalive(struct ceph_connection *con);
|
||||
extern bool ceph_con_keepalive_expired(struct ceph_connection *con,
|
||||
unsigned long interval);
|
||||
|
||||
-extern void ceph_msg_data_add_pages(struct ceph_msg *msg, struct page **pages,
|
||||
- size_t length, size_t alignment);
|
||||
+void ceph_msg_data_add_pages(struct ceph_msg *msg, struct page **pages,
|
||||
+ size_t length, size_t alignment, bool own_pages);
|
||||
extern void ceph_msg_data_add_pagelist(struct ceph_msg *msg,
|
||||
struct ceph_pagelist *pagelist);
|
||||
#ifdef CONFIG_BLOCK
|
||||
diff --git a/include/linux/selection.h b/include/linux/selection.h
|
||||
index e2c1f96bf059..5b890ef5b59f 100644
|
||||
--- a/include/linux/selection.h
|
||||
+++ b/include/linux/selection.h
|
||||
@@ -11,8 +11,8 @@
|
||||
#include <linux/tiocl.h>
|
||||
#include <linux/vt_buffer.h>
|
||||
|
||||
-extern struct vc_data *sel_cons;
|
||||
struct tty_struct;
|
||||
+struct vc_data;
|
||||
|
||||
extern void clear_selection(void);
|
||||
extern int set_selection_user(const struct tiocl_selection __user *sel,
|
||||
@@ -24,6 +24,8 @@ extern int sel_loadlut(char __user *p);
|
||||
extern int mouse_reporting(void);
|
||||
extern void mouse_report(struct tty_struct * tty, int butt, int mrx, int mry);
|
||||
|
||||
+bool vc_is_sel(struct vc_data *vc);
|
||||
+
|
||||
extern int console_blanked;
|
||||
|
||||
extern const unsigned char color_table[];
|
||||
diff --git a/include/linux/vt_kern.h b/include/linux/vt_kern.h
|
||||
index 8dc77e40bc03..ded5c48598f3 100644
|
||||
--- a/include/linux/vt_kern.h
|
||||
+++ b/include/linux/vt_kern.h
|
||||
@@ -135,7 +135,7 @@ extern int do_unbind_con_driver(const struct consw *csw, int first, int last,
|
||||
int deflt);
|
||||
int vty_init(const struct file_operations *console_fops);
|
||||
|
||||
-extern char vt_dont_switch;
|
||||
+extern bool vt_dont_switch;
|
||||
extern int default_utf8;
|
||||
extern int global_cursor_default;
|
||||
|
||||
diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c
|
||||
index b774e2210f7d..b03087f110eb 100644
|
||||
--- a/kernel/bpf/btf.c
|
||||
+++ b/kernel/bpf/btf.c
|
||||
@@ -3460,7 +3460,7 @@ int btf_get_info_by_fd(const struct btf *btf,
|
||||
union bpf_attr __user *uattr)
|
||||
{
|
||||
struct bpf_btf_info __user *uinfo;
|
||||
- struct bpf_btf_info info = {};
|
||||
+ struct bpf_btf_info info;
|
||||
u32 info_copy, btf_copy;
|
||||
void __user *ubtf;
|
||||
u32 uinfo_len;
|
||||
@@ -3469,6 +3469,7 @@ int btf_get_info_by_fd(const struct btf *btf,
|
||||
uinfo_len = attr->info.info_len;
|
||||
|
||||
info_copy = min_t(u32, uinfo_len, sizeof(info));
|
||||
+ memset(&info, 0, sizeof(info));
|
||||
if (copy_from_user(&info, uinfo, info_copy))
|
||||
return -EFAULT;
|
||||
|
||||
diff --git a/kernel/bpf/syscall.c b/kernel/bpf/syscall.c
|
||||
index ace1cfaa24b6..14f4a76b44d5 100644
|
||||
--- a/kernel/bpf/syscall.c
|
||||
+++ b/kernel/bpf/syscall.c
|
||||
@@ -2325,7 +2325,7 @@ static int bpf_prog_get_info_by_fd(struct bpf_prog *prog,
|
||||
union bpf_attr __user *uattr)
|
||||
{
|
||||
struct bpf_prog_info __user *uinfo = u64_to_user_ptr(attr->info.info);
|
||||
- struct bpf_prog_info info = {};
|
||||
+ struct bpf_prog_info info;
|
||||
u32 info_len = attr->info.info_len;
|
||||
struct bpf_prog_stats stats;
|
||||
char __user *uinsns;
|
||||
@@ -2337,6 +2337,7 @@ static int bpf_prog_get_info_by_fd(struct bpf_prog *prog,
|
||||
return err;
|
||||
info_len = min_t(u32, sizeof(info), info_len);
|
||||
|
||||
+ memset(&info, 0, sizeof(info));
|
||||
if (copy_from_user(&info, uinfo, info_len))
|
||||
return -EFAULT;
|
||||
|
||||
@@ -2600,7 +2601,7 @@ static int bpf_map_get_info_by_fd(struct bpf_map *map,
|
||||
union bpf_attr __user *uattr)
|
||||
{
|
||||
struct bpf_map_info __user *uinfo = u64_to_user_ptr(attr->info.info);
|
||||
- struct bpf_map_info info = {};
|
||||
+ struct bpf_map_info info;
|
||||
u32 info_len = attr->info.info_len;
|
||||
int err;
|
||||
|
||||
@@ -2609,6 +2610,7 @@ static int bpf_map_get_info_by_fd(struct bpf_map *map,
|
||||
return err;
|
||||
info_len = min_t(u32, sizeof(info), info_len);
|
||||
|
||||
+ memset(&info, 0, sizeof(info));
|
||||
info.type = map->map_type;
|
||||
info.id = map->id;
|
||||
info.key_size = map->key_size;
|
||||
@@ -2836,7 +2838,7 @@ out:
|
||||
|
||||
SYSCALL_DEFINE3(bpf, int, cmd, union bpf_attr __user *, uattr, unsigned int, size)
|
||||
{
|
||||
- union bpf_attr attr = {};
|
||||
+ union bpf_attr attr;
|
||||
int err;
|
||||
|
||||
if (sysctl_unprivileged_bpf_disabled && !capable(CAP_SYS_ADMIN))
|
||||
@@ -2848,6 +2850,7 @@ SYSCALL_DEFINE3(bpf, int, cmd, union bpf_attr __user *, uattr, unsigned int, siz
|
||||
size = min_t(u32, size, sizeof(attr));
|
||||
|
||||
/* copy attributes from user space, may be less than sizeof(bpf_attr) */
|
||||
+ memset(&attr, 0, sizeof(attr));
|
||||
if (copy_from_user(&attr, uattr, size) != 0)
|
||||
return -EFAULT;
|
||||
|
||||
diff --git a/net/ceph/messenger.c b/net/ceph/messenger.c
|
||||
index e4cb3db2ee77..3d2e9f944e0f 100644
|
||||
--- a/net/ceph/messenger.c
|
||||
+++ b/net/ceph/messenger.c
|
||||
@@ -3250,12 +3250,16 @@ static struct ceph_msg_data *ceph_msg_data_add(struct ceph_msg *msg)
|
||||
|
||||
static void ceph_msg_data_destroy(struct ceph_msg_data *data)
|
||||
{
|
||||
- if (data->type == CEPH_MSG_DATA_PAGELIST)
|
||||
+ if (data->type == CEPH_MSG_DATA_PAGES && data->own_pages) {
|
||||
+ int num_pages = calc_pages_for(data->alignment, data->length);
|
||||
+ ceph_release_page_vector(data->pages, num_pages);
|
||||
+ } else if (data->type == CEPH_MSG_DATA_PAGELIST) {
|
||||
ceph_pagelist_release(data->pagelist);
|
||||
+ }
|
||||
}
|
||||
|
||||
void ceph_msg_data_add_pages(struct ceph_msg *msg, struct page **pages,
|
||||
- size_t length, size_t alignment)
|
||||
+ size_t length, size_t alignment, bool own_pages)
|
||||
{
|
||||
struct ceph_msg_data *data;
|
||||
|
||||
@@ -3267,6 +3271,7 @@ void ceph_msg_data_add_pages(struct ceph_msg *msg, struct page **pages,
|
||||
data->pages = pages;
|
||||
data->length = length;
|
||||
data->alignment = alignment & ~PAGE_MASK;
|
||||
+ data->own_pages = own_pages;
|
||||
|
||||
msg->data_length += length;
|
||||
}
|
||||
diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c
|
||||
index ba45b074a362..2352afa62d1f 100644
|
||||
--- a/net/ceph/osd_client.c
|
||||
+++ b/net/ceph/osd_client.c
|
||||
@@ -962,7 +962,7 @@ static void ceph_osdc_msg_data_add(struct ceph_msg *msg,
|
||||
BUG_ON(length > (u64) SIZE_MAX);
|
||||
if (length)
|
||||
ceph_msg_data_add_pages(msg, osd_data->pages,
|
||||
- length, osd_data->alignment);
|
||||
+ length, osd_data->alignment, false);
|
||||
} else if (osd_data->type == CEPH_OSD_DATA_TYPE_PAGELIST) {
|
||||
BUG_ON(!length);
|
||||
ceph_msg_data_add_pagelist(msg, osd_data->pagelist);
|
||||
@@ -4436,9 +4436,7 @@ static void handle_watch_notify(struct ceph_osd_client *osdc,
|
||||
CEPH_MSG_DATA_PAGES);
|
||||
*lreq->preply_pages = data->pages;
|
||||
*lreq->preply_len = data->length;
|
||||
- } else {
|
||||
- ceph_release_page_vector(data->pages,
|
||||
- calc_pages_for(0, data->length));
|
||||
+ data->own_pages = false;
|
||||
}
|
||||
}
|
||||
lreq->notify_finish_error = return_code;
|
||||
@@ -5500,9 +5498,6 @@ out_unlock_osdc:
|
||||
return m;
|
||||
}
|
||||
|
||||
-/*
|
||||
- * TODO: switch to a msg-owned pagelist
|
||||
- */
|
||||
static struct ceph_msg *alloc_msg_with_page_vector(struct ceph_msg_header *hdr)
|
||||
{
|
||||
struct ceph_msg *m;
|
||||
@@ -5516,7 +5511,6 @@ static struct ceph_msg *alloc_msg_with_page_vector(struct ceph_msg_header *hdr)
|
||||
|
||||
if (data_len) {
|
||||
struct page **pages;
|
||||
- struct ceph_osd_data osd_data;
|
||||
|
||||
pages = ceph_alloc_page_vector(calc_pages_for(0, data_len),
|
||||
GFP_NOIO);
|
||||
@@ -5525,9 +5519,7 @@ static struct ceph_msg *alloc_msg_with_page_vector(struct ceph_msg_header *hdr)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
- ceph_osd_data_pages_init(&osd_data, pages, data_len, 0, false,
|
||||
- false);
|
||||
- ceph_osdc_msg_data_add(m, &osd_data);
|
||||
+ ceph_msg_data_add_pages(m, pages, data_len, 0, true);
|
||||
}
|
||||
|
||||
return m;
|
||||
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c
|
||||
index c8fc29f0efcf..41da41cb5c40 100644
|
||||
--- a/net/mac80211/tx.c
|
||||
+++ b/net/mac80211/tx.c
|
||||
@@ -3596,8 +3596,26 @@ begin:
|
||||
tx.skb = skb;
|
||||
tx.sdata = vif_to_sdata(info->control.vif);
|
||||
|
||||
- if (txq->sta)
|
||||
+ if (txq->sta) {
|
||||
tx.sta = container_of(txq->sta, struct sta_info, sta);
|
||||
+ /*
|
||||
+ * Drop unicast frames to unauthorised stations unless they are
|
||||
+ * EAPOL frames from the local station.
|
||||
+ */
|
||||
+ if (unlikely(ieee80211_is_data(hdr->frame_control) &&
|
||||
+ !ieee80211_vif_is_mesh(&tx.sdata->vif) &&
|
||||
+ tx.sdata->vif.type != NL80211_IFTYPE_OCB &&
|
||||
+ !is_multicast_ether_addr(hdr->addr1) &&
|
||||
+ !test_sta_flag(tx.sta, WLAN_STA_AUTHORIZED) &&
|
||||
+ (!(info->control.flags &
|
||||
+ IEEE80211_TX_CTRL_PORT_CTRL_PROTO) ||
|
||||
+ !ether_addr_equal(tx.sdata->vif.addr,
|
||||
+ hdr->addr2)))) {
|
||||
+ I802_DEBUG_INC(local->tx_handlers_drop_unauth_port);
|
||||
+ ieee80211_free_txskb(&local->hw, skb);
|
||||
+ goto begin;
|
||||
+ }
|
||||
+ }
|
||||
|
||||
/*
|
||||
* The key can be removed while the packet was queued, so need to call
|
||||
diff --git a/tools/perf/util/map.c b/tools/perf/util/map.c
|
||||
index eec9b282c047..4b07b1cc22dc 100644
|
||||
--- a/tools/perf/util/map.c
|
||||
+++ b/tools/perf/util/map.c
|
||||
@@ -90,7 +90,7 @@ static inline bool replace_android_lib(const char *filename, char *newfilename)
|
||||
return true;
|
||||
}
|
||||
|
||||
- if (!strncmp(filename, "/system/lib/", 11)) {
|
||||
+ if (!strncmp(filename, "/system/lib/", 12)) {
|
||||
char *ndk, *app;
|
||||
const char *arch;
|
||||
size_t ndk_length;
|
||||
@ -21,6 +21,6 @@ index 7534683db..1d3d4d7db 100644
|
||||
|
||||
-obj-$(CONFIG_RTL8812AU) += rtl8812au/
|
||||
-obj-$(CONFIG_RTL8188EU) += rtl8188eu/
|
||||
obj-$(CONFIG_RTL8189ES) += rtl8189es/
|
||||
obj-$(CONFIG_RTL8189FS) += rtl8189fs/
|
||||
obj-$(CONFIG_88XXAU) += rtl8812au/
|
||||
obj-$(CONFIG_RTL8812AU) += rtl8812au/
|
||||
obj-$(CONFIG_RTL8821CU) += rtl8811cu/
|
||||
|
||||
4354
patch/kernel/odroidxu4-legacy/patch-4.14.174-175.patch
Normal file
4354
patch/kernel/odroidxu4-legacy/patch-4.14.174-175.patch
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user