Merge android11-5.4.197+ (3970bc6
) into msm-5.4
* refs/heads/tmp-3970bc6: UPSTREAM: Revert "net: af_key: add check for pfkey_broadcast in function pfkey_process" FROMGIT: arm64: fix oops in concurrently setting insn_emulation sysctls ANDROID: abi_gki_aarch64_qcom: Add vmemdup_user to qcom symbol list ANDROID: GKI: update Sony KMI symbol list UPSTREAM: mm: fix misplaced unlock_page in do_wp_page() BACKPORT: mm: do_wp_page() simplification UPSTREAM: mm/ksm: Remove reuse_ksm_page() BACKPORT: ALSA: pcm: Fix races among concurrent prealloc proc writes BACKPORT: ALSA: pcm: Fix races among concurrent prepare and hw_params/hw_free calls BACKPORT: ALSA: pcm: Fix races among concurrent read/write and buffer changes ANDROID: Fix up abi issue with struct snd_pcm_runtime BACKPORT: ALSA: pcm: Fix races among concurrent hw_params and hw_free calls BACKPORT: nfc: nfcmrvl: main: reorder destructive operations in nfcmrvl_nci_unregister_dev to avoid bugs Linux 5.4.197 bpf: Enlarge offset check value to INT_MAX in bpf_skb_{load,store}_bytes NFSD: Fix possible sleep during nfsd4_release_lockowner() NFS: Memory allocation failures are not server fatal errors docs: submitting-patches: Fix crossref to 'The canonical patch format' tpm: ibmvtpm: Correct the return value in tpm_ibmvtpm_probe() tpm: Fix buffer access in tpm2_get_tpm_pt() HID: multitouch: Add support for Google Whiskers Touchpad raid5: introduce MD_BROKEN dm verity: set DM_TARGET_IMMUTABLE feature flag dm stats: add cond_resched when looping over entries dm crypt: make printing of the key constant-time dm integrity: fix error code in dm_integrity_ctr() zsmalloc: fix races between asynchronous zspage free and page migration crypto: ecrdsa - Fix incorrect use of vli_cmp netfilter: conntrack: re-fetch conntrack after insertion exec: Force single empty string when argv is empty drm/i915: Fix -Wstringop-overflow warning in call to intel_read_wm_latency() cfg80211: set custom regdomain after wiphy registration assoc_array: Fix BUG_ON during garbage collect drivers: i2c: thunderx: Allow driver to work with ACPI defined TWSI controllers i2c: ismt: Provide a DMA buffer for Interrupt Cause Logging net: ftgmac100: Disable hardware checksum on AST2600 net: af_key: check encryption module availability consistency pinctrl: sunxi: fix f1c100s uart2 function ACPI: sysfs: Fix BERT error region memory mapping ACPI: sysfs: Make sparse happy about address space in use media: vim2m: initialize the media device earlier media: vim2m: Register video device after setting up internals secure_seq: use the 64 bits of the siphash for port offset calculation tcp: change source port randomizarion at connect() time Input: goodix - fix spurious key release events staging: rtl8723bs: prevent ->Ssid overflow in rtw_wx_set_scan() x86/pci/xen: Disable PCI/MSI[-X] masking for XEN_HVM guests lockdown: also lock down previous kgdb use Linux 5.4.196 afs: Fix afs_getattr() to refetch file status if callback break occurred i2c: mt7621: fix missing clk_disable_unprepare() on error in mtk_i2c_probe() x86/xen: Mark cpu_bringup_and_idle() as dead_end_function x86/xen: fix booting 32-bit pv guest Reinstate some of "swiotlb: rework "fix info leak with DMA_FROM_DEVICE"" ARM: dts: imx7: Use audio_mclk_post_div instead audio_mclk_root_clk firmware_loader: use kernel credentials when reading firmware net: stmmac: disable Split Header (SPH) for Intel platforms block: return ELEVATOR_DISCARD_MERGE if possible Input: ili210x - fix reset timing net: atlantic: verify hw_head_ lies within TX buffer ring net: stmmac: fix missing pci_disable_device() on error in stmmac_pci_probe() ethernet: tulip: fix missing pci_disable_device() on error in tulip_init_one() selftests: add ping test with ping_group_range tuned mac80211: fix rx reordering with non explicit / psmp ack policy scsi: qla2xxx: Fix missed DMA unmap for aborted commands perf bench numa: Address compiler error on s390 gpio: mvebu/pwm: Refuse requests with inverted polarity gpio: gpio-vf610: do not touch other bits when set the target bit net: bridge: Clear offload_fwd_mark when passing frame up bridge interface. igb: skip phy status check where unavailable ARM: 9197/1: spectre-bhb: fix loop8 sequence for Thumb2 ARM: 9196/1: spectre-bhb: enable for Cortex-A15 net: af_key: add check for pfkey_broadcast in function pfkey_process net/mlx5e: Properly block LRO when XDP is enabled NFC: nci: fix sleep in atomic context bugs caused by nci_skb_alloc net/qla3xxx: Fix a test in ql_reset_work() clk: at91: generated: consider range when calculating best rate ice: fix possible under reporting of ethtool Tx and Rx statistics net: vmxnet3: fix possible NULL pointer dereference in vmxnet3_rq_cleanup() net: vmxnet3: fix possible use-after-free bugs in vmxnet3_rq_alloc_rx_buf() net/sched: act_pedit: sanitize shift argument before usage net: macb: Increment rx bd head after allocating skb and buffer ARM: dts: aspeed-g6: fix SPI1/SPI2 quad pin group ARM: dts: aspeed-g6: remove FWQSPID group in pinctrl dtsi dma-buf: fix use of DMA_BUF_SET_NAME_{A,B} in userspace drm/dp/mst: fix a possible memory leak in fetch_monitor_name() crypto: qcom-rng - fix infinite loop on requests not multiple of WORD_SZ KVM: x86/mmu: Update number of zapped pages even if page list is stable PCI/PM: Avoid putting Elo i2 PCIe Ports in D3cold Fix double fget() in vhost_net_set_backend() perf: Fix sys_perf_event_open() race against self ALSA: wavefront: Proper check of get_user() error SUNRPC: Ensure we flush any closed sockets before xs_xprt_free() SUNRPC: Don't call connect() more than once on a TCP socket SUNRPC: Prevent immediate close+reconnect SUNRPC: Clean up scheduling of autoclose mmc: core: Default to generic_cmd6_time as timeout in __mmc_switch() mmc: block: Use generic_cmd6_time when modifying INAND_CMD38_ARG_EXT_CSD mmc: core: Specify timeouts for BKOPS and CACHE_FLUSH for eMMC nilfs2: fix lockdep warnings during disk space reclamation nilfs2: fix lockdep warnings in page operations for btree nodes ARM: 9191/1: arm/stacktrace, kasan: Silence KASAN warnings in unwind_frame() platform/chrome: cros_ec_debugfs: detach log reader wq from devm drbd: remove usage of list iterator variable after loop MIPS: lantiq: check the return value of kzalloc() rtc: mc146818-lib: Fix the AltCentury for AMD platforms nvme-multipath: fix hang when disk goes live over reconnect ALSA: hda/realtek: Enable headset mic on Lenovo P360 crypto: x86/chacha20 - Avoid spurious jumps to other functions crypto: stm32 - fix reference leak in stm32_crc_remove Input: stmfts - fix reference leak in stmfts_input_open Input: add bounds checking to input_set_capability() um: Cleanup syscall_handler_t definition/cast, fix warning rtc: fix use-after-free on device removal x86/xen: Make the secondary CPU idle tasks reliable x86/xen: Make the boot CPU idle task reliable floppy: use a statically allocated error counter ANDROID: fix up abi issue with struct snd_pcm_runtime Linux 5.4.195 tty/serial: digicolor: fix possible null-ptr-deref in digicolor_uart_probe() ping: fix address binding wrt vrf arm[64]/memremap: don't abuse pfn_valid() to ensure presence of linear map net: phy: Fix race condition on link status change MIPS: fix build with gcc-12 drm/vmwgfx: Initialize drm_mode_fb_cmd2 cgroup/cpuset: Remove cpus_allowed/mems_allowed setup in cpuset_init_smp() i40e: i40e_main: fix a missing check on list iterator drm/nouveau/tegra: Stop using iommu_present() serial: 8250_mtk: Fix register address for XON/XOFF character serial: 8250_mtk: Fix UART_EFR register address slimbus: qcom: Fix IRQ check in qcom_slim_probe USB: serial: option: add Fibocom MA510 modem USB: serial: option: add Fibocom L610 modem USB: serial: qcserial: add support for Sierra Wireless EM7590 USB: serial: pl2303: add device id for HP LM930 Display usb: typec: tcpci: Don't skip cleanup in .remove() on error usb: cdc-wdm: fix reading stuck on device close tty: n_gsm: fix mux activation issues in gsm_config() tcp: resalt the secret every 10 seconds net: emaclite: Don't advertise 1000BASE-T and do auto negotiation s390: disable -Warray-bounds ASoC: ops: Validate input values in snd_soc_put_volsw_range() ASoC: max98090: Generate notifications on changes for custom control ASoC: max98090: Reject invalid values in custom control put() hwmon: (f71882fg) Fix negative temperature gfs2: Fix filesystem block deallocation for short writes net: sfc: ef10: fix memory leak in efx_ef10_mtd_probe() net/smc: non blocking recvmsg() return -EAGAIN when no data and signal_pending net/sched: act_pedit: really ensure the skb is writable s390/lcs: fix variable dereferenced before check s390/ctcm: fix potential memory leak s390/ctcm: fix variable dereferenced before check hwmon: (ltq-cputemp) restrict it to SOC_XWAY dim: initialize all struct fields mac80211_hwsim: call ieee80211_tx_prepare_skb under RCU protection netlink: do not reset transport header in netlink_recvmsg() drm/nouveau: Fix a potential theorical leak in nouveau_get_backlight_name() ipv4: drop dst in multicast routing path net: Fix features skip in for_each_netdev_feature() mac80211: Reset MBSSID parameters upon connection hwmon: (tmp401) Add OF device ID table batman-adv: Don't skb_split skbuffs with frag_list Linux 5.4.194 mm: userfaultfd: fix missing cache flush in mcopy_atomic_pte() and __mcopy_atomic() mm: hugetlb: fix missing cache flush in copy_huge_page_from_user() mm: fix missing cache flush for all tail pages of compound page Bluetooth: Fix the creation of hdev->name KVM: x86/svm: Account for family 17h event renumberings in amd_pmc_perf_hw_id x86: kprobes: Prohibit probing on instruction which has emulate prefix x86: xen: insn: Decode Xen and KVM emulate-prefix signature x86: xen: kvm: Gather the definition of emulate prefixes x86/asm: Allow to pass macros to __ASM_FORM() KVM: x86/pmu: Refactoring find_arch_event() to pmc_perf_hw_id() arm: remove CONFIG_ARCH_HAS_HOLES_MEMORYMODEL can: grcan: only use the NAPI poll budget for RX can: grcan: grcan_probe(): fix broken system id check for errata workaround needs nfp: bpf: silence bitwise vs. logical OR warning drm/i915: Cast remain to unsigned long in eb_relocate_vma drm/amd/display/dc/gpio/gpio_service: Pass around correct dce_{version, environment} types block: drbd: drbd_nl: Make conversion to 'enum drbd_ret_code' explicit MIPS: Use address-of operator on section symbols ANDROID: GKI: update the abi .xml file Revert "tcp: ensure to use the most recently sent skb when filling the rate sample" Linux 5.4.193 mmc: rtsx: add 74 Clocks in power on flow PCI: aardvark: Fix reading MSI interrupt number PCI: aardvark: Clear all MSIs at setup dm: interlock pending dm_io and dm_wait_for_bios_completion dm: fix mempool NULL pointer race when completing IO tcp: make sure treq->af_specific is initialized ALSA: pcm: Fix potential AB/BA lock with buffer_mutex and mmap_lock ALSA: pcm: Fix races among concurrent prealloc proc writes ALSA: pcm: Fix races among concurrent prepare and hw_params/hw_free calls ALSA: pcm: Fix races among concurrent read/write and buffer changes ALSA: pcm: Fix races among concurrent hw_params and hw_free calls mm: fix unexpected zeroed page mapping with zram swap block-map: add __GFP_ZERO flag for alloc_page in function bio_copy_kern net: ipv6: ensure we call ipv6_mc_down() at most once KVM: LAPIC: Enable timer posted-interrupt only when mwait/hlt is advertised x86/kvm: Preserve BSP MSR_KVM_POLL_CONTROL across suspend/resume kvm: x86/cpuid: Only provide CPUID leaf 0xA if host has architectural PMU NFSv4: Don't invalidate inode attributes on delegation return drm/amdkfd: Use drm_priv to pass VM from KFD to amdgpu net: igmp: respect RCU rules in ip_mc_source() and ip_mc_msfilter() btrfs: always log symlinks in full mode smsc911x: allow using IRQ0 bnxt_en: Fix possible bnxt_open() failure caused by wrong RFS flag selftests: mirror_gre_bridge_1q: Avoid changing PVID while interface is operational net: emaclite: Add error handling for of_address_to_resource() net: stmmac: dwmac-sun8i: add missing of_node_put() in sun8i_dwmac_register_mdio_mux() net: ethernet: mediatek: add missing of_node_put() in mtk_sgmii_init() RDMA/siw: Fix a condition race issue in MPA request processing ASoC: dmaengine: Restore NULL prepare_slave_config() callback hwmon: (adt7470) Fix warning on module removal NFC: netlink: fix sleep in atomic bug when firmware download timeout nfc: nfcmrvl: main: reorder destructive operations in nfcmrvl_nci_unregister_dev to avoid bugs nfc: replace improper check device_is_registered() in netlink related functions can: grcan: use ofdev->dev when allocating DMA memory can: grcan: grcan_close(): fix deadlock s390/dasd: Fix read inconsistency for ESE DASD devices s390/dasd: Fix read for ESE with blksize < 4k s390/dasd: prevent double format of tracks for ESE devices s390/dasd: fix data corruption for ESE devices ASoC: meson: Fix event generation for G12A tohdmi mux ASoC: wm8958: Fix change notifications for DSP controls ASoC: da7219: Fix change notifications for tone generator frequency genirq: Synchronize interrupt thread startup ACPICA: Always create namespace nodes using acpi_ns_create_node() firewire: core: extend card->lock in fw_core_handle_bus_reset firewire: remove check of list iterator against head past the loop body firewire: fix potential uaf in outbound_phy_packet_callback() Revert "SUNRPC: attempt AF_LOCAL connect on setup" gpiolib: of: fix bounds check for 'gpio-reserved-ranges' ALSA: fireworks: fix wrong return count shorter than expected by 4 bytes parisc: Merge model and model name into one line in /proc/cpuinfo MIPS: Fix CP0 counter erratum detection for R4k CPUs Linux 5.4.192 mm, hugetlb: allow for "high" userspace addresses hugetlbfs: get unmapped area below TASK_UNMAPPED_BASE for hugetlbfs tty: n_gsm: fix incorrect UA handling tty: n_gsm: fix wrong command frame length field encoding tty: n_gsm: fix wrong command retry handling tty: n_gsm: fix missing explicit ldisc flush tty: n_gsm: fix insufficient txframe size netfilter: nft_socket: only do sk lookups when indev is available tty: n_gsm: fix malformed counter for out of frame data tty: n_gsm: fix wrong signal octet encoding in convergence layer type 2 x86/cpu: Load microcode during restore_processor_state() net: ethernet: stmmac: fix write to sgmii_adapter_base drivers: net: hippi: Fix deadlock in rr_close() cifs: destage any unwritten data to the server before calling copychunk_write x86: __memcpy_flushcache: fix wrong alignment if size > 2^32 ip6_gre: Avoid updating tunnel->tun_hlen in __gre6_xmit() ASoC: wm8731: Disable the regulator when probing fails tcp: fix F-RTO may not work correctly when receiving DSACK ixgbe: ensure IPsec VF<->PF compatibility bnx2x: fix napi API usage sequence tls: Skip tls_append_frag on zero copy size drm/amd/display: Fix memory leak in dcn21_clock_source_create net: dsa: lantiq_gswip: Don't set GSWIP_MII_CFG_RMII_CLK net: bcmgenet: hide status block before TX timestamping clk: sunxi: sun9i-mmc: check return value after calling platform_get_resource() bus: sunxi-rsb: Fix the return value of sunxi_rsb_device_create() tcp: fix potential xmit stalls caused by TCP_NOTSENT_LOWAT ip_gre: Make o_seqno start from 0 in native mode net/smc: sync err code when tcp connection was refused net: hns3: add validity check for message data length cpufreq: fix memory leak in sun50i_cpufreq_nvmem_probe pinctrl: pistachio: fix use of irq_of_parse_and_map() arm64: dts: imx8mn-ddr4-evk: Describe the 32.768 kHz PMIC clock ARM: dts: imx6ull-colibri: fix vqmmc regulator sctp: check asoc strreset_chunk in sctp_generate_reconf_event tcp: ensure to use the most recently sent skb when filling the rate sample tcp: md5: incorrect tcp_header_len for incoming connections bpf, lwt: Fix crash when using bpf_skb_set_tunnel_key() from bpf_xmit lwt hook mtd: rawnand: Fix return value check of wait_for_completion_timeout ipvs: correctly print the memory size of ip_vs_conn_tab ARM: dts: logicpd-som-lv: Fix wrong pinmuxing on OMAP35 ARM: dts: am3517-evm: Fix misc pinmuxing ARM: dts: Fix mmc order for omap3-gta04 phy: ti: Add missing pm_runtime_disable() in serdes_am654_probe phy: mapphone-mdm6600: Fix PM error handling in phy_mdm6600_probe ARM: dts: at91: Map MCLK for wm8731 on at91sam9g20ek phy: ti: omap-usb2: Fix error handling in omap_usb2_enable_clocks ARM: OMAP2+: Fix refcount leak in omap_gic_of_init phy: samsung: exynos5250-sata: fix missing device put in probe error paths phy: samsung: Fix missing of_node_put() in exynos_sata_phy_probe ARM: dts: imx6qdl-apalis: Fix sgtl5000 detection issue USB: Fix xhci event ring dequeue pointer ERDP update issue mtd: rawnand: fix ecc parameters for mt7622 arm64: dts: meson: remove CPU opps below 1GHz for SM1 boards arm64: dts: meson: remove CPU opps below 1GHz for G12B boards video: fbdev: udlfb: properly check endpoint type hex2bin: fix access beyond string end hex2bin: make the function hex_to_bin constant-time arch_topology: Do not set llc_sibling if llc_id is invalid serial: 8250: Correct the clock for EndRun PTP/1588 PCIe device serial: 8250: Also set sticky MCR bits in console restoration serial: imx: fix overrun interrupts in DMA mode usb: dwc3: gadget: Return proper request status usb: dwc3: core: Fix tx/rx threshold settings usb: gadget: configfs: clear deactivation flag in configfs_composite_unbind() usb: gadget: uvc: Fix crash when encoding data for usb request usb: typec: ucsi: Fix role swapping usb: misc: fix improper handling of refcount in uss720_probe() iio: magnetometer: ak8975: Fix the error handling in ak8975_power_on() iio: dac: ad5446: Fix read_raw not returning set value iio: dac: ad5592r: Fix the missing return value. xhci: increase usb U3 -> U0 link resume timeout from 100ms to 500ms xhci: stop polling roothubs after shutdown USB: serial: option: add Telit 0x1057, 0x1058, 0x1075 compositions USB: serial: option: add support for Cinterion MV32-WA/MV32-WB USB: serial: cp210x: add PIDs for Kamstrup USB Meter Reader USB: serial: whiteheat: fix heap overflow in WHITEHEAT_GET_DTR_RTS USB: quirks: add STRING quirk for VCOM device USB: quirks: add a Realtek card reader usb: mtu3: fix USB 3.0 dual-role-switch from device to host lightnvm: disable the subsystem hamradio: remove needs_free_netdev to avoid UAF hamradio: defer 6pack kfree after unregister_netdev floppy: disable FDRAWCMD by default Conflicts: drivers/usb/dwc3/gadget.c include/linux/dma-mapping.h include/linux/stmmac.h mm/memory.c Change-Id: I3bf49e11ae4aeaf1db353efbdfee950cd12de8cf Signed-off-by: Srinivasarao Pathipati <quic_c_spathi@quicinc.com>
This commit is contained in:
commit
630e7df8c5
@ -156,13 +156,3 @@ accesses to DMA buffers in both privileged "supervisor" and unprivileged
|
|||||||
subsystem that the buffer is fully accessible at the elevated privilege
|
subsystem that the buffer is fully accessible at the elevated privilege
|
||||||
level (and ideally inaccessible or at least read-only at the
|
level (and ideally inaccessible or at least read-only at the
|
||||||
lesser-privileged levels).
|
lesser-privileged levels).
|
||||||
|
|
||||||
DMA_ATTR_PRIVILEGED
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
Some advanced peripherals such as remote processors and GPUs perform
|
|
||||||
accesses to DMA buffers in both privileged "supervisor" and unprivileged
|
|
||||||
"user" modes. This attribute is used to indicate to the DMA-mapping
|
|
||||||
subsystem that the buffer is fully accessible at the elevated privilege
|
|
||||||
level (and ideally inaccessible or at least read-only at the
|
|
||||||
lesser-privileged levels).
|
|
||||||
|
@ -133,7 +133,7 @@ as you intend it to.
|
|||||||
|
|
||||||
The maintainer will thank you if you write your patch description in a
|
The maintainer will thank you if you write your patch description in a
|
||||||
form which can be easily pulled into Linux's source code management
|
form which can be easily pulled into Linux's source code management
|
||||||
system, ``git``, as a "commit log". See :ref:`explicit_in_reply_to`.
|
system, ``git``, as a "commit log". See :ref:`the_canonical_patch_format`.
|
||||||
|
|
||||||
Solve only one problem per patch. If your description starts to get
|
Solve only one problem per patch. If your description starts to get
|
||||||
long, that's a sign that you probably need to split up your patch.
|
long, that's a sign that you probably need to split up your patch.
|
||||||
|
@ -52,8 +52,7 @@ wrapper :c:func:`free_area_init`. Yet, the mappings array is not
|
|||||||
usable until the call to :c:func:`memblock_free_all` that hands all
|
usable until the call to :c:func:`memblock_free_all` that hands all
|
||||||
the memory to the page allocator.
|
the memory to the page allocator.
|
||||||
|
|
||||||
If an architecture enables `CONFIG_ARCH_HAS_HOLES_MEMORYMODEL` option,
|
An architecture may free parts of the `mem_map` array that do not cover the
|
||||||
it may free parts of the `mem_map` array that do not cover the
|
|
||||||
actual physical pages. In such case, the architecture specific
|
actual physical pages. In such case, the architecture specific
|
||||||
:c:func:`pfn_valid` implementation should take the holes in the
|
:c:func:`pfn_valid` implementation should take the holes in the
|
||||||
`mem_map` into account.
|
`mem_map` into account.
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
VERSION = 5
|
VERSION = 5
|
||||||
PATCHLEVEL = 4
|
PATCHLEVEL = 4
|
||||||
SUBLEVEL = 191
|
SUBLEVEL = 197
|
||||||
EXTRAVERSION =
|
EXTRAVERSION =
|
||||||
NAME = Kleptomaniac Octopus
|
NAME = Kleptomaniac Octopus
|
||||||
|
|
||||||
|
@ -1 +1 @@
|
|||||||
LTS_5.4.191_375c2e2cdbdb
|
LTS_5.4.197_3970bc62738d
|
||||||
|
166481
android/abi_gki_aarch64.xml
166481
android/abi_gki_aarch64.xml
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -2870,6 +2870,7 @@
|
|||||||
vmalloc_to_page
|
vmalloc_to_page
|
||||||
vmalloc_user
|
vmalloc_user
|
||||||
vmap
|
vmap
|
||||||
|
vmemdup_user
|
||||||
vmemmap
|
vmemmap
|
||||||
vmf_insert_mixed
|
vmf_insert_mixed
|
||||||
vmf_insert_pfn
|
vmf_insert_pfn
|
||||||
|
@ -158,3 +158,6 @@
|
|||||||
|
|
||||||
# required by ledtrig_transient.ko
|
# required by ledtrig_transient.ko
|
||||||
led_set_brightness_nosleep
|
led_set_brightness_nosleep
|
||||||
|
|
||||||
|
# required by sec_touchscreen.ko
|
||||||
|
input_set_timestamp
|
||||||
|
@ -27,7 +27,7 @@ config ARM
|
|||||||
select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
|
select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
|
||||||
select ARCH_HAVE_CUSTOM_GPIO_H
|
select ARCH_HAVE_CUSTOM_GPIO_H
|
||||||
select ARCH_HAS_GCOV_PROFILE_ALL
|
select ARCH_HAS_GCOV_PROFILE_ALL
|
||||||
select ARCH_KEEP_MEMBLOCK if HAVE_ARCH_PFN_VALID || KEXEC
|
select ARCH_KEEP_MEMBLOCK
|
||||||
select ARCH_MIGHT_HAVE_PC_PARPORT
|
select ARCH_MIGHT_HAVE_PC_PARPORT
|
||||||
select ARCH_NO_SG_CHAIN if !ARM_HAS_SG_CHAIN
|
select ARCH_NO_SG_CHAIN if !ARM_HAS_SG_CHAIN
|
||||||
select ARCH_OPTIONAL_KERNEL_RWX if ARCH_HAS_STRICT_KERNEL_RWX
|
select ARCH_OPTIONAL_KERNEL_RWX if ARCH_HAS_STRICT_KERNEL_RWX
|
||||||
@ -549,7 +549,6 @@ config ARCH_S3C24XX
|
|||||||
config ARCH_OMAP1
|
config ARCH_OMAP1
|
||||||
bool "TI OMAP1"
|
bool "TI OMAP1"
|
||||||
depends on MMU
|
depends on MMU
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ARCH_OMAP
|
select ARCH_OMAP
|
||||||
select CLKDEV_LOOKUP
|
select CLKDEV_LOOKUP
|
||||||
select CLKSRC_MMIO
|
select CLKSRC_MMIO
|
||||||
@ -1547,9 +1546,6 @@ config OABI_COMPAT
|
|||||||
UNPREDICTABLE (in fact it can be predicted that it won't work
|
UNPREDICTABLE (in fact it can be predicted that it won't work
|
||||||
at all). If in doubt say N.
|
at all). If in doubt say N.
|
||||||
|
|
||||||
config ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
bool
|
|
||||||
|
|
||||||
config ARCH_SPARSEMEM_ENABLE
|
config ARCH_SPARSEMEM_ENABLE
|
||||||
bool
|
bool
|
||||||
|
|
||||||
@ -1557,7 +1553,7 @@ config ARCH_SPARSEMEM_DEFAULT
|
|||||||
def_bool ARCH_SPARSEMEM_ENABLE
|
def_bool ARCH_SPARSEMEM_ENABLE
|
||||||
|
|
||||||
config HAVE_ARCH_PFN_VALID
|
config HAVE_ARCH_PFN_VALID
|
||||||
def_bool ARCH_HAS_HOLES_MEMORYMODEL || !SPARSEMEM
|
def_bool y
|
||||||
|
|
||||||
config HIGHMEM
|
config HIGHMEM
|
||||||
bool "High Memory Support"
|
bool "High Memory Support"
|
||||||
|
@ -160,6 +160,8 @@
|
|||||||
|
|
||||||
/* HS USB Host PHY on PORT 1 */
|
/* HS USB Host PHY on PORT 1 */
|
||||||
hsusb1_phy: hsusb1_phy {
|
hsusb1_phy: hsusb1_phy {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&hsusb1_rst_pins>;
|
||||||
compatible = "usb-nop-xceiv";
|
compatible = "usb-nop-xceiv";
|
||||||
reset-gpios = <&gpio2 25 GPIO_ACTIVE_LOW>; /* gpio_57 */
|
reset-gpios = <&gpio2 25 GPIO_ACTIVE_LOW>; /* gpio_57 */
|
||||||
#phy-cells = <0>;
|
#phy-cells = <0>;
|
||||||
@ -167,7 +169,9 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&davinci_emac {
|
&davinci_emac {
|
||||||
status = "okay";
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <ðernet_pins>;
|
||||||
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
&davinci_mdio {
|
&davinci_mdio {
|
||||||
@ -192,6 +196,8 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&i2c2 {
|
&i2c2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&i2c2_pins>;
|
||||||
clock-frequency = <400000>;
|
clock-frequency = <400000>;
|
||||||
/* User DIP swithes [1:8] / User LEDS [1:2] */
|
/* User DIP swithes [1:8] / User LEDS [1:2] */
|
||||||
tca6416: gpio@21 {
|
tca6416: gpio@21 {
|
||||||
@ -204,6 +210,8 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&i2c3 {
|
&i2c3 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&i2c3_pins>;
|
||||||
clock-frequency = <400000>;
|
clock-frequency = <400000>;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -222,6 +230,8 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&usbhshost {
|
&usbhshost {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&hsusb1_pins>;
|
||||||
port1-mode = "ehci-phy";
|
port1-mode = "ehci-phy";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -230,8 +240,35 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&omap3_pmx_core {
|
&omap3_pmx_core {
|
||||||
pinctrl-names = "default";
|
|
||||||
pinctrl-0 = <&hsusb1_rst_pins>;
|
ethernet_pins: pinmux_ethernet_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3_CORE1_IOPAD(0x21fe, PIN_INPUT | MUX_MODE0) /* rmii_mdio_data */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2200, MUX_MODE0) /* rmii_mdio_clk */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2202, PIN_INPUT_PULLDOWN | MUX_MODE0) /* rmii_rxd0 */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2204, PIN_INPUT_PULLDOWN | MUX_MODE0) /* rmii_rxd1 */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2206, PIN_INPUT_PULLDOWN | MUX_MODE0) /* rmii_crs_dv */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2208, PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* rmii_rxer */
|
||||||
|
OMAP3_CORE1_IOPAD(0x220a, PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* rmii_txd0 */
|
||||||
|
OMAP3_CORE1_IOPAD(0x220c, PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* rmii_txd1 */
|
||||||
|
OMAP3_CORE1_IOPAD(0x220e, PIN_OUTPUT_PULLDOWN |MUX_MODE0) /* rmii_txen */
|
||||||
|
OMAP3_CORE1_IOPAD(0x2210, PIN_INPUT_PULLDOWN | MUX_MODE0) /* rmii_50mhz_clk */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
|
i2c2_pins: pinmux_i2c2_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3_CORE1_IOPAD(0x21be, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c2_scl */
|
||||||
|
OMAP3_CORE1_IOPAD(0x21c0, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c2_sda */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
|
i2c3_pins: pinmux_i2c3_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3_CORE1_IOPAD(0x21c2, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c3_scl */
|
||||||
|
OMAP3_CORE1_IOPAD(0x21c4, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c3_sda */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
leds_pins: pinmux_leds_pins {
|
leds_pins: pinmux_leds_pins {
|
||||||
pinctrl-single,pins = <
|
pinctrl-single,pins = <
|
||||||
@ -299,8 +336,6 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&omap3_pmx_core2 {
|
&omap3_pmx_core2 {
|
||||||
pinctrl-names = "default";
|
|
||||||
pinctrl-0 = <&hsusb1_pins>;
|
|
||||||
|
|
||||||
hsusb1_pins: pinmux_hsusb1_pins {
|
hsusb1_pins: pinmux_hsusb1_pins {
|
||||||
pinctrl-single,pins = <
|
pinctrl-single,pins = <
|
||||||
|
@ -69,6 +69,8 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
&i2c1 {
|
&i2c1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&i2c1_pins>;
|
||||||
clock-frequency = <400000>;
|
clock-frequency = <400000>;
|
||||||
|
|
||||||
s35390a: s35390a@30 {
|
s35390a: s35390a@30 {
|
||||||
@ -179,6 +181,13 @@
|
|||||||
|
|
||||||
&omap3_pmx_core {
|
&omap3_pmx_core {
|
||||||
|
|
||||||
|
i2c1_pins: pinmux_i2c1_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3_CORE1_IOPAD(0x21ba, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_scl */
|
||||||
|
OMAP3_CORE1_IOPAD(0x21bc, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_sda */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
wl12xx_buffer_pins: pinmux_wl12xx_buffer_pins {
|
wl12xx_buffer_pins: pinmux_wl12xx_buffer_pins {
|
||||||
pinctrl-single,pins = <
|
pinctrl-single,pins = <
|
||||||
OMAP3_CORE1_IOPAD(0x2156, PIN_OUTPUT | MUX_MODE4) /* mmc1_dat7.gpio_129 */
|
OMAP3_CORE1_IOPAD(0x2156, PIN_OUTPUT | MUX_MODE4) /* mmc1_dat7.gpio_129 */
|
||||||
|
@ -117,11 +117,6 @@
|
|||||||
groups = "FWSPID";
|
groups = "FWSPID";
|
||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_fwqspid_default: fwqspid_default {
|
|
||||||
function = "FWSPID";
|
|
||||||
groups = "FWQSPID";
|
|
||||||
};
|
|
||||||
|
|
||||||
pinctrl_fwspiwp_default: fwspiwp_default {
|
pinctrl_fwspiwp_default: fwspiwp_default {
|
||||||
function = "FWSPIWP";
|
function = "FWSPIWP";
|
||||||
groups = "FWSPIWP";
|
groups = "FWSPIWP";
|
||||||
@ -653,12 +648,12 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_qspi1_default: qspi1_default {
|
pinctrl_qspi1_default: qspi1_default {
|
||||||
function = "QSPI1";
|
function = "SPI1";
|
||||||
groups = "QSPI1";
|
groups = "QSPI1";
|
||||||
};
|
};
|
||||||
|
|
||||||
pinctrl_qspi2_default: qspi2_default {
|
pinctrl_qspi2_default: qspi2_default {
|
||||||
function = "QSPI2";
|
function = "SPI2";
|
||||||
groups = "QSPI2";
|
groups = "QSPI2";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -217,6 +217,12 @@
|
|||||||
wm8731: wm8731@1b {
|
wm8731: wm8731@1b {
|
||||||
compatible = "wm8731";
|
compatible = "wm8731";
|
||||||
reg = <0x1b>;
|
reg = <0x1b>;
|
||||||
|
|
||||||
|
/* PCK0 at 12MHz */
|
||||||
|
clocks = <&pmc PMC_TYPE_SYSTEM 8>;
|
||||||
|
clock-names = "mclk";
|
||||||
|
assigned-clocks = <&pmc PMC_TYPE_SYSTEM 8>;
|
||||||
|
assigned-clock-rates = <12000000>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -314,6 +314,8 @@
|
|||||||
codec: sgtl5000@a {
|
codec: sgtl5000@a {
|
||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&pinctrl_sgtl5000>;
|
||||||
clocks = <&clks IMX6QDL_CLK_CKO>;
|
clocks = <&clks IMX6QDL_CLK_CKO>;
|
||||||
VDDA-supply = <®_module_3v3_audio>;
|
VDDA-supply = <®_module_3v3_audio>;
|
||||||
VDDIO-supply = <®_module_3v3>;
|
VDDIO-supply = <®_module_3v3>;
|
||||||
@ -543,8 +545,6 @@
|
|||||||
MX6QDL_PAD_DISP0_DAT21__AUD4_TXD 0x130b0
|
MX6QDL_PAD_DISP0_DAT21__AUD4_TXD 0x130b0
|
||||||
MX6QDL_PAD_DISP0_DAT22__AUD4_TXFS 0x130b0
|
MX6QDL_PAD_DISP0_DAT22__AUD4_TXFS 0x130b0
|
||||||
MX6QDL_PAD_DISP0_DAT23__AUD4_RXD 0x130b0
|
MX6QDL_PAD_DISP0_DAT23__AUD4_RXD 0x130b0
|
||||||
/* SGTL5000 sys_mclk */
|
|
||||||
MX6QDL_PAD_GPIO_5__CCM_CLKO1 0x130b0
|
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -810,6 +810,12 @@
|
|||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pinctrl_sgtl5000: sgtl5000grp {
|
||||||
|
fsl,pins = <
|
||||||
|
MX6QDL_PAD_GPIO_5__CCM_CLKO1 0x130b0
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
pinctrl_spdif: spdifgrp {
|
pinctrl_spdif: spdifgrp {
|
||||||
fsl,pins = <
|
fsl,pins = <
|
||||||
MX6QDL_PAD_GPIO_16__SPDIF_IN 0x1b0b0
|
MX6QDL_PAD_GPIO_16__SPDIF_IN 0x1b0b0
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
reg_sd1_vmmc: regulator-sd1-vmmc {
|
reg_sd1_vmmc: regulator-sd1-vmmc {
|
||||||
compatible = "regulator-gpio";
|
compatible = "regulator-gpio";
|
||||||
gpio = <&gpio5 9 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 9 GPIO_ACTIVE_HIGH>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_snvs_reg_sd>;
|
pinctrl-0 = <&pinctrl_snvs_reg_sd>;
|
||||||
regulator-always-on;
|
regulator-always-on;
|
||||||
|
@ -77,7 +77,7 @@
|
|||||||
|
|
||||||
dailink_master: simple-audio-card,codec {
|
dailink_master: simple-audio-card,codec {
|
||||||
sound-dai = <&codec>;
|
sound-dai = <&codec>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -152,7 +152,7 @@
|
|||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
#sound-dai-cells = <0>;
|
#sound-dai-cells = <0>;
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_sai1_mclk>;
|
pinctrl-0 = <&pinctrl_sai1_mclk>;
|
||||||
VDDA-supply = <®_module_3v3_avdd>;
|
VDDA-supply = <®_module_3v3_avdd>;
|
||||||
|
@ -250,7 +250,7 @@
|
|||||||
tlv320aic32x4: audio-codec@18 {
|
tlv320aic32x4: audio-codec@18 {
|
||||||
compatible = "ti,tlv320aic32x4";
|
compatible = "ti,tlv320aic32x4";
|
||||||
reg = <0x18>;
|
reg = <0x18>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
clock-names = "mclk";
|
clock-names = "mclk";
|
||||||
ldoin-supply = <®_audio_3v3>;
|
ldoin-supply = <®_audio_3v3>;
|
||||||
iov-supply = <®_audio_3v3>;
|
iov-supply = <®_audio_3v3>;
|
||||||
|
@ -284,7 +284,7 @@
|
|||||||
codec: wm8960@1a {
|
codec: wm8960@1a {
|
||||||
compatible = "wlf,wm8960";
|
compatible = "wlf,wm8960";
|
||||||
reg = <0x1a>;
|
reg = <0x1a>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
clock-names = "mclk";
|
clock-names = "mclk";
|
||||||
wlf,shared-lrclk;
|
wlf,shared-lrclk;
|
||||||
};
|
};
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
dailink_master: simple-audio-card,codec {
|
dailink_master: simple-audio-card,codec {
|
||||||
sound-dai = <&sgtl5000>;
|
sound-dai = <&sgtl5000>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -41,7 +41,7 @@
|
|||||||
#sound-dai-cells = <0>;
|
#sound-dai-cells = <0>;
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
VDDA-supply = <®_2p5v>;
|
VDDA-supply = <®_2p5v>;
|
||||||
VDDIO-supply = <®_vref_1v8>;
|
VDDIO-supply = <®_vref_1v8>;
|
||||||
};
|
};
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
dailink_master: simple-audio-card,codec {
|
dailink_master: simple-audio-card,codec {
|
||||||
sound-dai = <&sgtl5000>;
|
sound-dai = <&sgtl5000>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -41,7 +41,7 @@
|
|||||||
#sound-dai-cells = <0>;
|
#sound-dai-cells = <0>;
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
VDDA-supply = <®_2p5v>;
|
VDDA-supply = <®_2p5v>;
|
||||||
VDDIO-supply = <®_vref_1v8>;
|
VDDIO-supply = <®_vref_1v8>;
|
||||||
};
|
};
|
||||||
|
@ -356,7 +356,7 @@
|
|||||||
codec: wm8960@1a {
|
codec: wm8960@1a {
|
||||||
compatible = "wlf,wm8960";
|
compatible = "wlf,wm8960";
|
||||||
reg = <0x1a>;
|
reg = <0x1a>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
clock-names = "mclk";
|
clock-names = "mclk";
|
||||||
wlf,shared-lrclk;
|
wlf,shared-lrclk;
|
||||||
};
|
};
|
||||||
|
@ -75,7 +75,7 @@
|
|||||||
|
|
||||||
dailink_master: simple-audio-card,codec {
|
dailink_master: simple-audio-card,codec {
|
||||||
sound-dai = <&codec>;
|
sound-dai = <&codec>;
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -232,7 +232,7 @@
|
|||||||
#sound-dai-cells = <0>;
|
#sound-dai-cells = <0>;
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_CLK>;
|
clocks = <&clks IMX7D_AUDIO_MCLK_ROOT_DIV>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_sai1_mclk>;
|
pinctrl-0 = <&pinctrl_sai1_mclk>;
|
||||||
VDDA-supply = <&vgen4_reg>;
|
VDDA-supply = <&vgen4_reg>;
|
||||||
|
@ -11,3 +11,18 @@
|
|||||||
model = "LogicPD Zoom OMAP35xx SOM-LV Development Kit";
|
model = "LogicPD Zoom OMAP35xx SOM-LV Development Kit";
|
||||||
compatible = "logicpd,dm3730-som-lv-devkit", "ti,omap3";
|
compatible = "logicpd,dm3730-som-lv-devkit", "ti,omap3";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&omap3_pmx_core2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&hsusb2_2_pins>;
|
||||||
|
hsusb2_2_pins: pinmux_hsusb2_2_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||||
|
OMAP3430_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
@ -11,3 +11,18 @@
|
|||||||
model = "LogicPD Zoom DM3730 SOM-LV Development Kit";
|
model = "LogicPD Zoom DM3730 SOM-LV Development Kit";
|
||||||
compatible = "logicpd,dm3730-som-lv-devkit", "ti,omap3630", "ti,omap3";
|
compatible = "logicpd,dm3730-som-lv-devkit", "ti,omap3630", "ti,omap3";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&omap3_pmx_core2 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&hsusb2_2_pins>;
|
||||||
|
hsusb2_2_pins: pinmux_hsusb2_2_pins {
|
||||||
|
pinctrl-single,pins = <
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
||||||
|
OMAP3630_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
@ -265,21 +265,6 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
&omap3_pmx_core2 {
|
|
||||||
pinctrl-names = "default";
|
|
||||||
pinctrl-0 = <&hsusb2_2_pins>;
|
|
||||||
hsusb2_2_pins: pinmux_hsusb2_2_pins {
|
|
||||||
pinctrl-single,pins = <
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */
|
|
||||||
OMAP3630_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */
|
|
||||||
>;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
&uart2 {
|
&uart2 {
|
||||||
interrupts-extended = <&intc 73 &omap3_pmx_core OMAP3_UART2_RX>;
|
interrupts-extended = <&intc 73 &omap3_pmx_core OMAP3_UART2_RX>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
|
@ -31,6 +31,8 @@
|
|||||||
aliases {
|
aliases {
|
||||||
display0 = &lcd;
|
display0 = &lcd;
|
||||||
display1 = &tv0;
|
display1 = &tv0;
|
||||||
|
/delete-property/ mmc2;
|
||||||
|
/delete-property/ mmc3;
|
||||||
};
|
};
|
||||||
|
|
||||||
ldo_3v3: fixedregulator {
|
ldo_3v3: fixedregulator {
|
||||||
|
@ -480,6 +480,9 @@ extern void pci_iounmap(struct pci_dev *dev, void __iomem *addr);
|
|||||||
extern int valid_phys_addr_range(phys_addr_t addr, size_t size);
|
extern int valid_phys_addr_range(phys_addr_t addr, size_t size);
|
||||||
extern int valid_mmap_phys_addr_range(unsigned long pfn, size_t size);
|
extern int valid_mmap_phys_addr_range(unsigned long pfn, size_t size);
|
||||||
extern int devmem_is_allowed(unsigned long pfn);
|
extern int devmem_is_allowed(unsigned long pfn);
|
||||||
|
extern bool arch_memremap_can_ram_remap(resource_size_t offset, size_t size,
|
||||||
|
unsigned long flags);
|
||||||
|
#define arch_memremap_can_ram_remap arch_memremap_can_ram_remap
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1043,7 +1043,7 @@ vector_bhb_loop8_\name:
|
|||||||
|
|
||||||
@ bhb workaround
|
@ bhb workaround
|
||||||
mov r0, #8
|
mov r0, #8
|
||||||
3: b . + 4
|
3: W(b) . + 4
|
||||||
subs r0, r0, #1
|
subs r0, r0, #1
|
||||||
bne 3b
|
bne 3b
|
||||||
dsb
|
dsb
|
||||||
|
@ -53,17 +53,17 @@ int notrace unwind_frame(struct stackframe *frame)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
frame->sp = frame->fp;
|
frame->sp = frame->fp;
|
||||||
frame->fp = *(unsigned long *)(fp);
|
frame->fp = READ_ONCE_NOCHECK(*(unsigned long *)(fp));
|
||||||
frame->pc = *(unsigned long *)(fp + 4);
|
frame->pc = READ_ONCE_NOCHECK(*(unsigned long *)(fp + 4));
|
||||||
#else
|
#else
|
||||||
/* check current frame pointer is within bounds */
|
/* check current frame pointer is within bounds */
|
||||||
if (fp < low + 12 || fp > high - 4)
|
if (fp < low + 12 || fp > high - 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
/* restore the registers from the stack frame */
|
/* restore the registers from the stack frame */
|
||||||
frame->fp = *(unsigned long *)(fp - 12);
|
frame->fp = READ_ONCE_NOCHECK(*(unsigned long *)(fp - 12));
|
||||||
frame->sp = *(unsigned long *)(fp - 8);
|
frame->sp = READ_ONCE_NOCHECK(*(unsigned long *)(fp - 8));
|
||||||
frame->pc = *(unsigned long *)(fp - 4);
|
frame->pc = READ_ONCE_NOCHECK(*(unsigned long *)(fp - 4));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -214,7 +214,6 @@ config ARCH_BRCMSTB
|
|||||||
select HAVE_ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select BRCMSTB_L2_IRQ
|
select BRCMSTB_L2_IRQ
|
||||||
select BCM7120_L2_IRQ
|
select BCM7120_L2_IRQ
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ZONE_DMA if ARM_LPAE
|
select ZONE_DMA if ARM_LPAE
|
||||||
select SOC_BRCMSTB
|
select SOC_BRCMSTB
|
||||||
select SOC_BUS
|
select SOC_BUS
|
||||||
|
@ -5,7 +5,6 @@ menuconfig ARCH_DAVINCI
|
|||||||
depends on ARCH_MULTI_V5
|
depends on ARCH_MULTI_V5
|
||||||
select DAVINCI_TIMER
|
select DAVINCI_TIMER
|
||||||
select ZONE_DMA
|
select ZONE_DMA
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select PM_GENERIC_DOMAINS if PM
|
select PM_GENERIC_DOMAINS if PM
|
||||||
select PM_GENERIC_DOMAINS_OF if PM && OF
|
select PM_GENERIC_DOMAINS_OF if PM && OF
|
||||||
select REGMAP_MMIO
|
select REGMAP_MMIO
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
menuconfig ARCH_EXYNOS
|
menuconfig ARCH_EXYNOS
|
||||||
bool "Samsung EXYNOS"
|
bool "Samsung EXYNOS"
|
||||||
depends on ARCH_MULTI_V7
|
depends on ARCH_MULTI_V7
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ARCH_SUPPORTS_BIG_ENDIAN
|
select ARCH_SUPPORTS_BIG_ENDIAN
|
||||||
select ARM_AMBA
|
select ARM_AMBA
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
config ARCH_HIGHBANK
|
config ARCH_HIGHBANK
|
||||||
bool "Calxeda ECX-1000/2000 (Highbank/Midway)"
|
bool "Calxeda ECX-1000/2000 (Highbank/Midway)"
|
||||||
depends on ARCH_MULTI_V7
|
depends on ARCH_MULTI_V7
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ARCH_SUPPORTS_BIG_ENDIAN
|
select ARCH_SUPPORTS_BIG_ENDIAN
|
||||||
select ARM_AMBA
|
select ARM_AMBA
|
||||||
select ARM_ERRATA_764369 if SMP
|
select ARM_ERRATA_764369 if SMP
|
||||||
|
@ -94,7 +94,7 @@ config SOC_DRA7XX
|
|||||||
config ARCH_OMAP2PLUS
|
config ARCH_OMAP2PLUS
|
||||||
bool
|
bool
|
||||||
select ARCH_HAS_BANDGAP
|
select ARCH_HAS_BANDGAP
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
select ARCH_HAS_RESET_CONTROLLER
|
||||||
select ARCH_OMAP
|
select ARCH_OMAP
|
||||||
select CLKSRC_MMIO
|
select CLKSRC_MMIO
|
||||||
select GENERIC_IRQ_CHIP
|
select GENERIC_IRQ_CHIP
|
||||||
|
@ -314,10 +314,12 @@ void __init omap_gic_of_init(void)
|
|||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-gic");
|
np = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-gic");
|
||||||
gic_dist_base_addr = of_iomap(np, 0);
|
gic_dist_base_addr = of_iomap(np, 0);
|
||||||
|
of_node_put(np);
|
||||||
WARN_ON(!gic_dist_base_addr);
|
WARN_ON(!gic_dist_base_addr);
|
||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-twd-timer");
|
np = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-twd-timer");
|
||||||
twd_base = of_iomap(np, 0);
|
twd_base = of_iomap(np, 0);
|
||||||
|
of_node_put(np);
|
||||||
WARN_ON(!twd_base);
|
WARN_ON(!twd_base);
|
||||||
|
|
||||||
skip_errata_init:
|
skip_errata_init:
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
config ARCH_S5PV210
|
config ARCH_S5PV210
|
||||||
bool "Samsung S5PV210/S5PC110"
|
bool "Samsung S5PV210/S5PC110"
|
||||||
depends on ARCH_MULTI_V7
|
depends on ARCH_MULTI_V7
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ARM_VIC
|
select ARM_VIC
|
||||||
select CLKSRC_SAMSUNG_PWM
|
select CLKSRC_SAMSUNG_PWM
|
||||||
select COMMON_CLK_SAMSUNG
|
select COMMON_CLK_SAMSUNG
|
||||||
|
@ -3,7 +3,6 @@ config ARCH_TANGO
|
|||||||
bool "Sigma Designs Tango4 (SMP87xx)"
|
bool "Sigma Designs Tango4 (SMP87xx)"
|
||||||
depends on ARCH_MULTI_V7
|
depends on ARCH_MULTI_V7
|
||||||
# Cortex-A9 MPCore r3p0, PL310 r3p2
|
# Cortex-A9 MPCore r3p0, PL310 r3p2
|
||||||
select ARCH_HAS_HOLES_MEMORYMODEL
|
|
||||||
select ARM_ERRATA_754322
|
select ARM_ERRATA_754322
|
||||||
select ARM_ERRATA_764369 if SMP
|
select ARM_ERRATA_764369 if SMP
|
||||||
select ARM_ERRATA_775420
|
select ARM_ERRATA_775420
|
||||||
|
@ -508,3 +508,11 @@ void __init early_ioremap_init(void)
|
|||||||
{
|
{
|
||||||
early_ioremap_setup();
|
early_ioremap_setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool arch_memremap_can_ram_remap(resource_size_t offset, size_t size,
|
||||||
|
unsigned long flags)
|
||||||
|
{
|
||||||
|
unsigned long pfn = PHYS_PFN(offset);
|
||||||
|
|
||||||
|
return memblock_is_map_memory(pfn);
|
||||||
|
}
|
||||||
|
@ -301,6 +301,7 @@ void cpu_v7_ca15_ibe(void)
|
|||||||
{
|
{
|
||||||
if (check_spectre_auxcr(this_cpu_ptr(&spectre_warned), BIT(0)))
|
if (check_spectre_auxcr(this_cpu_ptr(&spectre_warned), BIT(0)))
|
||||||
cpu_v7_spectre_v2_init();
|
cpu_v7_spectre_v2_init();
|
||||||
|
cpu_v7_spectre_bhb_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cpu_v7_bugs_init(void)
|
void cpu_v7_bugs_init(void)
|
||||||
|
@ -11,26 +11,6 @@
|
|||||||
compatible = "operating-points-v2";
|
compatible = "operating-points-v2";
|
||||||
opp-shared;
|
opp-shared;
|
||||||
|
|
||||||
opp-100000000 {
|
|
||||||
opp-hz = /bits/ 64 <100000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-250000000 {
|
|
||||||
opp-hz = /bits/ 64 <250000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-500000000 {
|
|
||||||
opp-hz = /bits/ 64 <500000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-667000000 {
|
|
||||||
opp-hz = /bits/ 64 <667000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-1000000000 {
|
opp-1000000000 {
|
||||||
opp-hz = /bits/ 64 <1000000000>;
|
opp-hz = /bits/ 64 <1000000000>;
|
||||||
opp-microvolt = <761000>;
|
opp-microvolt = <761000>;
|
||||||
@ -71,26 +51,6 @@
|
|||||||
compatible = "operating-points-v2";
|
compatible = "operating-points-v2";
|
||||||
opp-shared;
|
opp-shared;
|
||||||
|
|
||||||
opp-100000000 {
|
|
||||||
opp-hz = /bits/ 64 <100000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-250000000 {
|
|
||||||
opp-hz = /bits/ 64 <250000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-500000000 {
|
|
||||||
opp-hz = /bits/ 64 <500000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-667000000 {
|
|
||||||
opp-hz = /bits/ 64 <667000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-1000000000 {
|
opp-1000000000 {
|
||||||
opp-hz = /bits/ 64 <1000000000>;
|
opp-hz = /bits/ 64 <1000000000>;
|
||||||
opp-microvolt = <731000>;
|
opp-microvolt = <731000>;
|
||||||
|
@ -11,26 +11,6 @@
|
|||||||
compatible = "operating-points-v2";
|
compatible = "operating-points-v2";
|
||||||
opp-shared;
|
opp-shared;
|
||||||
|
|
||||||
opp-100000000 {
|
|
||||||
opp-hz = /bits/ 64 <100000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-250000000 {
|
|
||||||
opp-hz = /bits/ 64 <250000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-500000000 {
|
|
||||||
opp-hz = /bits/ 64 <500000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-667000000 {
|
|
||||||
opp-hz = /bits/ 64 <667000000>;
|
|
||||||
opp-microvolt = <731000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-1000000000 {
|
opp-1000000000 {
|
||||||
opp-hz = /bits/ 64 <1000000000>;
|
opp-hz = /bits/ 64 <1000000000>;
|
||||||
opp-microvolt = <731000>;
|
opp-microvolt = <731000>;
|
||||||
@ -71,26 +51,6 @@
|
|||||||
compatible = "operating-points-v2";
|
compatible = "operating-points-v2";
|
||||||
opp-shared;
|
opp-shared;
|
||||||
|
|
||||||
opp-100000000 {
|
|
||||||
opp-hz = /bits/ 64 <100000000>;
|
|
||||||
opp-microvolt = <751000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-250000000 {
|
|
||||||
opp-hz = /bits/ 64 <250000000>;
|
|
||||||
opp-microvolt = <751000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-500000000 {
|
|
||||||
opp-hz = /bits/ 64 <500000000>;
|
|
||||||
opp-microvolt = <751000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-667000000 {
|
|
||||||
opp-hz = /bits/ 64 <667000000>;
|
|
||||||
opp-microvolt = <751000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-1000000000 {
|
opp-1000000000 {
|
||||||
opp-hz = /bits/ 64 <1000000000>;
|
opp-hz = /bits/ 64 <1000000000>;
|
||||||
opp-microvolt = <771000>;
|
opp-microvolt = <771000>;
|
||||||
|
@ -55,26 +55,6 @@
|
|||||||
compatible = "operating-points-v2";
|
compatible = "operating-points-v2";
|
||||||
opp-shared;
|
opp-shared;
|
||||||
|
|
||||||
opp-100000000 {
|
|
||||||
opp-hz = /bits/ 64 <100000000>;
|
|
||||||
opp-microvolt = <730000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-250000000 {
|
|
||||||
opp-hz = /bits/ 64 <250000000>;
|
|
||||||
opp-microvolt = <730000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-500000000 {
|
|
||||||
opp-hz = /bits/ 64 <500000000>;
|
|
||||||
opp-microvolt = <730000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-667000000 {
|
|
||||||
opp-hz = /bits/ 64 <666666666>;
|
|
||||||
opp-microvolt = <750000>;
|
|
||||||
};
|
|
||||||
|
|
||||||
opp-1000000000 {
|
opp-1000000000 {
|
||||||
opp-hz = /bits/ 64 <1000000000>;
|
opp-hz = /bits/ 64 <1000000000>;
|
||||||
opp-microvolt = <770000>;
|
opp-microvolt = <770000>;
|
||||||
|
@ -213,6 +213,10 @@
|
|||||||
interrupts = <3 GPIO_ACTIVE_LOW>;
|
interrupts = <3 GPIO_ACTIVE_LOW>;
|
||||||
rohm,reset-snvs-powered;
|
rohm,reset-snvs-powered;
|
||||||
|
|
||||||
|
#clock-cells = <0>;
|
||||||
|
clocks = <&osc_32k 0>;
|
||||||
|
clock-output-names = "clk-32k-out";
|
||||||
|
|
||||||
regulators {
|
regulators {
|
||||||
buck1_reg: BUCK1 {
|
buck1_reg: BUCK1 {
|
||||||
regulator-name = "BUCK1";
|
regulator-name = "BUCK1";
|
||||||
|
@ -204,4 +204,8 @@ extern int valid_mmap_phys_addr_range(unsigned long pfn, size_t size);
|
|||||||
|
|
||||||
extern int devmem_is_allowed(unsigned long pfn);
|
extern int devmem_is_allowed(unsigned long pfn);
|
||||||
|
|
||||||
|
extern bool arch_memremap_can_ram_remap(resource_size_t offset, size_t size,
|
||||||
|
unsigned long flags);
|
||||||
|
#define arch_memremap_can_ram_remap arch_memremap_can_ram_remap
|
||||||
|
|
||||||
#endif /* __ASM_IO_H */
|
#endif /* __ASM_IO_H */
|
||||||
|
@ -59,6 +59,7 @@ struct insn_emulation {
|
|||||||
static LIST_HEAD(insn_emulation);
|
static LIST_HEAD(insn_emulation);
|
||||||
static int nr_insn_emulated __initdata;
|
static int nr_insn_emulated __initdata;
|
||||||
static DEFINE_RAW_SPINLOCK(insn_emulation_lock);
|
static DEFINE_RAW_SPINLOCK(insn_emulation_lock);
|
||||||
|
static DEFINE_MUTEX(insn_emulation_mutex);
|
||||||
|
|
||||||
static void register_emulation_hooks(struct insn_emulation_ops *ops)
|
static void register_emulation_hooks(struct insn_emulation_ops *ops)
|
||||||
{
|
{
|
||||||
@ -207,10 +208,10 @@ static int emulation_proc_handler(struct ctl_table *table, int write,
|
|||||||
loff_t *ppos)
|
loff_t *ppos)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
struct insn_emulation *insn = (struct insn_emulation *) table->data;
|
struct insn_emulation *insn = container_of(table->data, struct insn_emulation, current_mode);
|
||||||
enum insn_emulation_mode prev_mode = insn->current_mode;
|
enum insn_emulation_mode prev_mode = insn->current_mode;
|
||||||
|
|
||||||
table->data = &insn->current_mode;
|
mutex_lock(&insn_emulation_mutex);
|
||||||
ret = proc_dointvec_minmax(table, write, buffer, lenp, ppos);
|
ret = proc_dointvec_minmax(table, write, buffer, lenp, ppos);
|
||||||
|
|
||||||
if (ret || !write || prev_mode == insn->current_mode)
|
if (ret || !write || prev_mode == insn->current_mode)
|
||||||
@ -223,7 +224,7 @@ static int emulation_proc_handler(struct ctl_table *table, int write,
|
|||||||
update_insn_emulation_mode(insn, INSN_UNDEF);
|
update_insn_emulation_mode(insn, INSN_UNDEF);
|
||||||
}
|
}
|
||||||
ret:
|
ret:
|
||||||
table->data = insn;
|
mutex_unlock(&insn_emulation_mutex);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,7 +248,7 @@ static void __init register_insn_emulation_sysctl(void)
|
|||||||
sysctl->maxlen = sizeof(int);
|
sysctl->maxlen = sizeof(int);
|
||||||
|
|
||||||
sysctl->procname = insn->ops->name;
|
sysctl->procname = insn->ops->name;
|
||||||
sysctl->data = insn;
|
sysctl->data = &insn->current_mode;
|
||||||
sysctl->extra1 = &insn->min;
|
sysctl->extra1 = &insn->min;
|
||||||
sysctl->extra2 = &insn->max;
|
sysctl->extra2 = &insn->max;
|
||||||
sysctl->proc_handler = emulation_proc_handler;
|
sysctl->proc_handler = emulation_proc_handler;
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/vmalloc.h>
|
#include <linux/vmalloc.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
|
#include <linux/memblock.h>
|
||||||
|
|
||||||
#include <asm/fixmap.h>
|
#include <asm/fixmap.h>
|
||||||
#include <asm/tlbflush.h>
|
#include <asm/tlbflush.h>
|
||||||
@ -100,3 +101,11 @@ void __init early_ioremap_init(void)
|
|||||||
{
|
{
|
||||||
early_ioremap_setup();
|
early_ioremap_setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool arch_memremap_can_ram_remap(resource_size_t offset, size_t size,
|
||||||
|
unsigned long flags)
|
||||||
|
{
|
||||||
|
unsigned long pfn = PHYS_PFN(offset);
|
||||||
|
|
||||||
|
return memblock_is_map_memory(pfn);
|
||||||
|
}
|
||||||
|
@ -167,7 +167,7 @@ void __init plat_mem_setup(void)
|
|||||||
dtb = phys_to_virt(fw_arg2);
|
dtb = phys_to_virt(fw_arg2);
|
||||||
else if (fw_passed_dtb) /* UHI interface or appended dtb */
|
else if (fw_passed_dtb) /* UHI interface or appended dtb */
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
else
|
else
|
||||||
panic("no dtb found");
|
panic("no dtb found");
|
||||||
|
@ -40,9 +40,9 @@
|
|||||||
typedef unsigned int cycles_t;
|
typedef unsigned int cycles_t;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* On R4000/R4400 before version 5.0 an erratum exists such that if the
|
* On R4000/R4400 an erratum exists such that if the cycle counter is
|
||||||
* cycle counter is read in the exact moment that it is matching the
|
* read in the exact moment that it is matching the compare register,
|
||||||
* compare register, no interrupt will be generated.
|
* no interrupt will be generated.
|
||||||
*
|
*
|
||||||
* There is a suggested workaround and also the erratum can't strike if
|
* There is a suggested workaround and also the erratum can't strike if
|
||||||
* the compare interrupt isn't being used as the clock source device.
|
* the compare interrupt isn't being used as the clock source device.
|
||||||
@ -63,7 +63,7 @@ static inline int can_use_mips_counter(unsigned int prid)
|
|||||||
if (!__builtin_constant_p(cpu_has_counter))
|
if (!__builtin_constant_p(cpu_has_counter))
|
||||||
asm volatile("" : "=m" (cpu_data[0].options));
|
asm volatile("" : "=m" (cpu_data[0].options));
|
||||||
if (likely(cpu_has_counter &&
|
if (likely(cpu_has_counter &&
|
||||||
prid >= (PRID_IMP_R4000 | PRID_REV_ENCODE_44(5, 0))))
|
prid > (PRID_IMP_R4000 | PRID_REV_ENCODE_44(15, 15))))
|
||||||
return 1;
|
return 1;
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -61,7 +61,7 @@ void __init plat_mem_setup(void)
|
|||||||
|
|
||||||
jz4740_reset_init();
|
jz4740_reset_init();
|
||||||
|
|
||||||
if (__dtb_start != __dtb_end)
|
if (&__dtb_start != &__dtb_end)
|
||||||
dtb = __dtb_start;
|
dtb = __dtb_start;
|
||||||
else
|
else
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
|
@ -141,15 +141,10 @@ static __init int cpu_has_mfc0_count_bug(void)
|
|||||||
case CPU_R4400MC:
|
case CPU_R4400MC:
|
||||||
/*
|
/*
|
||||||
* The published errata for the R4400 up to 3.0 say the CPU
|
* The published errata for the R4400 up to 3.0 say the CPU
|
||||||
* has the mfc0 from count bug.
|
* has the mfc0 from count bug. This seems the last version
|
||||||
|
* produced.
|
||||||
*/
|
*/
|
||||||
if ((current_cpu_data.processor_id & 0xff) <= 0x30)
|
return 1;
|
||||||
return 1;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* we assume newer revisions are ok
|
|
||||||
*/
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -167,6 +167,8 @@ static inline void clkdev_add_sys(const char *dev, unsigned int module,
|
|||||||
{
|
{
|
||||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!clk)
|
||||||
|
return;
|
||||||
clk->cl.dev_id = dev;
|
clk->cl.dev_id = dev;
|
||||||
clk->cl.con_id = NULL;
|
clk->cl.con_id = NULL;
|
||||||
clk->cl.clk = clk;
|
clk->cl.clk = clk;
|
||||||
|
@ -79,7 +79,7 @@ void __init plat_mem_setup(void)
|
|||||||
|
|
||||||
if (fw_passed_dtb) /* UHI interface */
|
if (fw_passed_dtb) /* UHI interface */
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
else
|
else
|
||||||
panic("no dtb found");
|
panic("no dtb found");
|
||||||
|
@ -122,6 +122,8 @@ static inline void clkdev_add_gptu(struct device *dev, const char *con,
|
|||||||
{
|
{
|
||||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!clk)
|
||||||
|
return;
|
||||||
clk->cl.dev_id = dev_name(dev);
|
clk->cl.dev_id = dev_name(dev);
|
||||||
clk->cl.con_id = con;
|
clk->cl.con_id = con;
|
||||||
clk->cl.clk = clk;
|
clk->cl.clk = clk;
|
||||||
|
@ -311,6 +311,8 @@ static void clkdev_add_pmu(const char *dev, const char *con, bool deactivate,
|
|||||||
{
|
{
|
||||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!clk)
|
||||||
|
return;
|
||||||
clk->cl.dev_id = dev;
|
clk->cl.dev_id = dev;
|
||||||
clk->cl.con_id = con;
|
clk->cl.con_id = con;
|
||||||
clk->cl.clk = clk;
|
clk->cl.clk = clk;
|
||||||
@ -334,6 +336,8 @@ static void clkdev_add_cgu(const char *dev, const char *con,
|
|||||||
{
|
{
|
||||||
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
struct clk *clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!clk)
|
||||||
|
return;
|
||||||
clk->cl.dev_id = dev;
|
clk->cl.dev_id = dev;
|
||||||
clk->cl.con_id = con;
|
clk->cl.con_id = con;
|
||||||
clk->cl.clk = clk;
|
clk->cl.clk = clk;
|
||||||
@ -352,24 +356,28 @@ static void clkdev_add_pci(void)
|
|||||||
struct clk *clk_ext = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
struct clk *clk_ext = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
|
||||||
/* main pci clock */
|
/* main pci clock */
|
||||||
clk->cl.dev_id = "17000000.pci";
|
if (clk) {
|
||||||
clk->cl.con_id = NULL;
|
clk->cl.dev_id = "17000000.pci";
|
||||||
clk->cl.clk = clk;
|
clk->cl.con_id = NULL;
|
||||||
clk->rate = CLOCK_33M;
|
clk->cl.clk = clk;
|
||||||
clk->rates = valid_pci_rates;
|
clk->rate = CLOCK_33M;
|
||||||
clk->enable = pci_enable;
|
clk->rates = valid_pci_rates;
|
||||||
clk->disable = pmu_disable;
|
clk->enable = pci_enable;
|
||||||
clk->module = 0;
|
clk->disable = pmu_disable;
|
||||||
clk->bits = PMU_PCI;
|
clk->module = 0;
|
||||||
clkdev_add(&clk->cl);
|
clk->bits = PMU_PCI;
|
||||||
|
clkdev_add(&clk->cl);
|
||||||
|
}
|
||||||
|
|
||||||
/* use internal/external bus clock */
|
/* use internal/external bus clock */
|
||||||
clk_ext->cl.dev_id = "17000000.pci";
|
if (clk_ext) {
|
||||||
clk_ext->cl.con_id = "external";
|
clk_ext->cl.dev_id = "17000000.pci";
|
||||||
clk_ext->cl.clk = clk_ext;
|
clk_ext->cl.con_id = "external";
|
||||||
clk_ext->enable = pci_ext_enable;
|
clk_ext->cl.clk = clk_ext;
|
||||||
clk_ext->disable = pci_ext_disable;
|
clk_ext->enable = pci_ext_enable;
|
||||||
clkdev_add(&clk_ext->cl);
|
clk_ext->disable = pci_ext_disable;
|
||||||
|
clkdev_add(&clk_ext->cl);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* xway socs can generate clocks on gpio pins */
|
/* xway socs can generate clocks on gpio pins */
|
||||||
@ -389,9 +397,15 @@ static void clkdev_add_clkout(void)
|
|||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
name = kzalloc(sizeof("clkout0"), GFP_KERNEL);
|
name = kzalloc(sizeof("clkout0"), GFP_KERNEL);
|
||||||
|
if (!name)
|
||||||
|
continue;
|
||||||
sprintf(name, "clkout%d", i);
|
sprintf(name, "clkout%d", i);
|
||||||
|
|
||||||
clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
clk = kzalloc(sizeof(struct clk), GFP_KERNEL);
|
||||||
|
if (!clk) {
|
||||||
|
kfree(name);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
clk->cl.dev_id = "1f103000.cgu";
|
clk->cl.dev_id = "1f103000.cgu";
|
||||||
clk->cl.con_id = name;
|
clk->cl.con_id = name;
|
||||||
clk->cl.clk = clk;
|
clk->cl.clk = clk;
|
||||||
|
@ -28,7 +28,7 @@ static ulong get_fdtaddr(void)
|
|||||||
if (fw_passed_dtb && !fw_arg2 && !fw_arg3)
|
if (fw_passed_dtb && !fw_arg2 && !fw_arg3)
|
||||||
return (ulong)fw_passed_dtb;
|
return (ulong)fw_passed_dtb;
|
||||||
|
|
||||||
if (__dtb_start < __dtb_end)
|
if (&__dtb_start < &__dtb_end)
|
||||||
ftaddr = (ulong)__dtb_start;
|
ftaddr = (ulong)__dtb_start;
|
||||||
|
|
||||||
return ftaddr;
|
return ftaddr;
|
||||||
|
@ -77,7 +77,7 @@ void __init plat_mem_setup(void)
|
|||||||
*/
|
*/
|
||||||
if (fw_passed_dtb)
|
if (fw_passed_dtb)
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
|
|
||||||
__dt_setup_arch(dtb);
|
__dt_setup_arch(dtb);
|
||||||
|
@ -419,8 +419,7 @@ show_cpuinfo (struct seq_file *m, void *v)
|
|||||||
}
|
}
|
||||||
seq_printf(m, " (0x%02lx)\n", boot_cpu_data.pdc.capabilities);
|
seq_printf(m, " (0x%02lx)\n", boot_cpu_data.pdc.capabilities);
|
||||||
|
|
||||||
seq_printf(m, "model\t\t: %s\n"
|
seq_printf(m, "model\t\t: %s - %s\n",
|
||||||
"model name\t: %s\n",
|
|
||||||
boot_cpu_data.pdc.sys_model_name,
|
boot_cpu_data.pdc.sys_model_name,
|
||||||
cpuinfo->dev ?
|
cpuinfo->dev ?
|
||||||
cpuinfo->dev->name : "Unknown");
|
cpuinfo->dev->name : "Unknown");
|
||||||
|
@ -31,6 +31,16 @@ KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-option,-ffreestanding)
|
|||||||
KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, address-of-packed-member)
|
KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, address-of-packed-member)
|
||||||
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO),-g)
|
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO),-g)
|
||||||
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO_DWARF4), $(call cc-option, -gdwarf-4,))
|
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO_DWARF4), $(call cc-option, -gdwarf-4,))
|
||||||
|
|
||||||
|
ifdef CONFIG_CC_IS_GCC
|
||||||
|
ifeq ($(call cc-ifversion, -ge, 1200, y), y)
|
||||||
|
ifeq ($(call cc-ifversion, -lt, 1300, y), y)
|
||||||
|
KBUILD_CFLAGS += $(call cc-disable-warning, array-bounds)
|
||||||
|
KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, array-bounds)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
UTS_MACHINE := s390x
|
UTS_MACHINE := s390x
|
||||||
STACK_SIZE := $(if $(CONFIG_KASAN),65536,16384)
|
STACK_SIZE := $(if $(CONFIG_KASAN),65536,16384)
|
||||||
CHECKFLAGS += -D__s390__ -D__s390x__
|
CHECKFLAGS += -D__s390__ -D__s390x__
|
||||||
|
@ -172,7 +172,7 @@ ENTRY(chacha_2block_xor_avx512vl)
|
|||||||
# xor remaining bytes from partial register into output
|
# xor remaining bytes from partial register into output
|
||||||
mov %rcx,%rax
|
mov %rcx,%rax
|
||||||
and $0xf,%rcx
|
and $0xf,%rcx
|
||||||
jz .Ldone8
|
jz .Ldone2
|
||||||
mov %rax,%r9
|
mov %rax,%r9
|
||||||
and $~0xf,%r9
|
and $~0xf,%r9
|
||||||
|
|
||||||
@ -438,7 +438,7 @@ ENTRY(chacha_4block_xor_avx512vl)
|
|||||||
# xor remaining bytes from partial register into output
|
# xor remaining bytes from partial register into output
|
||||||
mov %rcx,%rax
|
mov %rcx,%rax
|
||||||
and $0xf,%rcx
|
and $0xf,%rcx
|
||||||
jz .Ldone8
|
jz .Ldone4
|
||||||
mov %rax,%r9
|
mov %rax,%r9
|
||||||
and $~0xf,%r9
|
and $~0xf,%r9
|
||||||
|
|
||||||
|
@ -7,9 +7,11 @@
|
|||||||
# define __ASM_FORM_RAW(x) x
|
# define __ASM_FORM_RAW(x) x
|
||||||
# define __ASM_FORM_COMMA(x) x,
|
# define __ASM_FORM_COMMA(x) x,
|
||||||
#else
|
#else
|
||||||
# define __ASM_FORM(x) " " #x " "
|
#include <linux/stringify.h>
|
||||||
# define __ASM_FORM_RAW(x) #x
|
|
||||||
# define __ASM_FORM_COMMA(x) " " #x ","
|
# define __ASM_FORM(x) " " __stringify(x) " "
|
||||||
|
# define __ASM_FORM_RAW(x) __stringify(x)
|
||||||
|
# define __ASM_FORM_COMMA(x) " " __stringify(x) ","
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __x86_64__
|
#ifndef __x86_64__
|
||||||
|
14
arch/x86/include/asm/emulate_prefix.h
Normal file
14
arch/x86/include/asm/emulate_prefix.h
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
|
#ifndef _ASM_X86_EMULATE_PREFIX_H
|
||||||
|
#define _ASM_X86_EMULATE_PREFIX_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Virt escape sequences to trigger instruction emulation;
|
||||||
|
* ideally these would decode to 'whole' instruction and not destroy
|
||||||
|
* the instruction stream; sadly this is not true for the 'kvm' one :/
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define __XEN_EMULATE_PREFIX 0x0f,0x0b,0x78,0x65,0x6e /* ud2 ; .ascii "xen" */
|
||||||
|
#define __KVM_EMULATE_PREFIX 0x0f,0x0b,0x6b,0x76,0x6d /* ud2 ; .ascii "kvm" */
|
||||||
|
|
||||||
|
#endif
|
@ -45,6 +45,7 @@ struct insn {
|
|||||||
struct insn_field immediate2; /* for 64bit imm or seg16 */
|
struct insn_field immediate2; /* for 64bit imm or seg16 */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
int emulate_prefix_size;
|
||||||
insn_attr_t attr;
|
insn_attr_t attr;
|
||||||
unsigned char opnd_bytes;
|
unsigned char opnd_bytes;
|
||||||
unsigned char addr_bytes;
|
unsigned char addr_bytes;
|
||||||
@ -128,6 +129,11 @@ static inline int insn_is_evex(struct insn *insn)
|
|||||||
return (insn->vex_prefix.nbytes == 4);
|
return (insn->vex_prefix.nbytes == 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int insn_has_emulate_prefix(struct insn *insn)
|
||||||
|
{
|
||||||
|
return !!insn->emulate_prefix_size;
|
||||||
|
}
|
||||||
|
|
||||||
/* Ensure this instruction is decoded completely */
|
/* Ensure this instruction is decoded completely */
|
||||||
static inline int insn_complete(struct insn *insn)
|
static inline int insn_complete(struct insn *insn)
|
||||||
{
|
{
|
||||||
|
@ -133,11 +133,13 @@ extern void load_ucode_ap(void);
|
|||||||
void reload_early_microcode(void);
|
void reload_early_microcode(void);
|
||||||
extern bool get_builtin_firmware(struct cpio_data *cd, const char *name);
|
extern bool get_builtin_firmware(struct cpio_data *cd, const char *name);
|
||||||
extern bool initrd_gone;
|
extern bool initrd_gone;
|
||||||
|
void microcode_bsp_resume(void);
|
||||||
#else
|
#else
|
||||||
static inline int __init microcode_init(void) { return 0; };
|
static inline int __init microcode_init(void) { return 0; };
|
||||||
static inline void __init load_ucode_bsp(void) { }
|
static inline void __init load_ucode_bsp(void) { }
|
||||||
static inline void load_ucode_ap(void) { }
|
static inline void load_ucode_ap(void) { }
|
||||||
static inline void reload_early_microcode(void) { }
|
static inline void reload_early_microcode(void) { }
|
||||||
|
static inline void microcode_bsp_resume(void) { }
|
||||||
static inline bool
|
static inline bool
|
||||||
get_builtin_firmware(struct cpio_data *cd, const char *name) { return false; }
|
get_builtin_firmware(struct cpio_data *cd, const char *name) { return false; }
|
||||||
#endif
|
#endif
|
||||||
|
@ -379,12 +379,9 @@ struct xen_pmu_arch {
|
|||||||
* Prefix forces emulation of some non-trapping instructions.
|
* Prefix forces emulation of some non-trapping instructions.
|
||||||
* Currently only CPUID.
|
* Currently only CPUID.
|
||||||
*/
|
*/
|
||||||
#ifdef __ASSEMBLY__
|
#include <asm/emulate_prefix.h>
|
||||||
#define XEN_EMULATE_PREFIX .byte 0x0f,0x0b,0x78,0x65,0x6e ;
|
|
||||||
#define XEN_CPUID XEN_EMULATE_PREFIX cpuid
|
#define XEN_EMULATE_PREFIX __ASM_FORM(.byte __XEN_EMULATE_PREFIX ;)
|
||||||
#else
|
#define XEN_CPUID XEN_EMULATE_PREFIX __ASM_FORM(cpuid)
|
||||||
#define XEN_EMULATE_PREFIX ".byte 0x0f,0x0b,0x78,0x65,0x6e ; "
|
|
||||||
#define XEN_CPUID XEN_EMULATE_PREFIX "cpuid"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _ASM_X86_XEN_INTERFACE_H */
|
#endif /* _ASM_X86_XEN_INTERFACE_H */
|
||||||
|
@ -772,9 +772,9 @@ static struct subsys_interface mc_cpu_interface = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* mc_bp_resume - Update boot CPU microcode during resume.
|
* microcode_bsp_resume - Update boot CPU microcode during resume.
|
||||||
*/
|
*/
|
||||||
static void mc_bp_resume(void)
|
void microcode_bsp_resume(void)
|
||||||
{
|
{
|
||||||
int cpu = smp_processor_id();
|
int cpu = smp_processor_id();
|
||||||
struct ucode_cpu_info *uci = ucode_cpu_info + cpu;
|
struct ucode_cpu_info *uci = ucode_cpu_info + cpu;
|
||||||
@ -786,7 +786,7 @@ static void mc_bp_resume(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct syscore_ops mc_syscore_ops = {
|
static struct syscore_ops mc_syscore_ops = {
|
||||||
.resume = mc_bp_resume,
|
.resume = microcode_bsp_resume,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int mc_cpu_starting(unsigned int cpu)
|
static int mc_cpu_starting(unsigned int cpu)
|
||||||
|
@ -358,6 +358,10 @@ int __copy_instruction(u8 *dest, u8 *src, u8 *real, struct insn *insn)
|
|||||||
kernel_insn_init(insn, dest, MAX_INSN_SIZE);
|
kernel_insn_init(insn, dest, MAX_INSN_SIZE);
|
||||||
insn_get_length(insn);
|
insn_get_length(insn);
|
||||||
|
|
||||||
|
/* We can not probe force emulate prefixed instruction */
|
||||||
|
if (insn_has_emulate_prefix(insn))
|
||||||
|
return 0;
|
||||||
|
|
||||||
/* Another subsystem puts a breakpoint, failed to recover */
|
/* Another subsystem puts a breakpoint, failed to recover */
|
||||||
if (insn->opcode.bytes[0] == BREAKPOINT_INSTRUCTION)
|
if (insn->opcode.bytes[0] == BREAKPOINT_INSTRUCTION)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -59,6 +59,7 @@ static DEFINE_PER_CPU_DECRYPTED(struct kvm_vcpu_pv_apf_data, apf_reason) __align
|
|||||||
DEFINE_PER_CPU_DECRYPTED(struct kvm_steal_time, steal_time) __aligned(64) __visible;
|
DEFINE_PER_CPU_DECRYPTED(struct kvm_steal_time, steal_time) __aligned(64) __visible;
|
||||||
static int has_steal_clock = 0;
|
static int has_steal_clock = 0;
|
||||||
|
|
||||||
|
static int has_guest_poll = 0;
|
||||||
/*
|
/*
|
||||||
* No need for any "IO delay" on KVM
|
* No need for any "IO delay" on KVM
|
||||||
*/
|
*/
|
||||||
@ -584,14 +585,26 @@ static int kvm_cpu_down_prepare(unsigned int cpu)
|
|||||||
|
|
||||||
static int kvm_suspend(void)
|
static int kvm_suspend(void)
|
||||||
{
|
{
|
||||||
|
u64 val = 0;
|
||||||
|
|
||||||
kvm_guest_cpu_offline(false);
|
kvm_guest_cpu_offline(false);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_CPUIDLE_HALTPOLL
|
||||||
|
if (kvm_para_has_feature(KVM_FEATURE_POLL_CONTROL))
|
||||||
|
rdmsrl(MSR_KVM_POLL_CONTROL, val);
|
||||||
|
has_guest_poll = !(val & 1);
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void kvm_resume(void)
|
static void kvm_resume(void)
|
||||||
{
|
{
|
||||||
kvm_cpu_online(raw_smp_processor_id());
|
kvm_cpu_online(raw_smp_processor_id());
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_CPUIDLE_HALTPOLL
|
||||||
|
if (kvm_para_has_feature(KVM_FEATURE_POLL_CONTROL) && has_guest_poll)
|
||||||
|
wrmsrl(MSR_KVM_POLL_CONTROL, 0);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct syscore_ops kvm_syscore_ops = {
|
static struct syscore_ops kvm_syscore_ops = {
|
||||||
|
@ -592,6 +592,11 @@ static inline int __do_cpuid_func(struct kvm_cpuid_entry2 *entry, u32 function,
|
|||||||
union cpuid10_eax eax;
|
union cpuid10_eax eax;
|
||||||
union cpuid10_edx edx;
|
union cpuid10_edx edx;
|
||||||
|
|
||||||
|
if (!static_cpu_has(X86_FEATURE_ARCH_PERFMON)) {
|
||||||
|
entry->eax = entry->ebx = entry->ecx = entry->edx = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
perf_get_x86_pmu_capability(&cap);
|
perf_get_x86_pmu_capability(&cap);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -118,7 +118,8 @@ static inline u32 kvm_x2apic_id(struct kvm_lapic *apic)
|
|||||||
|
|
||||||
bool kvm_can_post_timer_interrupt(struct kvm_vcpu *vcpu)
|
bool kvm_can_post_timer_interrupt(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
return pi_inject_timer && kvm_vcpu_apicv_active(vcpu);
|
return pi_inject_timer && kvm_vcpu_apicv_active(vcpu) &&
|
||||||
|
(kvm_mwait_in_guest(vcpu->kvm) || kvm_hlt_in_guest(vcpu->kvm));
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(kvm_can_post_timer_interrupt);
|
EXPORT_SYMBOL_GPL(kvm_can_post_timer_interrupt);
|
||||||
|
|
||||||
|
@ -5821,6 +5821,7 @@ static void kvm_zap_obsolete_pages(struct kvm *kvm)
|
|||||||
{
|
{
|
||||||
struct kvm_mmu_page *sp, *node;
|
struct kvm_mmu_page *sp, *node;
|
||||||
int nr_zapped, batch = 0;
|
int nr_zapped, batch = 0;
|
||||||
|
bool unstable;
|
||||||
|
|
||||||
restart:
|
restart:
|
||||||
list_for_each_entry_safe_reverse(sp, node,
|
list_for_each_entry_safe_reverse(sp, node,
|
||||||
@ -5853,11 +5854,12 @@ static void kvm_zap_obsolete_pages(struct kvm *kvm)
|
|||||||
goto restart;
|
goto restart;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (__kvm_mmu_prepare_zap_page(kvm, sp,
|
unstable = __kvm_mmu_prepare_zap_page(kvm, sp,
|
||||||
&kvm->arch.zapped_obsolete_pages, &nr_zapped)) {
|
&kvm->arch.zapped_obsolete_pages, &nr_zapped);
|
||||||
batch += nr_zapped;
|
batch += nr_zapped;
|
||||||
|
|
||||||
|
if (unstable)
|
||||||
goto restart;
|
goto restart;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -143,7 +143,6 @@ static void pmc_reprogram_counter(struct kvm_pmc *pmc, u32 type,
|
|||||||
void reprogram_gp_counter(struct kvm_pmc *pmc, u64 eventsel)
|
void reprogram_gp_counter(struct kvm_pmc *pmc, u64 eventsel)
|
||||||
{
|
{
|
||||||
unsigned config, type = PERF_TYPE_RAW;
|
unsigned config, type = PERF_TYPE_RAW;
|
||||||
u8 event_select, unit_mask;
|
|
||||||
struct kvm *kvm = pmc->vcpu->kvm;
|
struct kvm *kvm = pmc->vcpu->kvm;
|
||||||
struct kvm_pmu_event_filter *filter;
|
struct kvm_pmu_event_filter *filter;
|
||||||
int i;
|
int i;
|
||||||
@ -175,17 +174,12 @@ void reprogram_gp_counter(struct kvm_pmc *pmc, u64 eventsel)
|
|||||||
if (!allow_event)
|
if (!allow_event)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
event_select = eventsel & ARCH_PERFMON_EVENTSEL_EVENT;
|
|
||||||
unit_mask = (eventsel & ARCH_PERFMON_EVENTSEL_UMASK) >> 8;
|
|
||||||
|
|
||||||
if (!(eventsel & (ARCH_PERFMON_EVENTSEL_EDGE |
|
if (!(eventsel & (ARCH_PERFMON_EVENTSEL_EDGE |
|
||||||
ARCH_PERFMON_EVENTSEL_INV |
|
ARCH_PERFMON_EVENTSEL_INV |
|
||||||
ARCH_PERFMON_EVENTSEL_CMASK |
|
ARCH_PERFMON_EVENTSEL_CMASK |
|
||||||
HSW_IN_TX |
|
HSW_IN_TX |
|
||||||
HSW_IN_TX_CHECKPOINTED))) {
|
HSW_IN_TX_CHECKPOINTED))) {
|
||||||
config = kvm_x86_ops->pmu_ops->find_arch_event(pmc_to_pmu(pmc),
|
config = kvm_x86_ops->pmu_ops->pmc_perf_hw_id(pmc);
|
||||||
event_select,
|
|
||||||
unit_mask);
|
|
||||||
if (config != PERF_COUNT_HW_MAX)
|
if (config != PERF_COUNT_HW_MAX)
|
||||||
type = PERF_TYPE_HARDWARE;
|
type = PERF_TYPE_HARDWARE;
|
||||||
}
|
}
|
||||||
|
@ -22,8 +22,7 @@ struct kvm_event_hw_type_mapping {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct kvm_pmu_ops {
|
struct kvm_pmu_ops {
|
||||||
unsigned (*find_arch_event)(struct kvm_pmu *pmu, u8 event_select,
|
unsigned int (*pmc_perf_hw_id)(struct kvm_pmc *pmc);
|
||||||
u8 unit_mask);
|
|
||||||
unsigned (*find_fixed_event)(int idx);
|
unsigned (*find_fixed_event)(int idx);
|
||||||
bool (*pmc_is_enabled)(struct kvm_pmc *pmc);
|
bool (*pmc_is_enabled)(struct kvm_pmc *pmc);
|
||||||
struct kvm_pmc *(*pmc_idx_to_pmc)(struct kvm_pmu *pmu, int pmc_idx);
|
struct kvm_pmc *(*pmc_idx_to_pmc)(struct kvm_pmu *pmu, int pmc_idx);
|
||||||
|
@ -44,6 +44,22 @@ static struct kvm_event_hw_type_mapping amd_event_mapping[] = {
|
|||||||
[7] = { 0xd1, 0x00, PERF_COUNT_HW_STALLED_CYCLES_BACKEND },
|
[7] = { 0xd1, 0x00, PERF_COUNT_HW_STALLED_CYCLES_BACKEND },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* duplicated from amd_f17h_perfmon_event_map. */
|
||||||
|
static struct kvm_event_hw_type_mapping amd_f17h_event_mapping[] = {
|
||||||
|
[0] = { 0x76, 0x00, PERF_COUNT_HW_CPU_CYCLES },
|
||||||
|
[1] = { 0xc0, 0x00, PERF_COUNT_HW_INSTRUCTIONS },
|
||||||
|
[2] = { 0x60, 0xff, PERF_COUNT_HW_CACHE_REFERENCES },
|
||||||
|
[3] = { 0x64, 0x09, PERF_COUNT_HW_CACHE_MISSES },
|
||||||
|
[4] = { 0xc2, 0x00, PERF_COUNT_HW_BRANCH_INSTRUCTIONS },
|
||||||
|
[5] = { 0xc3, 0x00, PERF_COUNT_HW_BRANCH_MISSES },
|
||||||
|
[6] = { 0x87, 0x02, PERF_COUNT_HW_STALLED_CYCLES_FRONTEND },
|
||||||
|
[7] = { 0x87, 0x01, PERF_COUNT_HW_STALLED_CYCLES_BACKEND },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* amd_pmc_perf_hw_id depends on these being the same size */
|
||||||
|
static_assert(ARRAY_SIZE(amd_event_mapping) ==
|
||||||
|
ARRAY_SIZE(amd_f17h_event_mapping));
|
||||||
|
|
||||||
static unsigned int get_msr_base(struct kvm_pmu *pmu, enum pmu_type type)
|
static unsigned int get_msr_base(struct kvm_pmu *pmu, enum pmu_type type)
|
||||||
{
|
{
|
||||||
struct kvm_vcpu *vcpu = pmu_to_vcpu(pmu);
|
struct kvm_vcpu *vcpu = pmu_to_vcpu(pmu);
|
||||||
@ -126,21 +142,27 @@ static inline struct kvm_pmc *get_gp_pmc_amd(struct kvm_pmu *pmu, u32 msr,
|
|||||||
return &pmu->gp_counters[msr_to_index(msr)];
|
return &pmu->gp_counters[msr_to_index(msr)];
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned amd_find_arch_event(struct kvm_pmu *pmu,
|
static unsigned int amd_pmc_perf_hw_id(struct kvm_pmc *pmc)
|
||||||
u8 event_select,
|
|
||||||
u8 unit_mask)
|
|
||||||
{
|
{
|
||||||
|
struct kvm_event_hw_type_mapping *event_mapping;
|
||||||
|
u8 event_select = pmc->eventsel & ARCH_PERFMON_EVENTSEL_EVENT;
|
||||||
|
u8 unit_mask = (pmc->eventsel & ARCH_PERFMON_EVENTSEL_UMASK) >> 8;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
if (guest_cpuid_family(pmc->vcpu) >= 0x17)
|
||||||
|
event_mapping = amd_f17h_event_mapping;
|
||||||
|
else
|
||||||
|
event_mapping = amd_event_mapping;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(amd_event_mapping); i++)
|
for (i = 0; i < ARRAY_SIZE(amd_event_mapping); i++)
|
||||||
if (amd_event_mapping[i].eventsel == event_select
|
if (event_mapping[i].eventsel == event_select
|
||||||
&& amd_event_mapping[i].unit_mask == unit_mask)
|
&& event_mapping[i].unit_mask == unit_mask)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (i == ARRAY_SIZE(amd_event_mapping))
|
if (i == ARRAY_SIZE(amd_event_mapping))
|
||||||
return PERF_COUNT_HW_MAX;
|
return PERF_COUNT_HW_MAX;
|
||||||
|
|
||||||
return amd_event_mapping[i].event_type;
|
return event_mapping[i].event_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* return PERF_COUNT_HW_MAX as AMD doesn't have fixed events */
|
/* return PERF_COUNT_HW_MAX as AMD doesn't have fixed events */
|
||||||
@ -300,7 +322,7 @@ static void amd_pmu_reset(struct kvm_vcpu *vcpu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct kvm_pmu_ops amd_pmu_ops = {
|
struct kvm_pmu_ops amd_pmu_ops = {
|
||||||
.find_arch_event = amd_find_arch_event,
|
.pmc_perf_hw_id = amd_pmc_perf_hw_id,
|
||||||
.find_fixed_event = amd_find_fixed_event,
|
.find_fixed_event = amd_find_fixed_event,
|
||||||
.pmc_is_enabled = amd_pmc_is_enabled,
|
.pmc_is_enabled = amd_pmc_is_enabled,
|
||||||
.pmc_idx_to_pmc = amd_pmc_idx_to_pmc,
|
.pmc_idx_to_pmc = amd_pmc_idx_to_pmc,
|
||||||
|
@ -64,10 +64,11 @@ static void global_ctrl_changed(struct kvm_pmu *pmu, u64 data)
|
|||||||
reprogram_counter(pmu, bit);
|
reprogram_counter(pmu, bit);
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned intel_find_arch_event(struct kvm_pmu *pmu,
|
static unsigned int intel_pmc_perf_hw_id(struct kvm_pmc *pmc)
|
||||||
u8 event_select,
|
|
||||||
u8 unit_mask)
|
|
||||||
{
|
{
|
||||||
|
struct kvm_pmu *pmu = pmc_to_pmu(pmc);
|
||||||
|
u8 event_select = pmc->eventsel & ARCH_PERFMON_EVENTSEL_EVENT;
|
||||||
|
u8 unit_mask = (pmc->eventsel & ARCH_PERFMON_EVENTSEL_UMASK) >> 8;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(intel_arch_events); i++)
|
for (i = 0; i < ARRAY_SIZE(intel_arch_events); i++)
|
||||||
@ -374,7 +375,7 @@ static void intel_pmu_reset(struct kvm_vcpu *vcpu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct kvm_pmu_ops intel_pmu_ops = {
|
struct kvm_pmu_ops intel_pmu_ops = {
|
||||||
.find_arch_event = intel_find_arch_event,
|
.pmc_perf_hw_id = intel_pmc_perf_hw_id,
|
||||||
.find_fixed_event = intel_find_fixed_event,
|
.find_fixed_event = intel_find_fixed_event,
|
||||||
.pmc_is_enabled = intel_pmc_is_enabled,
|
.pmc_is_enabled = intel_pmc_is_enabled,
|
||||||
.pmc_idx_to_pmc = intel_pmc_idx_to_pmc,
|
.pmc_idx_to_pmc = intel_pmc_idx_to_pmc,
|
||||||
|
@ -68,6 +68,7 @@
|
|||||||
#include <asm/mshyperv.h>
|
#include <asm/mshyperv.h>
|
||||||
#include <asm/hypervisor.h>
|
#include <asm/hypervisor.h>
|
||||||
#include <asm/intel_pt.h>
|
#include <asm/intel_pt.h>
|
||||||
|
#include <asm/emulate_prefix.h>
|
||||||
#include <clocksource/hyperv_timer.h>
|
#include <clocksource/hyperv_timer.h>
|
||||||
|
|
||||||
#define CREATE_TRACE_POINTS
|
#define CREATE_TRACE_POINTS
|
||||||
@ -5583,6 +5584,7 @@ EXPORT_SYMBOL_GPL(kvm_write_guest_virt_system);
|
|||||||
|
|
||||||
int handle_ud(struct kvm_vcpu *vcpu)
|
int handle_ud(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
|
static const char kvm_emulate_prefix[] = { __KVM_EMULATE_PREFIX };
|
||||||
int emul_type = EMULTYPE_TRAP_UD;
|
int emul_type = EMULTYPE_TRAP_UD;
|
||||||
char sig[5]; /* ud2; .ascii "kvm" */
|
char sig[5]; /* ud2; .ascii "kvm" */
|
||||||
struct x86_exception e;
|
struct x86_exception e;
|
||||||
@ -5590,7 +5592,7 @@ int handle_ud(struct kvm_vcpu *vcpu)
|
|||||||
if (force_emulation_prefix &&
|
if (force_emulation_prefix &&
|
||||||
kvm_read_guest_virt(vcpu, kvm_get_linear_rip(vcpu),
|
kvm_read_guest_virt(vcpu, kvm_get_linear_rip(vcpu),
|
||||||
sig, sizeof(sig), &e) == 0 &&
|
sig, sizeof(sig), &e) == 0 &&
|
||||||
memcmp(sig, "\xf\xbkvm", sizeof(sig)) == 0) {
|
memcmp(sig, kvm_emulate_prefix, sizeof(sig)) == 0) {
|
||||||
kvm_rip_write(vcpu, kvm_rip_read(vcpu) + sizeof(sig));
|
kvm_rip_write(vcpu, kvm_rip_read(vcpu) + sizeof(sig));
|
||||||
emul_type = EMULTYPE_TRAP_UD_FORCED;
|
emul_type = EMULTYPE_TRAP_UD_FORCED;
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,8 @@
|
|||||||
#include <asm/inat.h>
|
#include <asm/inat.h>
|
||||||
#include <asm/insn.h>
|
#include <asm/insn.h>
|
||||||
|
|
||||||
|
#include <asm/emulate_prefix.h>
|
||||||
|
|
||||||
/* Verify next sizeof(t) bytes can be on the same instruction */
|
/* Verify next sizeof(t) bytes can be on the same instruction */
|
||||||
#define validate_next(t, insn, n) \
|
#define validate_next(t, insn, n) \
|
||||||
((insn)->next_byte + sizeof(t) + n <= (insn)->end_kaddr)
|
((insn)->next_byte + sizeof(t) + n <= (insn)->end_kaddr)
|
||||||
@ -58,6 +60,36 @@ void insn_init(struct insn *insn, const void *kaddr, int buf_len, int x86_64)
|
|||||||
insn->addr_bytes = 4;
|
insn->addr_bytes = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const insn_byte_t xen_prefix[] = { __XEN_EMULATE_PREFIX };
|
||||||
|
static const insn_byte_t kvm_prefix[] = { __KVM_EMULATE_PREFIX };
|
||||||
|
|
||||||
|
static int __insn_get_emulate_prefix(struct insn *insn,
|
||||||
|
const insn_byte_t *prefix, size_t len)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
for (i = 0; i < len; i++) {
|
||||||
|
if (peek_nbyte_next(insn_byte_t, insn, i) != prefix[i])
|
||||||
|
goto err_out;
|
||||||
|
}
|
||||||
|
|
||||||
|
insn->emulate_prefix_size = len;
|
||||||
|
insn->next_byte += len;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
err_out:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void insn_get_emulate_prefix(struct insn *insn)
|
||||||
|
{
|
||||||
|
if (__insn_get_emulate_prefix(insn, xen_prefix, sizeof(xen_prefix)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
__insn_get_emulate_prefix(insn, kvm_prefix, sizeof(kvm_prefix));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* insn_get_prefixes - scan x86 instruction prefix bytes
|
* insn_get_prefixes - scan x86 instruction prefix bytes
|
||||||
* @insn: &struct insn containing instruction
|
* @insn: &struct insn containing instruction
|
||||||
@ -76,6 +108,8 @@ void insn_get_prefixes(struct insn *insn)
|
|||||||
if (prefixes->got)
|
if (prefixes->got)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
insn_get_emulate_prefix(insn);
|
||||||
|
|
||||||
nb = 0;
|
nb = 0;
|
||||||
lb = 0;
|
lb = 0;
|
||||||
b = peek_next(insn_byte_t, insn);
|
b = peek_next(insn_byte_t, insn);
|
||||||
|
@ -142,7 +142,7 @@ void __memcpy_flushcache(void *_dst, const void *_src, size_t size)
|
|||||||
|
|
||||||
/* cache copy and flush to align dest */
|
/* cache copy and flush to align dest */
|
||||||
if (!IS_ALIGNED(dest, 8)) {
|
if (!IS_ALIGNED(dest, 8)) {
|
||||||
unsigned len = min_t(unsigned, size, ALIGN(dest, 8) - dest);
|
size_t len = min_t(size_t, size, ALIGN(dest, 8) - dest);
|
||||||
|
|
||||||
memcpy((void *) dest, (void *) source, len);
|
memcpy((void *) dest, (void *) source, len);
|
||||||
clean_cache_range((void *) dest, len);
|
clean_cache_range((void *) dest, len);
|
||||||
|
@ -442,6 +442,11 @@ void __init xen_msi_init(void)
|
|||||||
|
|
||||||
x86_msi.setup_msi_irqs = xen_hvm_setup_msi_irqs;
|
x86_msi.setup_msi_irqs = xen_hvm_setup_msi_irqs;
|
||||||
x86_msi.teardown_msi_irq = xen_teardown_msi_irq;
|
x86_msi.teardown_msi_irq = xen_teardown_msi_irq;
|
||||||
|
/*
|
||||||
|
* With XEN PIRQ/Eventchannels in use PCI/MSI[-X] masking is solely
|
||||||
|
* controlled by the hypervisor.
|
||||||
|
*/
|
||||||
|
pci_msi_ignore_mask = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include <asm/cpu.h>
|
#include <asm/cpu.h>
|
||||||
#include <asm/mmu_context.h>
|
#include <asm/mmu_context.h>
|
||||||
#include <asm/cpu_device_id.h>
|
#include <asm/cpu_device_id.h>
|
||||||
|
#include <asm/microcode.h>
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
__visible unsigned long saved_context_ebx;
|
__visible unsigned long saved_context_ebx;
|
||||||
@ -263,6 +264,13 @@ static void notrace __restore_processor_state(struct saved_context *ctxt)
|
|||||||
x86_platform.restore_sched_clock_state();
|
x86_platform.restore_sched_clock_state();
|
||||||
mtrr_bp_restore();
|
mtrr_bp_restore();
|
||||||
perf_restore_debug_store();
|
perf_restore_debug_store();
|
||||||
|
|
||||||
|
microcode_bsp_resume();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This needs to happen after the microcode has been updated upon resume
|
||||||
|
* because some of the MSRs are "emulated" in microcode.
|
||||||
|
*/
|
||||||
msr_restore_context(ctxt);
|
msr_restore_context(ctxt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,13 +10,12 @@
|
|||||||
#include <linux/msg.h>
|
#include <linux/msg.h>
|
||||||
#include <linux/shm.h>
|
#include <linux/shm.h>
|
||||||
|
|
||||||
typedef long syscall_handler_t(void);
|
typedef long syscall_handler_t(long, long, long, long, long, long);
|
||||||
|
|
||||||
extern syscall_handler_t *sys_call_table[];
|
extern syscall_handler_t *sys_call_table[];
|
||||||
|
|
||||||
#define EXECUTE_SYSCALL(syscall, regs) \
|
#define EXECUTE_SYSCALL(syscall, regs) \
|
||||||
(((long (*)(long, long, long, long, long, long)) \
|
(((*sys_call_table[syscall]))(UPT_SYSCALL_ARG1(®s->regs), \
|
||||||
(*sys_call_table[syscall]))(UPT_SYSCALL_ARG1(®s->regs), \
|
|
||||||
UPT_SYSCALL_ARG2(®s->regs), \
|
UPT_SYSCALL_ARG2(®s->regs), \
|
||||||
UPT_SYSCALL_ARG3(®s->regs), \
|
UPT_SYSCALL_ARG3(®s->regs), \
|
||||||
UPT_SYSCALL_ARG4(®s->regs), \
|
UPT_SYSCALL_ARG4(®s->regs), \
|
||||||
|
@ -53,6 +53,7 @@ static DEFINE_PER_CPU(struct xen_common_irq, xen_irq_work) = { .irq = -1 };
|
|||||||
static DEFINE_PER_CPU(struct xen_common_irq, xen_pmu_irq) = { .irq = -1 };
|
static DEFINE_PER_CPU(struct xen_common_irq, xen_pmu_irq) = { .irq = -1 };
|
||||||
|
|
||||||
static irqreturn_t xen_irq_work_interrupt(int irq, void *dev_id);
|
static irqreturn_t xen_irq_work_interrupt(int irq, void *dev_id);
|
||||||
|
void asm_cpu_bringup_and_idle(void);
|
||||||
|
|
||||||
static void cpu_bringup(void)
|
static void cpu_bringup(void)
|
||||||
{
|
{
|
||||||
@ -310,7 +311,7 @@ cpu_initialize_context(unsigned int cpu, struct task_struct *idle)
|
|||||||
* pointing just below where pt_regs would be if it were a normal
|
* pointing just below where pt_regs would be if it were a normal
|
||||||
* kernel entry.
|
* kernel entry.
|
||||||
*/
|
*/
|
||||||
ctxt->user_regs.eip = (unsigned long)cpu_bringup_and_idle;
|
ctxt->user_regs.eip = (unsigned long)asm_cpu_bringup_and_idle;
|
||||||
ctxt->flags = VGCF_IN_KERNEL;
|
ctxt->flags = VGCF_IN_KERNEL;
|
||||||
ctxt->user_regs.eflags = 0x1000; /* IOPL_RING1 */
|
ctxt->user_regs.eflags = 0x1000; /* IOPL_RING1 */
|
||||||
ctxt->user_regs.ds = __USER_DS;
|
ctxt->user_regs.ds = __USER_DS;
|
||||||
|
@ -35,7 +35,11 @@ ENTRY(startup_xen)
|
|||||||
rep __ASM_SIZE(stos)
|
rep __ASM_SIZE(stos)
|
||||||
|
|
||||||
mov %_ASM_SI, xen_start_info
|
mov %_ASM_SI, xen_start_info
|
||||||
mov $init_thread_union+THREAD_SIZE, %_ASM_SP
|
#ifdef CONFIG_X86_64
|
||||||
|
mov initial_stack(%rip), %rsp
|
||||||
|
#else
|
||||||
|
mov initial_stack, %esp
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_X86_64
|
#ifdef CONFIG_X86_64
|
||||||
/* Set up %gs.
|
/* Set up %gs.
|
||||||
@ -51,9 +55,19 @@ ENTRY(startup_xen)
|
|||||||
wrmsr
|
wrmsr
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
jmp xen_start_kernel
|
call xen_start_kernel
|
||||||
END(startup_xen)
|
END(startup_xen)
|
||||||
__FINIT
|
__FINIT
|
||||||
|
|
||||||
|
#ifdef CONFIG_XEN_PV_SMP
|
||||||
|
.pushsection .text
|
||||||
|
SYM_CODE_START(asm_cpu_bringup_and_idle)
|
||||||
|
UNWIND_HINT_EMPTY
|
||||||
|
|
||||||
|
call cpu_bringup_and_idle
|
||||||
|
SYM_CODE_END(asm_cpu_bringup_and_idle)
|
||||||
|
.popsection
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
.pushsection .text
|
.pushsection .text
|
||||||
|
@ -2251,6 +2251,9 @@ static int bfq_request_merge(struct request_queue *q, struct request **req,
|
|||||||
__rq = bfq_find_rq_fmerge(bfqd, bio, q);
|
__rq = bfq_find_rq_fmerge(bfqd, bio, q);
|
||||||
if (__rq && elv_bio_merge_ok(__rq, bio)) {
|
if (__rq && elv_bio_merge_ok(__rq, bio)) {
|
||||||
*req = __rq;
|
*req = __rq;
|
||||||
|
|
||||||
|
if (blk_discard_mergable(__rq))
|
||||||
|
return ELEVATOR_DISCARD_MERGE;
|
||||||
return ELEVATOR_FRONT_MERGE;
|
return ELEVATOR_FRONT_MERGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1625,7 +1625,7 @@ struct bio *bio_copy_kern(struct request_queue *q, void *data, unsigned int len,
|
|||||||
if (bytes > len)
|
if (bytes > len)
|
||||||
bytes = len;
|
bytes = len;
|
||||||
|
|
||||||
page = alloc_page(q->bounce_gfp | gfp_mask);
|
page = alloc_page(q->bounce_gfp | __GFP_ZERO | gfp_mask);
|
||||||
if (!page)
|
if (!page)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
@ -730,21 +730,6 @@ static void blk_account_io_merge(struct request *req)
|
|||||||
part_stat_unlock();
|
part_stat_unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
* Two cases of handling DISCARD merge:
|
|
||||||
* If max_discard_segments > 1, the driver takes every bio
|
|
||||||
* as a range and send them to controller together. The ranges
|
|
||||||
* needn't to be contiguous.
|
|
||||||
* Otherwise, the bios/requests will be handled as same as
|
|
||||||
* others which should be contiguous.
|
|
||||||
*/
|
|
||||||
static inline bool blk_discard_mergable(struct request *req)
|
|
||||||
{
|
|
||||||
if (req_op(req) == REQ_OP_DISCARD &&
|
|
||||||
queue_max_discard_segments(req->q) > 1)
|
|
||||||
return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
static enum elv_merge blk_try_req_merge(struct request *req,
|
static enum elv_merge blk_try_req_merge(struct request *req,
|
||||||
struct request *next)
|
struct request *next)
|
||||||
|
@ -337,6 +337,9 @@ enum elv_merge elv_merge(struct request_queue *q, struct request **req,
|
|||||||
__rq = elv_rqhash_find(q, bio->bi_iter.bi_sector);
|
__rq = elv_rqhash_find(q, bio->bi_iter.bi_sector);
|
||||||
if (__rq && elv_bio_merge_ok(__rq, bio)) {
|
if (__rq && elv_bio_merge_ok(__rq, bio)) {
|
||||||
*req = __rq;
|
*req = __rq;
|
||||||
|
|
||||||
|
if (blk_discard_mergable(__rq))
|
||||||
|
return ELEVATOR_DISCARD_MERGE;
|
||||||
return ELEVATOR_BACK_MERGE;
|
return ELEVATOR_BACK_MERGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -452,6 +452,8 @@ static int dd_request_merge(struct request_queue *q, struct request **rq,
|
|||||||
|
|
||||||
if (elv_bio_merge_ok(__rq, bio)) {
|
if (elv_bio_merge_ok(__rq, bio)) {
|
||||||
*rq = __rq;
|
*rq = __rq;
|
||||||
|
if (blk_discard_mergable(__rq))
|
||||||
|
return ELEVATOR_DISCARD_MERGE;
|
||||||
return ELEVATOR_FRONT_MERGE;
|
return ELEVATOR_FRONT_MERGE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -112,15 +112,15 @@ static int ecrdsa_verify(struct akcipher_request *req)
|
|||||||
|
|
||||||
/* Step 1: verify that 0 < r < q, 0 < s < q */
|
/* Step 1: verify that 0 < r < q, 0 < s < q */
|
||||||
if (vli_is_zero(r, ndigits) ||
|
if (vli_is_zero(r, ndigits) ||
|
||||||
vli_cmp(r, ctx->curve->n, ndigits) == 1 ||
|
vli_cmp(r, ctx->curve->n, ndigits) >= 0 ||
|
||||||
vli_is_zero(s, ndigits) ||
|
vli_is_zero(s, ndigits) ||
|
||||||
vli_cmp(s, ctx->curve->n, ndigits) == 1)
|
vli_cmp(s, ctx->curve->n, ndigits) >= 0)
|
||||||
return -EKEYREJECTED;
|
return -EKEYREJECTED;
|
||||||
|
|
||||||
/* Step 2: calculate hash (h) of the message (passed as input) */
|
/* Step 2: calculate hash (h) of the message (passed as input) */
|
||||||
/* Step 3: calculate e = h \mod q */
|
/* Step 3: calculate e = h \mod q */
|
||||||
vli_from_le64(e, digest, ndigits);
|
vli_from_le64(e, digest, ndigits);
|
||||||
if (vli_cmp(e, ctx->curve->n, ndigits) == 1)
|
if (vli_cmp(e, ctx->curve->n, ndigits) >= 0)
|
||||||
vli_sub(e, e, ctx->curve->n, ndigits);
|
vli_sub(e, e, ctx->curve->n, ndigits);
|
||||||
if (vli_is_zero(e, ndigits))
|
if (vli_is_zero(e, ndigits))
|
||||||
e[0] = 1;
|
e[0] = 1;
|
||||||
@ -136,7 +136,7 @@ static int ecrdsa_verify(struct akcipher_request *req)
|
|||||||
/* Step 6: calculate point C = z_1P + z_2Q, and R = x_c \mod q */
|
/* Step 6: calculate point C = z_1P + z_2Q, and R = x_c \mod q */
|
||||||
ecc_point_mult_shamir(&cc, z1, &ctx->curve->g, z2, &ctx->pub_key,
|
ecc_point_mult_shamir(&cc, z1, &ctx->curve->g, z2, &ctx->pub_key,
|
||||||
ctx->curve);
|
ctx->curve);
|
||||||
if (vli_cmp(cc.x, ctx->curve->n, ndigits) == 1)
|
if (vli_cmp(cc.x, ctx->curve->n, ndigits) >= 0)
|
||||||
vli_sub(cc.x, cc.x, ctx->curve->n, ndigits);
|
vli_sub(cc.x, cc.x, ctx->curve->n, ndigits);
|
||||||
|
|
||||||
/* Step 7: if R == r signature is valid */
|
/* Step 7: if R == r signature is valid */
|
||||||
|
@ -99,13 +99,12 @@ acpi_status acpi_ns_root_initialize(void)
|
|||||||
* just create and link the new node(s) here.
|
* just create and link the new node(s) here.
|
||||||
*/
|
*/
|
||||||
new_node =
|
new_node =
|
||||||
ACPI_ALLOCATE_ZEROED(sizeof(struct acpi_namespace_node));
|
acpi_ns_create_node(*ACPI_CAST_PTR(u32, init_val->name));
|
||||||
if (!new_node) {
|
if (!new_node) {
|
||||||
status = AE_NO_MEMORY;
|
status = AE_NO_MEMORY;
|
||||||
goto unlock_and_exit;
|
goto unlock_and_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
ACPI_COPY_NAMESEG(new_node->name.ascii, init_val->name);
|
|
||||||
new_node->descriptor_type = ACPI_DESC_TYPE_NAMED;
|
new_node->descriptor_type = ACPI_DESC_TYPE_NAMED;
|
||||||
new_node->type = init_val->type;
|
new_node->type = init_val->type;
|
||||||
|
|
||||||
|
@ -439,18 +439,29 @@ static ssize_t acpi_data_show(struct file *filp, struct kobject *kobj,
|
|||||||
{
|
{
|
||||||
struct acpi_data_attr *data_attr;
|
struct acpi_data_attr *data_attr;
|
||||||
void __iomem *base;
|
void __iomem *base;
|
||||||
ssize_t rc;
|
ssize_t size;
|
||||||
|
|
||||||
data_attr = container_of(bin_attr, struct acpi_data_attr, attr);
|
data_attr = container_of(bin_attr, struct acpi_data_attr, attr);
|
||||||
|
size = data_attr->attr.size;
|
||||||
|
|
||||||
base = acpi_os_map_memory(data_attr->addr, data_attr->attr.size);
|
if (offset < 0)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (offset >= size)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (count > size - offset)
|
||||||
|
count = size - offset;
|
||||||
|
|
||||||
|
base = acpi_os_map_iomem(data_attr->addr, size);
|
||||||
if (!base)
|
if (!base)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
rc = memory_read_from_buffer(buf, count, &offset, base,
|
|
||||||
data_attr->attr.size);
|
|
||||||
acpi_os_unmap_memory(base, data_attr->attr.size);
|
|
||||||
|
|
||||||
return rc;
|
memcpy_fromio(buf, base + offset, count);
|
||||||
|
|
||||||
|
acpi_os_unmap_iomem(base, size);
|
||||||
|
|
||||||
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int acpi_bert_data_init(void *th, struct acpi_data_attr *data_attr)
|
static int acpi_bert_data_init(void *th, struct acpi_data_attr *data_attr)
|
||||||
|
@ -487,7 +487,7 @@ void update_siblings_masks(unsigned int cpuid)
|
|||||||
for_each_online_cpu(cpu) {
|
for_each_online_cpu(cpu) {
|
||||||
cpu_topo = &cpu_topology[cpu];
|
cpu_topo = &cpu_topology[cpu];
|
||||||
|
|
||||||
if (cpuid_topo->llc_id == cpu_topo->llc_id) {
|
if (cpu_topo->llc_id != -1 && cpuid_topo->llc_id == cpu_topo->llc_id) {
|
||||||
cpumask_set_cpu(cpu, &cpuid_topo->llc_sibling);
|
cpumask_set_cpu(cpu, &cpuid_topo->llc_sibling);
|
||||||
cpumask_set_cpu(cpuid, &cpu_topo->llc_sibling);
|
cpumask_set_cpu(cpuid, &cpu_topo->llc_sibling);
|
||||||
}
|
}
|
||||||
|
@ -761,6 +761,8 @@ _request_firmware(const struct firmware **firmware_p, const char *name,
|
|||||||
enum fw_opt opt_flags)
|
enum fw_opt opt_flags)
|
||||||
{
|
{
|
||||||
struct firmware *fw = NULL;
|
struct firmware *fw = NULL;
|
||||||
|
struct cred *kern_cred = NULL;
|
||||||
|
const struct cred *old_cred;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!firmware_p)
|
if (!firmware_p)
|
||||||
@ -776,6 +778,18 @@ _request_firmware(const struct firmware **firmware_p, const char *name,
|
|||||||
if (ret <= 0) /* error or already assigned */
|
if (ret <= 0) /* error or already assigned */
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We are about to try to access the firmware file. Because we may have been
|
||||||
|
* called by a driver when serving an unrelated request from userland, we use
|
||||||
|
* the kernel credentials to read the file.
|
||||||
|
*/
|
||||||
|
kern_cred = prepare_kernel_cred(NULL);
|
||||||
|
if (!kern_cred) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
old_cred = override_creds(kern_cred);
|
||||||
|
|
||||||
ret = fw_get_filesystem_firmware(device, fw->priv, "", NULL);
|
ret = fw_get_filesystem_firmware(device, fw->priv, "", NULL);
|
||||||
#ifdef CONFIG_FW_LOADER_COMPRESS
|
#ifdef CONFIG_FW_LOADER_COMPRESS
|
||||||
if (ret == -ENOENT)
|
if (ret == -ENOENT)
|
||||||
@ -792,6 +806,9 @@ _request_firmware(const struct firmware **firmware_p, const char *name,
|
|||||||
} else
|
} else
|
||||||
ret = assign_fw(fw, device, opt_flags);
|
ret = assign_fw(fw, device, opt_flags);
|
||||||
|
|
||||||
|
revert_creds(old_cred);
|
||||||
|
put_cred(kern_cred);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
fw_abort_batch_reqs(fw);
|
fw_abort_batch_reqs(fw);
|
||||||
|
@ -39,6 +39,22 @@ config BLK_DEV_FD
|
|||||||
To compile this driver as a module, choose M here: the
|
To compile this driver as a module, choose M here: the
|
||||||
module will be called floppy.
|
module will be called floppy.
|
||||||
|
|
||||||
|
config BLK_DEV_FD_RAWCMD
|
||||||
|
bool "Support for raw floppy disk commands (DEPRECATED)"
|
||||||
|
depends on BLK_DEV_FD
|
||||||
|
help
|
||||||
|
If you want to use actual physical floppies and expect to do
|
||||||
|
special low-level hardware accesses to them (access and use
|
||||||
|
non-standard formats, for example), then enable this.
|
||||||
|
|
||||||
|
Note that the code enabled by this option is rarely used and
|
||||||
|
might be unstable or insecure, and distros should not enable it.
|
||||||
|
|
||||||
|
Note: FDRAWCMD is deprecated and will be removed from the kernel
|
||||||
|
in the near future.
|
||||||
|
|
||||||
|
If unsure, say N.
|
||||||
|
|
||||||
config AMIGA_FLOPPY
|
config AMIGA_FLOPPY
|
||||||
tristate "Amiga floppy support"
|
tristate "Amiga floppy support"
|
||||||
depends on AMIGA
|
depends on AMIGA
|
||||||
|
@ -183,7 +183,7 @@ void tl_release(struct drbd_connection *connection, unsigned int barrier_nr,
|
|||||||
unsigned int set_size)
|
unsigned int set_size)
|
||||||
{
|
{
|
||||||
struct drbd_request *r;
|
struct drbd_request *r;
|
||||||
struct drbd_request *req = NULL;
|
struct drbd_request *req = NULL, *tmp = NULL;
|
||||||
int expect_epoch = 0;
|
int expect_epoch = 0;
|
||||||
int expect_size = 0;
|
int expect_size = 0;
|
||||||
|
|
||||||
@ -237,8 +237,11 @@ void tl_release(struct drbd_connection *connection, unsigned int barrier_nr,
|
|||||||
* to catch requests being barrier-acked "unexpectedly".
|
* to catch requests being barrier-acked "unexpectedly".
|
||||||
* It usually should find the same req again, or some READ preceding it. */
|
* It usually should find the same req again, or some READ preceding it. */
|
||||||
list_for_each_entry(req, &connection->transfer_log, tl_requests)
|
list_for_each_entry(req, &connection->transfer_log, tl_requests)
|
||||||
if (req->epoch == expect_epoch)
|
if (req->epoch == expect_epoch) {
|
||||||
|
tmp = req;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
req = list_prepare_entry(tmp, &connection->transfer_log, tl_requests);
|
||||||
list_for_each_entry_safe_from(req, r, &connection->transfer_log, tl_requests) {
|
list_for_each_entry_safe_from(req, r, &connection->transfer_log, tl_requests) {
|
||||||
if (req->epoch != expect_epoch)
|
if (req->epoch != expect_epoch)
|
||||||
break;
|
break;
|
||||||
|
@ -791,9 +791,11 @@ int drbd_adm_set_role(struct sk_buff *skb, struct genl_info *info)
|
|||||||
mutex_lock(&adm_ctx.resource->adm_mutex);
|
mutex_lock(&adm_ctx.resource->adm_mutex);
|
||||||
|
|
||||||
if (info->genlhdr->cmd == DRBD_ADM_PRIMARY)
|
if (info->genlhdr->cmd == DRBD_ADM_PRIMARY)
|
||||||
retcode = drbd_set_role(adm_ctx.device, R_PRIMARY, parms.assume_uptodate);
|
retcode = (enum drbd_ret_code)drbd_set_role(adm_ctx.device,
|
||||||
|
R_PRIMARY, parms.assume_uptodate);
|
||||||
else
|
else
|
||||||
retcode = drbd_set_role(adm_ctx.device, R_SECONDARY, 0);
|
retcode = (enum drbd_ret_code)drbd_set_role(adm_ctx.device,
|
||||||
|
R_SECONDARY, 0);
|
||||||
|
|
||||||
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
||||||
genl_lock();
|
genl_lock();
|
||||||
@ -1971,7 +1973,7 @@ int drbd_adm_attach(struct sk_buff *skb, struct genl_info *info)
|
|||||||
drbd_flush_workqueue(&connection->sender_work);
|
drbd_flush_workqueue(&connection->sender_work);
|
||||||
|
|
||||||
rv = _drbd_request_state(device, NS(disk, D_ATTACHING), CS_VERBOSE);
|
rv = _drbd_request_state(device, NS(disk, D_ATTACHING), CS_VERBOSE);
|
||||||
retcode = rv; /* FIXME: Type mismatch. */
|
retcode = (enum drbd_ret_code)rv;
|
||||||
drbd_resume_io(device);
|
drbd_resume_io(device);
|
||||||
if (rv < SS_SUCCESS)
|
if (rv < SS_SUCCESS)
|
||||||
goto fail;
|
goto fail;
|
||||||
@ -2696,7 +2698,8 @@ int drbd_adm_connect(struct sk_buff *skb, struct genl_info *info)
|
|||||||
}
|
}
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
||||||
retcode = conn_request_state(connection, NS(conn, C_UNCONNECTED), CS_VERBOSE);
|
retcode = (enum drbd_ret_code)conn_request_state(connection,
|
||||||
|
NS(conn, C_UNCONNECTED), CS_VERBOSE);
|
||||||
|
|
||||||
conn_reconfig_done(connection);
|
conn_reconfig_done(connection);
|
||||||
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
||||||
@ -2809,7 +2812,7 @@ int drbd_adm_disconnect(struct sk_buff *skb, struct genl_info *info)
|
|||||||
mutex_lock(&adm_ctx.resource->adm_mutex);
|
mutex_lock(&adm_ctx.resource->adm_mutex);
|
||||||
rv = conn_try_disconnect(connection, parms.force_disconnect);
|
rv = conn_try_disconnect(connection, parms.force_disconnect);
|
||||||
if (rv < SS_SUCCESS)
|
if (rv < SS_SUCCESS)
|
||||||
retcode = rv; /* FIXME: Type mismatch. */
|
retcode = (enum drbd_ret_code)rv;
|
||||||
else
|
else
|
||||||
retcode = NO_ERROR;
|
retcode = NO_ERROR;
|
||||||
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
mutex_unlock(&adm_ctx.resource->adm_mutex);
|
||||||
|
@ -521,8 +521,8 @@ static unsigned long fdc_busy;
|
|||||||
static DECLARE_WAIT_QUEUE_HEAD(fdc_wait);
|
static DECLARE_WAIT_QUEUE_HEAD(fdc_wait);
|
||||||
static DECLARE_WAIT_QUEUE_HEAD(command_done);
|
static DECLARE_WAIT_QUEUE_HEAD(command_done);
|
||||||
|
|
||||||
/* Errors during formatting are counted here. */
|
/* errors encountered on the current (or last) request */
|
||||||
static int format_errors;
|
static int floppy_errors;
|
||||||
|
|
||||||
/* Format request descriptor. */
|
/* Format request descriptor. */
|
||||||
static struct format_descr format_req;
|
static struct format_descr format_req;
|
||||||
@ -542,7 +542,6 @@ static struct format_descr format_req;
|
|||||||
static char *floppy_track_buffer;
|
static char *floppy_track_buffer;
|
||||||
static int max_buffer_sectors;
|
static int max_buffer_sectors;
|
||||||
|
|
||||||
static int *errors;
|
|
||||||
typedef void (*done_f)(int);
|
typedef void (*done_f)(int);
|
||||||
static const struct cont_t {
|
static const struct cont_t {
|
||||||
void (*interrupt)(void);
|
void (*interrupt)(void);
|
||||||
@ -1435,7 +1434,7 @@ static int interpret_errors(void)
|
|||||||
if (DP->flags & FTD_MSG)
|
if (DP->flags & FTD_MSG)
|
||||||
DPRINT("Over/Underrun - retrying\n");
|
DPRINT("Over/Underrun - retrying\n");
|
||||||
bad = 0;
|
bad = 0;
|
||||||
} else if (*errors >= DP->max_errors.reporting) {
|
} else if (floppy_errors >= DP->max_errors.reporting) {
|
||||||
print_errors();
|
print_errors();
|
||||||
}
|
}
|
||||||
if (ST2 & ST2_WC || ST2 & ST2_BC)
|
if (ST2 & ST2_WC || ST2 & ST2_BC)
|
||||||
@ -2055,7 +2054,7 @@ static void bad_flp_intr(void)
|
|||||||
if (!next_valid_format())
|
if (!next_valid_format())
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
err_count = ++(*errors);
|
err_count = ++floppy_errors;
|
||||||
INFBOUND(DRWE->badness, err_count);
|
INFBOUND(DRWE->badness, err_count);
|
||||||
if (err_count > DP->max_errors.abort)
|
if (err_count > DP->max_errors.abort)
|
||||||
cont->done(0);
|
cont->done(0);
|
||||||
@ -2200,9 +2199,8 @@ static int do_format(int drive, struct format_descr *tmp_format_req)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
format_req = *tmp_format_req;
|
format_req = *tmp_format_req;
|
||||||
format_errors = 0;
|
|
||||||
cont = &format_cont;
|
cont = &format_cont;
|
||||||
errors = &format_errors;
|
floppy_errors = 0;
|
||||||
ret = wait_til_done(redo_format, true);
|
ret = wait_til_done(redo_format, true);
|
||||||
if (ret == -EINTR)
|
if (ret == -EINTR)
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
@ -2677,7 +2675,7 @@ static int make_raw_rw_request(void)
|
|||||||
*/
|
*/
|
||||||
if (!direct ||
|
if (!direct ||
|
||||||
(indirect * 2 > direct * 3 &&
|
(indirect * 2 > direct * 3 &&
|
||||||
*errors < DP->max_errors.read_track &&
|
floppy_errors < DP->max_errors.read_track &&
|
||||||
((!probing ||
|
((!probing ||
|
||||||
(DP->read_track & (1 << DRS->probed_format)))))) {
|
(DP->read_track & (1 << DRS->probed_format)))))) {
|
||||||
max_size = blk_rq_sectors(current_req);
|
max_size = blk_rq_sectors(current_req);
|
||||||
@ -2801,10 +2799,11 @@ static int set_next_request(void)
|
|||||||
current_req = list_first_entry_or_null(&floppy_reqs, struct request,
|
current_req = list_first_entry_or_null(&floppy_reqs, struct request,
|
||||||
queuelist);
|
queuelist);
|
||||||
if (current_req) {
|
if (current_req) {
|
||||||
current_req->error_count = 0;
|
floppy_errors = 0;
|
||||||
list_del_init(¤t_req->queuelist);
|
list_del_init(¤t_req->queuelist);
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
return current_req != NULL;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void redo_fd_request(void)
|
static void redo_fd_request(void)
|
||||||
@ -2860,7 +2859,6 @@ static void redo_fd_request(void)
|
|||||||
_floppy = floppy_type + DP->autodetect[DRS->probed_format];
|
_floppy = floppy_type + DP->autodetect[DRS->probed_format];
|
||||||
} else
|
} else
|
||||||
probing = 0;
|
probing = 0;
|
||||||
errors = &(current_req->error_count);
|
|
||||||
tmp = make_raw_rw_request();
|
tmp = make_raw_rw_request();
|
||||||
if (tmp < 2) {
|
if (tmp < 2) {
|
||||||
request_done(tmp);
|
request_done(tmp);
|
||||||
@ -3012,6 +3010,8 @@ static const char *drive_name(int type, int drive)
|
|||||||
return "(null)";
|
return "(null)";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_BLK_DEV_FD_RAWCMD
|
||||||
|
|
||||||
/* raw commands */
|
/* raw commands */
|
||||||
static void raw_cmd_done(int flag)
|
static void raw_cmd_done(int flag)
|
||||||
{
|
{
|
||||||
@ -3223,6 +3223,35 @@ static int raw_cmd_ioctl(int cmd, void __user *param)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int floppy_raw_cmd_ioctl(int type, int drive, int cmd,
|
||||||
|
void __user *param)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
pr_warn_once("Note: FDRAWCMD is deprecated and will be removed from the kernel in the near future.\n");
|
||||||
|
|
||||||
|
if (type)
|
||||||
|
return -EINVAL;
|
||||||
|
if (lock_fdc(drive))
|
||||||
|
return -EINTR;
|
||||||
|
set_floppy(drive);
|
||||||
|
ret = raw_cmd_ioctl(cmd, param);
|
||||||
|
if (ret == -EINTR)
|
||||||
|
return -EINTR;
|
||||||
|
process_fd_request();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* CONFIG_BLK_DEV_FD_RAWCMD */
|
||||||
|
|
||||||
|
static int floppy_raw_cmd_ioctl(int type, int drive, int cmd,
|
||||||
|
void __user *param)
|
||||||
|
{
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
static int invalidate_drive(struct block_device *bdev)
|
static int invalidate_drive(struct block_device *bdev)
|
||||||
{
|
{
|
||||||
/* invalidate the buffer track to force a reread */
|
/* invalidate the buffer track to force a reread */
|
||||||
@ -3410,7 +3439,6 @@ static int fd_locked_ioctl(struct block_device *bdev, fmode_t mode, unsigned int
|
|||||||
{
|
{
|
||||||
int drive = (long)bdev->bd_disk->private_data;
|
int drive = (long)bdev->bd_disk->private_data;
|
||||||
int type = ITYPE(UDRS->fd_device);
|
int type = ITYPE(UDRS->fd_device);
|
||||||
int i;
|
|
||||||
int ret;
|
int ret;
|
||||||
int size;
|
int size;
|
||||||
union inparam {
|
union inparam {
|
||||||
@ -3561,16 +3589,7 @@ static int fd_locked_ioctl(struct block_device *bdev, fmode_t mode, unsigned int
|
|||||||
outparam = UDRWE;
|
outparam = UDRWE;
|
||||||
break;
|
break;
|
||||||
case FDRAWCMD:
|
case FDRAWCMD:
|
||||||
if (type)
|
return floppy_raw_cmd_ioctl(type, drive, cmd, (void __user *)param);
|
||||||
return -EINVAL;
|
|
||||||
if (lock_fdc(drive))
|
|
||||||
return -EINTR;
|
|
||||||
set_floppy(drive);
|
|
||||||
i = raw_cmd_ioctl(cmd, (void __user *)param);
|
|
||||||
if (i == -EINTR)
|
|
||||||
return -EINTR;
|
|
||||||
process_fd_request();
|
|
||||||
return i;
|
|
||||||
case FDTWADDLE:
|
case FDTWADDLE:
|
||||||
if (lock_fdc(drive))
|
if (lock_fdc(drive))
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
|
@ -224,6 +224,8 @@ static struct sunxi_rsb_device *sunxi_rsb_device_create(struct sunxi_rsb *rsb,
|
|||||||
|
|
||||||
dev_dbg(&rdev->dev, "device %s registered\n", dev_name(&rdev->dev));
|
dev_dbg(&rdev->dev, "device %s registered\n", dev_name(&rdev->dev));
|
||||||
|
|
||||||
|
return rdev;
|
||||||
|
|
||||||
err_device_add:
|
err_device_add:
|
||||||
put_device(&rdev->dev);
|
put_device(&rdev->dev);
|
||||||
|
|
||||||
|
@ -706,7 +706,16 @@ ssize_t tpm2_get_tpm_pt(struct tpm_chip *chip, u32 property_id, u32 *value,
|
|||||||
if (!rc) {
|
if (!rc) {
|
||||||
out = (struct tpm2_get_cap_out *)
|
out = (struct tpm2_get_cap_out *)
|
||||||
&buf.data[TPM_HEADER_SIZE];
|
&buf.data[TPM_HEADER_SIZE];
|
||||||
*value = be32_to_cpu(out->value);
|
/*
|
||||||
|
* To prevent failing boot up of some systems, Infineon TPM2.0
|
||||||
|
* returns SUCCESS on TPM2_Startup in field upgrade mode. Also
|
||||||
|
* the TPM2_Getcapability command returns a zero length list
|
||||||
|
* in field upgrade mode.
|
||||||
|
*/
|
||||||
|
if (be32_to_cpu(out->property_cnt) > 0)
|
||||||
|
*value = be32_to_cpu(out->value);
|
||||||
|
else
|
||||||
|
rc = -ENODATA;
|
||||||
}
|
}
|
||||||
tpm_buf_destroy(&buf);
|
tpm_buf_destroy(&buf);
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -685,6 +685,7 @@ static int tpm_ibmvtpm_probe(struct vio_dev *vio_dev,
|
|||||||
if (!wait_event_timeout(ibmvtpm->crq_queue.wq,
|
if (!wait_event_timeout(ibmvtpm->crq_queue.wq,
|
||||||
ibmvtpm->rtce_buf != NULL,
|
ibmvtpm->rtce_buf != NULL,
|
||||||
HZ)) {
|
HZ)) {
|
||||||
|
rc = -ENODEV;
|
||||||
dev_err(dev, "CRQ response timed out\n");
|
dev_err(dev, "CRQ response timed out\n");
|
||||||
goto init_irq_cleanup;
|
goto init_irq_cleanup;
|
||||||
}
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user