Merge 6.1.47 into android14-6.1-lts
Changes in 6.1.47 mmc: sdhci-f-sdh30: Replace with sdhci_pltfm cpuidle: psci: Extend information in log about OSI/PC mode cpuidle: psci: Move enabling OSI mode after power domains creation zsmalloc: consolidate zs_pool's migrate_lock and size_class's locks zsmalloc: fix races between modifications of fullness and isolated selftests: forwarding: tc_actions: cleanup temporary files when test is aborted selftests: forwarding: tc_actions: Use ncat instead of nc net/smc: replace mutex rmbs_lock and sndbufs_lock with rw_semaphore net/smc: Fix setsockopt and sysctl to specify same buffer size again net: phy: at803x: Use devm_regulator_get_enable_optional() net: phy: at803x: fix the wol setting functions drm/amdgpu: fix calltrace warning in amddrm_buddy_fini drm/amdgpu: Fix integer overflow in amdgpu_cs_pass1 drm/amdgpu: fix memory leak in mes self test ASoC: Intel: sof_sdw: add quirk for MTL RVP ASoC: Intel: sof_sdw: add quirk for LNL RVP PCI: tegra194: Fix possible array out of bounds access ASoC: SOF: amd: Add pci revision id check drm/stm: ltdc: fix late dereference check drm: rcar-du: remove R-Car H3 ES1.* workarounds ASoC: amd: vangogh: Add check for acp config flags in vangogh platform ARM: dts: imx6dl: prtrvt, prtvt7, prti6q, prtwd2: fix USB related warnings ASoC: Intel: sof_sdw_rt_sdca_jack_common: test SOF_JACK_JDSRC in _exit ASoC: Intel: sof_sdw: Add support for Rex soundwire iopoll: Call cpu_relax() in busy loops ASoC: SOF: Intel: fix SoundWire/HDaudio mutual exclusion dma-remap: use kvmalloc_array/kvfree for larger dma memory remap accel/habanalabs: add pci health check during heartbeat HID: logitech-hidpp: Add USB and Bluetooth IDs for the Logitech G915 TKL Keyboard iommu/amd: Introduce Disable IRTE Caching Support drm/amdgpu: install stub fence into potential unused fence pointers drm/amd/display: Apply 60us prefetch for DCFCLK <= 300Mhz RDMA/mlx5: Return the firmware result upon destroying QP/RQ drm/amd/display: Skip DPP DTO update if root clock is gated drm/amd/display: Enable dcn314 DPP RCO ASoC: SOF: core: Free the firmware trace before calling snd_sof_shutdown() HID: intel-ish-hid: ipc: Add Arrow Lake PCI device ID ALSA: hda/realtek: Add quirks for ROG ALLY CS35l41 audio smb: client: fix warning in cifs_smb3_do_mount() cifs: fix session state check in reconnect to avoid use-after-free issue serial: stm32: Ignore return value of uart_remove_one_port() in .remove() led: qcom-lpg: Fix resource leaks in for_each_available_child_of_node() loops media: v4l2-mem2mem: add lock to protect parameter num_rdy media: camss: set VFE bpl_alignment to 16 for sdm845 and sm8250 usb: gadget: u_serial: Avoid spinlock recursion in __gs_console_push usb: gadget: uvc: queue empty isoc requests if no video buffer is available media: platform: mediatek: vpu: fix NULL ptr dereference thunderbolt: Read retimer NVM authentication status prior tb_retimer_set_inbound_sbtx() usb: chipidea: imx: don't request QoS for imx8ulp usb: chipidea: imx: add missing USB PHY DPDM wakeup setting gfs2: Fix possible data races in gfs2_show_options() pcmcia: rsrc_nonstatic: Fix memory leak in nonstatic_release_resource_db() thunderbolt: Add Intel Barlow Ridge PCI ID thunderbolt: Limit Intel Barlow Ridge USB3 bandwidth firewire: net: fix use after free in fwnet_finish_incoming_packet() watchdog: sp5100_tco: support Hygon FCH/SCH (Server Controller Hub) Bluetooth: L2CAP: Fix use-after-free Bluetooth: btusb: Add MT7922 bluetooth ID for the Asus Ally ceph: try to dump the msgs when decoding fails drm/amdgpu: Fix potential fence use-after-free v2 fs/ntfs3: Enhance sanity check while generating attr_list fs: ntfs3: Fix possible null-pointer dereferences in mi_read() fs/ntfs3: Mark ntfs dirty when on-disk struct is corrupted ALSA: hda/realtek: Add quirks for Unis H3C Desktop B760 & Q760 ALSA: hda: fix a possible null-pointer dereference due to data race in snd_hdac_regmap_sync() ALSA: hda/realtek: Add quirk for ASUS ROG GX650P ALSA: hda/realtek: Add quirk for ASUS ROG GA402X ALSA: hda/realtek: Add quirk for ASUS ROG GZ301V powerpc/kasan: Disable KCOV in KASAN code Bluetooth: MGMT: Use correct address for memcpy() ring-buffer: Do not swap cpu_buffer during resize process igc: read before write to SRRCTL register drm/amd/display: save restore hdcp state when display is unplugged from mst hub drm/amd/display: phase3 mst hdcp for multiple displays drm/amd/display: fix access hdcp_workqueue assert KVM: arm64: vgic-v4: Make the doorbell request robust w.r.t preemption ARM: dts: nxp/imx6sll: fix wrong property name in usbphy node fbdev/hyperv-fb: Do not set struct fb_info.apertures video/aperture: Only remove sysfb on the default vga pci device btrfs: move out now unused BG from the reclaim list btrfs: convert btrfs_block_group::needs_free_space to runtime flag btrfs: convert btrfs_block_group::seq_zone to runtime flag btrfs: fix use-after-free of new block group that became unused virtio-mmio: don't break lifecycle of vm_dev vduse: Use proper spinlock for IRQ injection vdpa/mlx5: Fix mr->initialized semantics vdpa/mlx5: Delete control vq iotlb in destroy_mr only when necessary cifs: fix potential oops in cifs_oplock_break i2c: bcm-iproc: Fix bcm_iproc_i2c_isr deadlock issue i2c: hisi: Only handle the interrupt of the driver's transfer i2c: tegra: Fix i2c-tegra DMA config option processing fbdev: mmp: fix value check in mmphw_probe() powerpc/rtas_flash: allow user copy to flash block cache objects vdpa: Add features attr to vdpa_nl_policy for nlattr length check vdpa: Add queue index attr to vdpa_nl_policy for nlattr length check vdpa: Add max vqp attr to vdpa_nl_policy for nlattr length check vdpa: Enable strict validation for netlinks ops tty: n_gsm: fix the UAF caused by race condition in gsm_cleanup_mux tty: serial: fsl_lpuart: Clear the error flags by writing 1 for lpuart32 platforms btrfs: fix incorrect splitting in btrfs_drop_extent_map_range btrfs: fix BUG_ON condition in btrfs_cancel_balance i2c: designware: Correct length byte validation logic i2c: designware: Handle invalid SMBus block data response length value net: xfrm: Fix xfrm_address_filter OOB read net: af_key: fix sadb_x_filter validation net: xfrm: Amend XFRMA_SEC_CTX nla_policy structure xfrm: fix slab-use-after-free in decode_session6 ip6_vti: fix slab-use-after-free in decode_session6 ip_vti: fix potential slab-use-after-free in decode_session6 xfrm: add NULL check in xfrm_update_ae_params xfrm: add forgotten nla_policy for XFRMA_MTIMER_THRESH virtio_net: notify MAC address change on device initialization virtio-net: set queues after driver_ok net: pcs: Add missing put_device call in miic_create net: phy: fix IRQ-based wake-on-lan over hibernate / power off selftests: mirror_gre_changes: Tighten up the TTL test match drm/panel: simple: Fix AUO G121EAN01 panel timings according to the docs net: macb: In ZynqMP resume always configure PS GTR for non-wakeup source octeon_ep: cancel tx_timeout_task later in remove sequence netfilter: nf_tables: fix false-positive lockdep splat netfilter: nf_tables: deactivate catchall elements in next generation ipvs: fix racy memcpy in proc_do_sync_threshold netfilter: nft_dynset: disallow object maps net: phy: broadcom: stub c45 read/write for 54810 team: Fix incorrect deletion of ETH_P_8021AD protocol vid from slaves net: openvswitch: reject negative ifindex iavf: fix FDIR rule fields masks validation i40e: fix misleading debug logs net: dsa: mv88e6xxx: Wait for EEPROM done before HW reset sfc: don't unregister flow_indr if it was never registered sock: Fix misuse of sk_under_memory_pressure() net: do not allow gso_size to be set to GSO_BY_FRAGS qede: fix firmware halt over suspend and resume ice: Block switchdev mode when ADQ is active and vice versa bus: ti-sysc: Flush posted write on enable before reset arm64: dts: qcom: qrb5165-rb5: fix thermal zone conflict arm64: dts: rockchip: Disable HS400 for eMMC on ROCK Pi 4 arm64: dts: rockchip: Disable HS400 for eMMC on ROCK 4C+ ARM: dts: imx: align LED node names with dtschema ARM: dts: imx6: phytec: fix RTC interrupt level arm64: dts: imx8mm: Drop CSI1 PHY reference clock configuration ARM: dts: imx: Set default tuning step for imx6sx usdhc arm64: dts: imx93: Fix anatop node size ASoC: rt5665: add missed regulator_bulk_disable ASoC: meson: axg-tdm-formatter: fix channel slot allocation ALSA: hda/realtek: Add quirks for HP G11 Laptops soc: aspeed: uart-routing: Use __sysfs_match_string soc: aspeed: socinfo: Add kfree for kstrdup ALSA: hda/realtek - Remodified 3k pull low procedure riscv: uaccess: Return the number of bytes effectively not copied serial: 8250: Fix oops for port->pm on uart_change_pm() ALSA: usb-audio: Add support for Mythware XA001AU capture and playback interfaces. cifs: Release folio lock on fscache read hit. virtio-net: Zero max_tx_vq field for VIRTIO_NET_CTRL_MQ_HASH_CONFIG case arm64: dts: rockchip: Fix Wifi/Bluetooth on ROCK Pi 4 boards blk-crypto: dynamically allocate fallback profile mmc: wbsd: fix double mmc_free_host() in wbsd_init() mmc: block: Fix in_flight[issue_type] value error drm/qxl: fix UAF on handle creation drm/i915/sdvo: fix panel_type initialization drm/amd: flush any delayed gfxoff on suspend entry drm/amdgpu: skip fence GFX interrupts disable/enable for S0ix drm/amdgpu/pm: fix throttle_status for other than MP1 11.0.7 ASoC: amd: vangogh: select CONFIG_SND_AMD_ACP_CONFIG drm/amd/display: disable RCO for DCN314 zsmalloc: allow only one active pool compaction context sched/fair: unlink misfit task from cpu overutilized sched/fair: Remove capacity inversion detection drm/amd/display: Implement workaround for writing to OTG_PIXEL_RATE_DIV register hugetlb: do not clear hugetlb dtor until allocating vmemmap netfilter: set default timeout to 3 secs for sctp shutdown send and recv state arm64/ptrace: Ensure that SME is set up for target when writing SSVE state drm/amd/pm: skip the RLC stop when S0i3 suspend for SMU v13.0.4/11 drm/amdgpu: keep irq count in amdgpu_irq_disable_all af_unix: Fix null-ptr-deref in unix_stream_sendpage(). drm/nouveau/disp: fix use-after-free in error handling of nouveau_connector_create net: fix the RTO timer retransmitting skb every 1ms if linear option is enabled mmc: f-sdh30: fix order of function calls in sdhci_f_sdh30_remove Linux 6.1.47 Change-Id: I7c55c71f43f88a1d44d39c835e3f6e58d4c86279 Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
This commit is contained in:
commit
50874c58d8
@ -323,6 +323,7 @@
|
|||||||
option with care.
|
option with care.
|
||||||
pgtbl_v1 - Use v1 page table for DMA-API (Default).
|
pgtbl_v1 - Use v1 page table for DMA-API (Default).
|
||||||
pgtbl_v2 - Use v2 page table for DMA-API.
|
pgtbl_v2 - Use v2 page table for DMA-API.
|
||||||
|
irtcachedis - Disable Interrupt Remapping Table (IRT) caching.
|
||||||
|
|
||||||
amd_iommu_dump= [HW,X86-64]
|
amd_iommu_dump= [HW,X86-64]
|
||||||
Enable AMD IOMMU driver option to dump the ACPI table
|
Enable AMD IOMMU driver option to dump the ACPI table
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
VERSION = 6
|
VERSION = 6
|
||||||
PATCHLEVEL = 1
|
PATCHLEVEL = 1
|
||||||
SUBLEVEL = 46
|
SUBLEVEL = 47
|
||||||
EXTRAVERSION =
|
EXTRAVERSION =
|
||||||
NAME = Curry Ramen
|
NAME = Curry Ramen
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ gpio-leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_leds>;
|
pinctrl-0 = <&pinctrl_leds>;
|
||||||
|
|
||||||
on {
|
led-on {
|
||||||
label = "kobo_aura:orange:on";
|
label = "kobo_aura:orange:on";
|
||||||
gpios = <&gpio6 24 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio6 24 GPIO_ACTIVE_LOW>;
|
||||||
panic-indicator;
|
panic-indicator;
|
||||||
|
@ -86,27 +86,27 @@ tfp410_out: endpoint {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
pwr-r {
|
led-pwr-r {
|
||||||
gpios = <&gpio3 22 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 22 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
pwr-g {
|
led-pwr-g {
|
||||||
gpios = <&gpio3 24 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 24 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
};
|
};
|
||||||
|
|
||||||
pwr-b {
|
led-pwr-b {
|
||||||
gpios = <&gpio3 23 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 23 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
sd1-b {
|
led-sd1-b {
|
||||||
linux,default-trigger = "mmc0";
|
linux,default-trigger = "mmc0";
|
||||||
gpios = <&gpio3 20 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 20 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
|
||||||
sd2-b {
|
led-sd2-b {
|
||||||
linux,default-trigger = "mmc1";
|
linux,default-trigger = "mmc1";
|
||||||
gpios = <&gpio3 17 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 17 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
@ -52,13 +52,13 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&led_pin_gpio>;
|
pinctrl-0 = <&led_pin_gpio>;
|
||||||
|
|
||||||
user1 {
|
led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio2 8 0>;
|
gpios = <&gpio2 8 0>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
user2 {
|
led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio2 9 0>;
|
gpios = <&gpio2 9 0>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -34,19 +34,19 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user1 {
|
led-user1 {
|
||||||
label = "TestLed601";
|
label = "TestLed601";
|
||||||
gpios = <&gpio6 1 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio6 1 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "mmc0";
|
linux,default-trigger = "mmc0";
|
||||||
};
|
};
|
||||||
|
|
||||||
user2 {
|
led-user2 {
|
||||||
label = "TestLed602";
|
label = "TestLed602";
|
||||||
gpios = <&gpio6 2 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio6 2 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
eth {
|
led-eth {
|
||||||
label = "EthLedYe";
|
label = "EthLedYe";
|
||||||
gpios = <&gpio2 11 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio2 11 GPIO_ACTIVE_LOW>;
|
||||||
linux,default-trigger = "netdev";
|
linux,default-trigger = "netdev";
|
||||||
|
@ -94,7 +94,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_stk5led>;
|
pinctrl-0 = <&pinctrl_stk5led>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "Heartbeat";
|
label = "Heartbeat";
|
||||||
gpios = <&gpio2 20 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio2 20 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -67,7 +67,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "LED";
|
label = "LED";
|
||||||
gpios = <&gpio4 27 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio4 27 GPIO_ACTIVE_LOW>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -211,17 +211,17 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_q7_gpio1 &pinctrl_q7_gpio3 &pinctrl_q7_gpio5>;
|
pinctrl-0 = <&pinctrl_q7_gpio1 &pinctrl_q7_gpio3 &pinctrl_q7_gpio5>;
|
||||||
|
|
||||||
alarm1 {
|
led-alarm1 {
|
||||||
label = "alarm:red";
|
label = "alarm:red";
|
||||||
gpios = <&gpio1 8 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio1 8 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
|
||||||
alarm2 {
|
led-alarm2 {
|
||||||
label = "alarm:yellow";
|
label = "alarm:yellow";
|
||||||
gpios = <&gpio4 27 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio4 27 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
|
||||||
alarm3 {
|
led-alarm3 {
|
||||||
label = "alarm:blue";
|
label = "alarm:blue";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio4 15 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
@ -124,6 +124,10 @@ &usbh1 {
|
|||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&usbotg {
|
||||||
|
disable-over-current;
|
||||||
|
};
|
||||||
|
|
||||||
&vpu {
|
&vpu {
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
@ -25,14 +25,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio5 2 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio5 2 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio3 28 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio3 28 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -274,7 +274,7 @@ leds: led-controller@30 {
|
|||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
|
|
||||||
chan@0 {
|
led@0 {
|
||||||
chan-name = "R";
|
chan-name = "R";
|
||||||
led-cur = /bits/ 8 <0x20>;
|
led-cur = /bits/ 8 <0x20>;
|
||||||
max-cur = /bits/ 8 <0x60>;
|
max-cur = /bits/ 8 <0x60>;
|
||||||
@ -282,7 +282,7 @@ chan@0 {
|
|||||||
color = <LED_COLOR_ID_RED>;
|
color = <LED_COLOR_ID_RED>;
|
||||||
};
|
};
|
||||||
|
|
||||||
chan@1 {
|
led@1 {
|
||||||
chan-name = "G";
|
chan-name = "G";
|
||||||
led-cur = /bits/ 8 <0x20>;
|
led-cur = /bits/ 8 <0x20>;
|
||||||
max-cur = /bits/ 8 <0x60>;
|
max-cur = /bits/ 8 <0x60>;
|
||||||
@ -290,7 +290,7 @@ chan@1 {
|
|||||||
color = <LED_COLOR_ID_GREEN>;
|
color = <LED_COLOR_ID_GREEN>;
|
||||||
};
|
};
|
||||||
|
|
||||||
chan@2 {
|
led@2 {
|
||||||
chan-name = "B";
|
chan-name = "B";
|
||||||
led-cur = /bits/ 8 <0x20>;
|
led-cur = /bits/ 8 <0x20>;
|
||||||
max-cur = /bits/ 8 <0x60>;
|
max-cur = /bits/ 8 <0x60>;
|
||||||
|
@ -34,20 +34,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* 102 -> MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* 102 -> MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>; /* 106 -> MX6_PANLEDR */
|
gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>; /* 106 -> MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* 111 -> MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* 111 -> MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -76,19 +76,19 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_h100_leds>;
|
pinctrl-0 = <&pinctrl_h100_leds>;
|
||||||
|
|
||||||
led0: power {
|
led0: led-power {
|
||||||
label = "power";
|
label = "power";
|
||||||
gpios = <&gpio3 0 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio3 0 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: stream {
|
led1: led-stream {
|
||||||
label = "stream";
|
label = "stream";
|
||||||
gpios = <&gpio2 29 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio2 29 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: rec {
|
led2: led-rec {
|
||||||
label = "rec";
|
label = "rec";
|
||||||
gpios = <&gpio2 28 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio2 28 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -66,14 +66,14 @@ lcd_panel_in: endpoint {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
green {
|
led-green {
|
||||||
label = "led1";
|
label = "led1";
|
||||||
gpios = <&gpio3 16 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 16 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "gpio";
|
linux,default-trigger = "gpio";
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
red {
|
led-red {
|
||||||
label = "led0";
|
label = "led0";
|
||||||
gpios = <&gpio3 23 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 23 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "gpio";
|
linux,default-trigger = "gpio";
|
||||||
|
@ -73,14 +73,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user1 {
|
led-user1 {
|
||||||
label = "imx6:green:user1";
|
label = "imx6:green:user1";
|
||||||
gpios = <&gpio5 2 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio5 2 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
user2 {
|
led-user2 {
|
||||||
label = "imx6:green:user2";
|
label = "imx6:green:user2";
|
||||||
gpios = <&gpio3 28 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio3 28 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -49,7 +49,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
blue {
|
led-blue {
|
||||||
label = "blue_status_led";
|
label = "blue_status_led";
|
||||||
gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "keep";
|
default-state = "keep";
|
||||||
|
@ -46,14 +46,14 @@ som_leds: leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_som_leds>;
|
pinctrl-0 = <&pinctrl_som_leds>;
|
||||||
|
|
||||||
green {
|
led-green {
|
||||||
label = "som:green";
|
label = "som:green";
|
||||||
gpios = <&gpio3 0 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 0 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
};
|
};
|
||||||
|
|
||||||
red {
|
led-red {
|
||||||
label = "som:red";
|
label = "som:red";
|
||||||
gpios = <&gpio3 1 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio3 1 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "keep";
|
default-state = "keep";
|
||||||
|
@ -71,14 +71,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -80,20 +80,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -80,20 +80,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -81,20 +81,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -115,7 +115,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio4 7 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
|
@ -72,20 +72,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -113,14 +113,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 11 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 11 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -139,20 +139,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -123,7 +123,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio6 14 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio6 14 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -120,20 +120,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -71,14 +71,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -74,20 +74,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -72,20 +72,20 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
led2: user3 {
|
led2: led-user3 {
|
||||||
label = "user3";
|
label = "user3";
|
||||||
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* MX6_LOCLED# */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -71,14 +71,14 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
led0: user1 {
|
led0: led-user1 {
|
||||||
label = "user1";
|
label = "user1";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
|
||||||
led1: user2 {
|
led1: led-user2 {
|
||||||
label = "user2";
|
label = "user2";
|
||||||
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -85,31 +85,31 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_leds>;
|
pinctrl-0 = <&pinctrl_leds>;
|
||||||
|
|
||||||
j14-pin1 {
|
led-j14-pin1 {
|
||||||
gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
j14-pin3 {
|
led-j14-pin3 {
|
||||||
gpios = <&gpio1 3 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio1 3 GPIO_ACTIVE_LOW>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
j14-pins8-9 {
|
led-j14-pins8-9 {
|
||||||
gpios = <&gpio3 29 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio3 29 GPIO_ACTIVE_LOW>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
j46-pin2 {
|
led-j46-pin2 {
|
||||||
gpios = <&gpio1 7 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio1 7 GPIO_ACTIVE_LOW>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
j46-pin3 {
|
led-j46-pin3 {
|
||||||
gpios = <&gpio1 8 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio1 8 GPIO_ACTIVE_LOW>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -181,13 +181,13 @@ i2c3mux@1 {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
speaker-enable {
|
led-speaker-enable {
|
||||||
gpios = <&gpio1 29 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio1 29 GPIO_ACTIVE_HIGH>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
ttymxc4-rs232 {
|
led-ttymxc4-rs232 {
|
||||||
gpios = <&gpio6 10 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio6 10 GPIO_ACTIVE_HIGH>;
|
||||||
retain-state-suspended;
|
retain-state-suspended;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
|
@ -25,17 +25,17 @@ gpio_leds: leds {
|
|||||||
pinctrl-0 = <&pinctrl_gpioleds>;
|
pinctrl-0 = <&pinctrl_gpioleds>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
||||||
red {
|
led-red {
|
||||||
label = "phyboard-mira:red";
|
label = "phyboard-mira:red";
|
||||||
gpios = <&gpio5 22 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 22 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
|
||||||
green {
|
led-green {
|
||||||
label = "phyboard-mira:green";
|
label = "phyboard-mira:green";
|
||||||
gpios = <&gpio5 23 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 23 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
|
||||||
blue {
|
led-blue {
|
||||||
label = "phyboard-mira:blue";
|
label = "phyboard-mira:blue";
|
||||||
gpios = <&gpio5 24 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 24 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "mmc0";
|
linux,default-trigger = "mmc0";
|
||||||
@ -182,7 +182,7 @@ i2c_rtc: rtc@68 {
|
|||||||
pinctrl-0 = <&pinctrl_rtc_int>;
|
pinctrl-0 = <&pinctrl_rtc_int>;
|
||||||
reg = <0x68>;
|
reg = <0x68>;
|
||||||
interrupt-parent = <&gpio7>;
|
interrupt-parent = <&gpio7>;
|
||||||
interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <8 IRQ_TYPE_LEVEL_LOW>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -47,12 +47,12 @@ gpio_leds: leds {
|
|||||||
pinctrl-0 = <&pinctrl_leds>;
|
pinctrl-0 = <&pinctrl_leds>;
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
led_green: green {
|
led_green: led-green {
|
||||||
label = "phyflex:green";
|
label = "phyflex:green";
|
||||||
gpios = <&gpio1 30 0>;
|
gpios = <&gpio1 30 0>;
|
||||||
};
|
};
|
||||||
|
|
||||||
led_red: red {
|
led_red: led-red {
|
||||||
label = "phyflex:red";
|
label = "phyflex:red";
|
||||||
gpios = <&gpio2 31 0>;
|
gpios = <&gpio2 31 0>;
|
||||||
};
|
};
|
||||||
|
@ -69,6 +69,7 @@ &usbh1 {
|
|||||||
vbus-supply = <®_usb_h1_vbus>;
|
vbus-supply = <®_usb_h1_vbus>;
|
||||||
phy_type = "utmi";
|
phy_type = "utmi";
|
||||||
dr_mode = "host";
|
dr_mode = "host";
|
||||||
|
disable-over-current;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -78,10 +79,18 @@ &usbotg {
|
|||||||
pinctrl-0 = <&pinctrl_usbotg>;
|
pinctrl-0 = <&pinctrl_usbotg>;
|
||||||
phy_type = "utmi";
|
phy_type = "utmi";
|
||||||
dr_mode = "host";
|
dr_mode = "host";
|
||||||
disable-over-current;
|
over-current-active-low;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&usbphynop1 {
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
|
&usbphynop2 {
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
&usdhc1 {
|
&usdhc1 {
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_usdhc1>;
|
pinctrl-0 = <&pinctrl_usdhc1>;
|
||||||
|
@ -55,7 +55,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
led0: usr {
|
led0: led-usr {
|
||||||
label = "usr";
|
label = "usr";
|
||||||
gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;
|
gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -21,7 +21,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "debug";
|
label = "debug";
|
||||||
gpios = <&gpio5 15 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 15 GPIO_ACTIVE_HIGH>;
|
||||||
};
|
};
|
||||||
|
@ -130,7 +130,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_gpio_leds>;
|
pinctrl-0 = <&pinctrl_gpio_leds>;
|
||||||
|
|
||||||
red {
|
led-red {
|
||||||
gpios = <&gpio1 2 0>;
|
gpios = <&gpio1 2 0>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
};
|
};
|
||||||
|
@ -73,13 +73,13 @@ blue-led {
|
|||||||
default-state = "off";
|
default-state = "off";
|
||||||
};
|
};
|
||||||
|
|
||||||
en-usb-5v {
|
en-usb-5v-led {
|
||||||
label = "en-usb-5v";
|
label = "en-usb-5v";
|
||||||
gpios = <&gpio2 22 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio2 22 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "on";
|
default-state = "on";
|
||||||
};
|
};
|
||||||
|
|
||||||
sel_dc_usb {
|
sel-dc-usb-led {
|
||||||
label = "sel_dc_usb";
|
label = "sel_dc_usb";
|
||||||
gpios = <&gpio5 17 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 17 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
|
@ -92,7 +92,7 @@ power {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
user_led: user {
|
user_led: led-user {
|
||||||
label = "Heartbeat";
|
label = "Heartbeat";
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_user_led>;
|
pinctrl-0 = <&pinctrl_user_led>;
|
||||||
|
@ -33,7 +33,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "debug";
|
label = "debug";
|
||||||
gpios = <&gpio3 20 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio3 20 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -37,7 +37,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "debug";
|
label = "debug";
|
||||||
gpios = <&gpio2 4 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio2 4 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -552,7 +552,7 @@ usbphy2: usb-phy@20ca000 {
|
|||||||
reg = <0x020ca000 0x1000>;
|
reg = <0x020ca000 0x1000>;
|
||||||
interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
clocks = <&clks IMX6SLL_CLK_USBPHY2>;
|
clocks = <&clks IMX6SLL_CLK_USBPHY2>;
|
||||||
phy-reg_3p0-supply = <®_3p0>;
|
phy-3p0-supply = <®_3p0>;
|
||||||
fsl,anatop = <&anatop>;
|
fsl,anatop = <&anatop>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ leds {
|
|||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
|
||||||
user {
|
led-user {
|
||||||
label = "debug";
|
label = "debug";
|
||||||
gpios = <&gpio1 24 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio1 24 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
|
@ -15,14 +15,14 @@ chosen {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
red {
|
led-red {
|
||||||
label = "udoo-neo:red:mmc";
|
label = "udoo-neo:red:mmc";
|
||||||
gpios = <&gpio6 0 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio6 0 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "off";
|
default-state = "off";
|
||||||
linux,default-trigger = "mmc0";
|
linux,default-trigger = "mmc0";
|
||||||
};
|
};
|
||||||
|
|
||||||
orange {
|
led-orange {
|
||||||
label = "udoo-neo:orange:user";
|
label = "udoo-neo:orange:user";
|
||||||
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>;
|
||||||
default-state = "keep";
|
default-state = "keep";
|
||||||
|
@ -981,6 +981,8 @@ usdhc1: mmc@2190000 {
|
|||||||
<&clks IMX6SX_CLK_USDHC1>;
|
<&clks IMX6SX_CLK_USDHC1>;
|
||||||
clock-names = "ipg", "ahb", "per";
|
clock-names = "ipg", "ahb", "per";
|
||||||
bus-width = <4>;
|
bus-width = <4>;
|
||||||
|
fsl,tuning-start-tap = <20>;
|
||||||
|
fsl,tuning-step= <2>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -993,6 +995,8 @@ usdhc2: mmc@2194000 {
|
|||||||
<&clks IMX6SX_CLK_USDHC2>;
|
<&clks IMX6SX_CLK_USDHC2>;
|
||||||
clock-names = "ipg", "ahb", "per";
|
clock-names = "ipg", "ahb", "per";
|
||||||
bus-width = <4>;
|
bus-width = <4>;
|
||||||
|
fsl,tuning-start-tap = <20>;
|
||||||
|
fsl,tuning-step= <2>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1005,6 +1009,8 @@ usdhc3: mmc@2198000 {
|
|||||||
<&clks IMX6SX_CLK_USDHC3>;
|
<&clks IMX6SX_CLK_USDHC3>;
|
||||||
clock-names = "ipg", "ahb", "per";
|
clock-names = "ipg", "ahb", "per";
|
||||||
bus-width = <4>;
|
bus-width = <4>;
|
||||||
|
fsl,tuning-start-tap = <20>;
|
||||||
|
fsl,tuning-step= <2>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ gpio_leds_som: leds {
|
|||||||
pinctrl-0 = <&pinctrl_gpioleds_som>;
|
pinctrl-0 = <&pinctrl_gpioleds_som>;
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
phycore-green {
|
led-phycore-green {
|
||||||
gpios = <&gpio5 4 GPIO_ACTIVE_HIGH>;
|
gpios = <&gpio5 4 GPIO_ACTIVE_HIGH>;
|
||||||
linux,default-trigger = "heartbeat";
|
linux,default-trigger = "heartbeat";
|
||||||
};
|
};
|
||||||
|
@ -131,7 +131,7 @@ ds1339: rtc@68 {
|
|||||||
leds {
|
leds {
|
||||||
compatible = "gpio-leds";
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
user_led: user {
|
user_led: led-user {
|
||||||
label = "Heartbeat";
|
label = "Heartbeat";
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&pinctrl_led>;
|
pinctrl-0 = <&pinctrl_led>;
|
||||||
|
@ -1145,10 +1145,9 @@ mipi_csi: mipi-csi@32e30000 {
|
|||||||
compatible = "fsl,imx8mm-mipi-csi2";
|
compatible = "fsl,imx8mm-mipi-csi2";
|
||||||
reg = <0x32e30000 0x1000>;
|
reg = <0x32e30000 0x1000>;
|
||||||
interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
|
||||||
assigned-clocks = <&clk IMX8MM_CLK_CSI1_CORE>,
|
assigned-clocks = <&clk IMX8MM_CLK_CSI1_CORE>;
|
||||||
<&clk IMX8MM_CLK_CSI1_PHY_REF>;
|
assigned-clock-parents = <&clk IMX8MM_SYS_PLL2_1000M>;
|
||||||
assigned-clock-parents = <&clk IMX8MM_SYS_PLL2_1000M>,
|
|
||||||
<&clk IMX8MM_SYS_PLL2_1000M>;
|
|
||||||
clock-frequency = <333000000>;
|
clock-frequency = <333000000>;
|
||||||
clocks = <&clk IMX8MM_CLK_DISP_APB_ROOT>,
|
clocks = <&clk IMX8MM_CLK_DISP_APB_ROOT>,
|
||||||
<&clk IMX8MM_CLK_CSI1_ROOT>,
|
<&clk IMX8MM_CLK_CSI1_ROOT>,
|
||||||
|
@ -254,7 +254,7 @@ mlmix: power-domain@44461800 {
|
|||||||
|
|
||||||
anatop: anatop@44480000 {
|
anatop: anatop@44480000 {
|
||||||
compatible = "fsl,imx93-anatop", "syscon";
|
compatible = "fsl,imx93-anatop", "syscon";
|
||||||
reg = <0x44480000 0x10000>;
|
reg = <0x44480000 0x2000>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ active-config0 {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
pm8150l-thermal {
|
pm8150l-pcb-thermal {
|
||||||
polling-delay-passive = <0>;
|
polling-delay-passive = <0>;
|
||||||
polling-delay = <0>;
|
polling-delay = <0>;
|
||||||
thermal-sensors = <&pm8150l_adc_tm 1>;
|
thermal-sensors = <&pm8150l_adc_tm 1>;
|
||||||
|
@ -548,9 +548,8 @@ &saradc {
|
|||||||
&sdhci {
|
&sdhci {
|
||||||
max-frequency = <150000000>;
|
max-frequency = <150000000>;
|
||||||
bus-width = <8>;
|
bus-width = <8>;
|
||||||
mmc-hs400-1_8v;
|
mmc-hs200-1_8v;
|
||||||
non-removable;
|
non-removable;
|
||||||
mmc-hs400-enhanced-strobe;
|
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ led-0 {
|
|||||||
sdio_pwrseq: sdio-pwrseq {
|
sdio_pwrseq: sdio-pwrseq {
|
||||||
compatible = "mmc-pwrseq-simple";
|
compatible = "mmc-pwrseq-simple";
|
||||||
clocks = <&rk808 1>;
|
clocks = <&rk808 1>;
|
||||||
clock-names = "ext_clock";
|
clock-names = "lpo";
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <&wifi_enable_h>;
|
pinctrl-0 = <&wifi_enable_h>;
|
||||||
reset-gpios = <&gpio0 RK_PB2 GPIO_ACTIVE_LOW>;
|
reset-gpios = <&gpio0 RK_PB2 GPIO_ACTIVE_LOW>;
|
||||||
@ -645,9 +645,9 @@ &saradc {
|
|||||||
};
|
};
|
||||||
|
|
||||||
&sdhci {
|
&sdhci {
|
||||||
|
max-frequency = <150000000>;
|
||||||
bus-width = <8>;
|
bus-width = <8>;
|
||||||
mmc-hs400-1_8v;
|
mmc-hs200-1_8v;
|
||||||
mmc-hs400-enhanced-strobe;
|
|
||||||
non-removable;
|
non-removable;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
};
|
};
|
||||||
|
@ -339,7 +339,7 @@ static inline int sme_max_virtualisable_vl(void)
|
|||||||
return vec_max_virtualisable_vl(ARM64_VEC_SME);
|
return vec_max_virtualisable_vl(ARM64_VEC_SME);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern void sme_alloc(struct task_struct *task);
|
extern void sme_alloc(struct task_struct *task, bool flush);
|
||||||
extern unsigned int sme_get_vl(void);
|
extern unsigned int sme_get_vl(void);
|
||||||
extern int sme_set_current_vl(unsigned long arg);
|
extern int sme_set_current_vl(unsigned long arg);
|
||||||
extern int sme_get_current_vl(void);
|
extern int sme_get_current_vl(void);
|
||||||
@ -365,7 +365,7 @@ static inline void sme_smstart_sm(void) { }
|
|||||||
static inline void sme_smstop_sm(void) { }
|
static inline void sme_smstop_sm(void) { }
|
||||||
static inline void sme_smstop(void) { }
|
static inline void sme_smstop(void) { }
|
||||||
|
|
||||||
static inline void sme_alloc(struct task_struct *task) { }
|
static inline void sme_alloc(struct task_struct *task, bool flush) { }
|
||||||
static inline void sme_setup(void) { }
|
static inline void sme_setup(void) { }
|
||||||
static inline unsigned int sme_get_vl(void) { return 0; }
|
static inline unsigned int sme_get_vl(void) { return 0; }
|
||||||
static inline int sme_max_vl(void) { return 0; }
|
static inline int sme_max_vl(void) { return 0; }
|
||||||
|
@ -704,6 +704,8 @@ struct kvm_vcpu_arch {
|
|||||||
#define SYSREGS_ON_CPU __vcpu_single_flag(sflags, BIT(4))
|
#define SYSREGS_ON_CPU __vcpu_single_flag(sflags, BIT(4))
|
||||||
/* Software step state is Active-pending */
|
/* Software step state is Active-pending */
|
||||||
#define DBG_SS_ACTIVE_PENDING __vcpu_single_flag(sflags, BIT(5))
|
#define DBG_SS_ACTIVE_PENDING __vcpu_single_flag(sflags, BIT(5))
|
||||||
|
/* WFI instruction trapped */
|
||||||
|
#define IN_WFI __vcpu_single_flag(sflags, BIT(7))
|
||||||
|
|
||||||
|
|
||||||
/* Pointer to the vcpu's SVE FFR for sve_{save,load}_state() */
|
/* Pointer to the vcpu's SVE FFR for sve_{save,load}_state() */
|
||||||
|
@ -1239,9 +1239,9 @@ void fpsimd_release_task(struct task_struct *dead_task)
|
|||||||
* the interest of testability and predictability, the architecture
|
* the interest of testability and predictability, the architecture
|
||||||
* guarantees that when ZA is enabled it will be zeroed.
|
* guarantees that when ZA is enabled it will be zeroed.
|
||||||
*/
|
*/
|
||||||
void sme_alloc(struct task_struct *task)
|
void sme_alloc(struct task_struct *task, bool flush)
|
||||||
{
|
{
|
||||||
if (task->thread.za_state) {
|
if (task->thread.za_state && flush) {
|
||||||
memset(task->thread.za_state, 0, za_state_size(task));
|
memset(task->thread.za_state, 0, za_state_size(task));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1460,7 +1460,7 @@ void do_sme_acc(unsigned long esr, struct pt_regs *regs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sve_alloc(current, false);
|
sve_alloc(current, false);
|
||||||
sme_alloc(current);
|
sme_alloc(current, true);
|
||||||
if (!current->thread.sve_state || !current->thread.za_state) {
|
if (!current->thread.sve_state || !current->thread.za_state) {
|
||||||
force_sig(SIGKILL);
|
force_sig(SIGKILL);
|
||||||
return;
|
return;
|
||||||
|
@ -886,6 +886,13 @@ static int sve_set_common(struct task_struct *target,
|
|||||||
break;
|
break;
|
||||||
case ARM64_VEC_SME:
|
case ARM64_VEC_SME:
|
||||||
target->thread.svcr |= SVCR_SM_MASK;
|
target->thread.svcr |= SVCR_SM_MASK;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Disable traps and ensure there is SME storage but
|
||||||
|
* preserve any currently set values in ZA/ZT.
|
||||||
|
*/
|
||||||
|
sme_alloc(target, false);
|
||||||
|
set_tsk_thread_flag(target, TIF_SME);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WARN_ON_ONCE(1);
|
WARN_ON_ONCE(1);
|
||||||
@ -1107,7 +1114,7 @@ static int za_set(struct task_struct *target,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Allocate/reinit ZA storage */
|
/* Allocate/reinit ZA storage */
|
||||||
sme_alloc(target);
|
sme_alloc(target, true);
|
||||||
if (!target->thread.za_state) {
|
if (!target->thread.za_state) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -430,7 +430,7 @@ static int restore_za_context(struct user_ctxs *user)
|
|||||||
fpsimd_flush_task_state(current);
|
fpsimd_flush_task_state(current);
|
||||||
/* From now, fpsimd_thread_switch() won't touch thread.sve_state */
|
/* From now, fpsimd_thread_switch() won't touch thread.sve_state */
|
||||||
|
|
||||||
sme_alloc(current);
|
sme_alloc(current, true);
|
||||||
if (!current->thread.za_state) {
|
if (!current->thread.za_state) {
|
||||||
current->thread.svcr &= ~SVCR_ZA_MASK;
|
current->thread.svcr &= ~SVCR_ZA_MASK;
|
||||||
clear_thread_flag(TIF_SME);
|
clear_thread_flag(TIF_SME);
|
||||||
|
@ -818,6 +818,8 @@ void kvm_vcpu_wfi(struct kvm_vcpu *vcpu)
|
|||||||
*/
|
*/
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
kvm_vgic_put(vcpu, true);
|
kvm_vgic_put(vcpu, true);
|
||||||
|
vcpu_set_flag(vcpu, IN_WFI);
|
||||||
|
vgic_v4_put(vcpu);
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
|
|
||||||
kvm_vcpu_halt(vcpu);
|
kvm_vcpu_halt(vcpu);
|
||||||
@ -825,6 +827,8 @@ void kvm_vcpu_wfi(struct kvm_vcpu *vcpu)
|
|||||||
|
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
kvm_vgic_load(vcpu);
|
kvm_vgic_load(vcpu);
|
||||||
|
vcpu_clear_flag(vcpu, IN_WFI);
|
||||||
|
vgic_v4_load(vcpu);
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -891,7 +895,7 @@ static int check_vcpu_requests(struct kvm_vcpu *vcpu)
|
|||||||
if (kvm_check_request(KVM_REQ_RELOAD_GICv4, vcpu)) {
|
if (kvm_check_request(KVM_REQ_RELOAD_GICv4, vcpu)) {
|
||||||
/* The distributor enable bits were changed */
|
/* The distributor enable bits were changed */
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
vgic_v4_put(vcpu, false);
|
vgic_v4_put(vcpu);
|
||||||
vgic_v4_load(vcpu);
|
vgic_v4_load(vcpu);
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
}
|
}
|
||||||
|
@ -727,7 +727,7 @@ void vgic_v3_put(struct kvm_vcpu *vcpu, bool blocking)
|
|||||||
{
|
{
|
||||||
struct vgic_v3_cpu_if *cpu_if = &vcpu->arch.vgic_cpu.vgic_v3;
|
struct vgic_v3_cpu_if *cpu_if = &vcpu->arch.vgic_cpu.vgic_v3;
|
||||||
|
|
||||||
WARN_ON(vgic_v4_put(vcpu, blocking));
|
WARN_ON(vgic_v4_put(vcpu));
|
||||||
|
|
||||||
if (likely(!is_protected_kvm_enabled()))
|
if (likely(!is_protected_kvm_enabled()))
|
||||||
kvm_call_hyp(__vgic_v3_save_vmcr_aprs, cpu_if);
|
kvm_call_hyp(__vgic_v3_save_vmcr_aprs, cpu_if);
|
||||||
|
@ -335,14 +335,14 @@ void vgic_v4_teardown(struct kvm *kvm)
|
|||||||
its_vm->vpes = NULL;
|
its_vm->vpes = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int vgic_v4_put(struct kvm_vcpu *vcpu, bool need_db)
|
int vgic_v4_put(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
struct its_vpe *vpe = &vcpu->arch.vgic_cpu.vgic_v3.its_vpe;
|
struct its_vpe *vpe = &vcpu->arch.vgic_cpu.vgic_v3.its_vpe;
|
||||||
|
|
||||||
if (!vgic_supports_direct_msis(vcpu->kvm) || !vpe->resident)
|
if (!vgic_supports_direct_msis(vcpu->kvm) || !vpe->resident)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return its_make_vpe_non_resident(vpe, need_db);
|
return its_make_vpe_non_resident(vpe, !!vcpu_get_flag(vcpu, IN_WFI));
|
||||||
}
|
}
|
||||||
|
|
||||||
int vgic_v4_load(struct kvm_vcpu *vcpu)
|
int vgic_v4_load(struct kvm_vcpu *vcpu)
|
||||||
@ -353,6 +353,9 @@ int vgic_v4_load(struct kvm_vcpu *vcpu)
|
|||||||
if (!vgic_supports_direct_msis(vcpu->kvm) || vpe->resident)
|
if (!vgic_supports_direct_msis(vcpu->kvm) || vpe->resident)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (vcpu_get_flag(vcpu, IN_WFI))
|
||||||
|
return 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Before making the VPE resident, make sure the redistributor
|
* Before making the VPE resident, make sure the redistributor
|
||||||
* corresponding to our current CPU expects us here. See the
|
* corresponding to our current CPU expects us here. See the
|
||||||
|
@ -710,9 +710,9 @@ static int __init rtas_flash_init(void)
|
|||||||
if (!rtas_validate_flash_data.buf)
|
if (!rtas_validate_flash_data.buf)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
flash_block_cache = kmem_cache_create("rtas_flash_cache",
|
flash_block_cache = kmem_cache_create_usercopy("rtas_flash_cache",
|
||||||
RTAS_BLK_SIZE, RTAS_BLK_SIZE, 0,
|
RTAS_BLK_SIZE, RTAS_BLK_SIZE,
|
||||||
NULL);
|
0, 0, RTAS_BLK_SIZE, NULL);
|
||||||
if (!flash_block_cache) {
|
if (!flash_block_cache) {
|
||||||
printk(KERN_ERR "%s: failed to create block cache\n",
|
printk(KERN_ERR "%s: failed to create block cache\n",
|
||||||
__func__);
|
__func__);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
KASAN_SANITIZE := n
|
KASAN_SANITIZE := n
|
||||||
|
KCOV_INSTRUMENT := n
|
||||||
|
|
||||||
obj-$(CONFIG_PPC32) += init_32.o
|
obj-$(CONFIG_PPC32) += init_32.o
|
||||||
obj-$(CONFIG_PPC_8xx) += 8xx.o
|
obj-$(CONFIG_PPC_8xx) += 8xx.o
|
||||||
|
@ -17,8 +17,11 @@ ENTRY(__asm_copy_from_user)
|
|||||||
li t6, SR_SUM
|
li t6, SR_SUM
|
||||||
csrs CSR_STATUS, t6
|
csrs CSR_STATUS, t6
|
||||||
|
|
||||||
/* Save for return value */
|
/*
|
||||||
mv t5, a2
|
* Save the terminal address which will be used to compute the number
|
||||||
|
* of bytes copied in case of a fixup exception.
|
||||||
|
*/
|
||||||
|
add t5, a0, a2
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Register allocation for code below:
|
* Register allocation for code below:
|
||||||
@ -176,7 +179,7 @@ ENTRY(__asm_copy_from_user)
|
|||||||
10:
|
10:
|
||||||
/* Disable access to user memory */
|
/* Disable access to user memory */
|
||||||
csrc CSR_STATUS, t6
|
csrc CSR_STATUS, t6
|
||||||
mv a0, t5
|
sub a0, t5, a0
|
||||||
ret
|
ret
|
||||||
ENDPROC(__asm_copy_to_user)
|
ENDPROC(__asm_copy_to_user)
|
||||||
ENDPROC(__asm_copy_from_user)
|
ENDPROC(__asm_copy_from_user)
|
||||||
@ -228,7 +231,7 @@ ENTRY(__clear_user)
|
|||||||
11:
|
11:
|
||||||
/* Disable access to user memory */
|
/* Disable access to user memory */
|
||||||
csrc CSR_STATUS, t6
|
csrc CSR_STATUS, t6
|
||||||
mv a0, a1
|
sub a0, a3, a0
|
||||||
ret
|
ret
|
||||||
ENDPROC(__clear_user)
|
ENDPROC(__clear_user)
|
||||||
EXPORT_SYMBOL(__clear_user)
|
EXPORT_SYMBOL(__clear_user)
|
||||||
|
@ -78,7 +78,7 @@ static struct blk_crypto_fallback_keyslot {
|
|||||||
struct crypto_skcipher *tfms[BLK_ENCRYPTION_MODE_MAX];
|
struct crypto_skcipher *tfms[BLK_ENCRYPTION_MODE_MAX];
|
||||||
} *blk_crypto_keyslots;
|
} *blk_crypto_keyslots;
|
||||||
|
|
||||||
static struct blk_crypto_profile blk_crypto_fallback_profile;
|
static struct blk_crypto_profile *blk_crypto_fallback_profile;
|
||||||
static struct workqueue_struct *blk_crypto_wq;
|
static struct workqueue_struct *blk_crypto_wq;
|
||||||
static mempool_t *blk_crypto_bounce_page_pool;
|
static mempool_t *blk_crypto_bounce_page_pool;
|
||||||
static struct bio_set crypto_bio_split;
|
static struct bio_set crypto_bio_split;
|
||||||
@ -294,7 +294,7 @@ static bool blk_crypto_fallback_encrypt_bio(struct bio **bio_ptr)
|
|||||||
* Get a blk-crypto-fallback keyslot that contains a crypto_skcipher for
|
* Get a blk-crypto-fallback keyslot that contains a crypto_skcipher for
|
||||||
* this bio's algorithm and key.
|
* this bio's algorithm and key.
|
||||||
*/
|
*/
|
||||||
blk_st = blk_crypto_get_keyslot(&blk_crypto_fallback_profile,
|
blk_st = blk_crypto_get_keyslot(blk_crypto_fallback_profile,
|
||||||
bc->bc_key, &slot);
|
bc->bc_key, &slot);
|
||||||
if (blk_st != BLK_STS_OK) {
|
if (blk_st != BLK_STS_OK) {
|
||||||
src_bio->bi_status = blk_st;
|
src_bio->bi_status = blk_st;
|
||||||
@ -397,7 +397,7 @@ static void blk_crypto_fallback_decrypt_bio(struct work_struct *work)
|
|||||||
* Get a blk-crypto-fallback keyslot that contains a crypto_skcipher for
|
* Get a blk-crypto-fallback keyslot that contains a crypto_skcipher for
|
||||||
* this bio's algorithm and key.
|
* this bio's algorithm and key.
|
||||||
*/
|
*/
|
||||||
blk_st = blk_crypto_get_keyslot(&blk_crypto_fallback_profile,
|
blk_st = blk_crypto_get_keyslot(blk_crypto_fallback_profile,
|
||||||
bc->bc_key, &slot);
|
bc->bc_key, &slot);
|
||||||
if (blk_st != BLK_STS_OK) {
|
if (blk_st != BLK_STS_OK) {
|
||||||
bio->bi_status = blk_st;
|
bio->bi_status = blk_st;
|
||||||
@ -501,7 +501,7 @@ bool blk_crypto_fallback_bio_prep(struct bio **bio_ptr)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!__blk_crypto_cfg_supported(&blk_crypto_fallback_profile,
|
if (!__blk_crypto_cfg_supported(blk_crypto_fallback_profile,
|
||||||
&bc->bc_key->crypto_cfg)) {
|
&bc->bc_key->crypto_cfg)) {
|
||||||
bio->bi_status = BLK_STS_NOTSUPP;
|
bio->bi_status = BLK_STS_NOTSUPP;
|
||||||
return false;
|
return false;
|
||||||
@ -528,7 +528,7 @@ bool blk_crypto_fallback_bio_prep(struct bio **bio_ptr)
|
|||||||
|
|
||||||
int blk_crypto_fallback_evict_key(const struct blk_crypto_key *key)
|
int blk_crypto_fallback_evict_key(const struct blk_crypto_key *key)
|
||||||
{
|
{
|
||||||
return __blk_crypto_evict_key(&blk_crypto_fallback_profile, key);
|
return __blk_crypto_evict_key(blk_crypto_fallback_profile, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool blk_crypto_fallback_inited;
|
static bool blk_crypto_fallback_inited;
|
||||||
@ -536,7 +536,6 @@ static int blk_crypto_fallback_init(void)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int err;
|
int err;
|
||||||
struct blk_crypto_profile *profile = &blk_crypto_fallback_profile;
|
|
||||||
|
|
||||||
if (blk_crypto_fallback_inited)
|
if (blk_crypto_fallback_inited)
|
||||||
return 0;
|
return 0;
|
||||||
@ -547,19 +546,28 @@ static int blk_crypto_fallback_init(void)
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
err = blk_crypto_profile_init(profile, blk_crypto_num_keyslots);
|
/* Dynamic allocation is needed because of lockdep_register_key(). */
|
||||||
if (err)
|
blk_crypto_fallback_profile =
|
||||||
|
kzalloc(sizeof(*blk_crypto_fallback_profile), GFP_KERNEL);
|
||||||
|
if (!blk_crypto_fallback_profile) {
|
||||||
|
err = -ENOMEM;
|
||||||
goto fail_free_bioset;
|
goto fail_free_bioset;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = blk_crypto_profile_init(blk_crypto_fallback_profile,
|
||||||
|
blk_crypto_num_keyslots);
|
||||||
|
if (err)
|
||||||
|
goto fail_free_profile;
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
|
|
||||||
profile->ll_ops = blk_crypto_fallback_ll_ops;
|
blk_crypto_fallback_profile->ll_ops = blk_crypto_fallback_ll_ops;
|
||||||
profile->max_dun_bytes_supported = BLK_CRYPTO_MAX_IV_SIZE;
|
blk_crypto_fallback_profile->max_dun_bytes_supported = BLK_CRYPTO_MAX_IV_SIZE;
|
||||||
profile->key_types_supported = BLK_CRYPTO_KEY_TYPE_STANDARD;
|
blk_crypto_fallback_profile->key_types_supported = BLK_CRYPTO_KEY_TYPE_STANDARD;
|
||||||
|
|
||||||
/* All blk-crypto modes have a crypto API fallback. */
|
/* All blk-crypto modes have a crypto API fallback. */
|
||||||
for (i = 0; i < BLK_ENCRYPTION_MODE_MAX; i++)
|
for (i = 0; i < BLK_ENCRYPTION_MODE_MAX; i++)
|
||||||
profile->modes_supported[i] = 0xFFFFFFFF;
|
blk_crypto_fallback_profile->modes_supported[i] = 0xFFFFFFFF;
|
||||||
profile->modes_supported[BLK_ENCRYPTION_MODE_INVALID] = 0;
|
blk_crypto_fallback_profile->modes_supported[BLK_ENCRYPTION_MODE_INVALID] = 0;
|
||||||
|
|
||||||
blk_crypto_wq = alloc_workqueue("blk_crypto_wq",
|
blk_crypto_wq = alloc_workqueue("blk_crypto_wq",
|
||||||
WQ_UNBOUND | WQ_HIGHPRI |
|
WQ_UNBOUND | WQ_HIGHPRI |
|
||||||
@ -600,7 +608,9 @@ static int blk_crypto_fallback_init(void)
|
|||||||
fail_free_wq:
|
fail_free_wq:
|
||||||
destroy_workqueue(blk_crypto_wq);
|
destroy_workqueue(blk_crypto_wq);
|
||||||
fail_destroy_profile:
|
fail_destroy_profile:
|
||||||
blk_crypto_profile_destroy(profile);
|
blk_crypto_profile_destroy(blk_crypto_fallback_profile);
|
||||||
|
fail_free_profile:
|
||||||
|
kfree(blk_crypto_fallback_profile);
|
||||||
fail_free_bioset:
|
fail_free_bioset:
|
||||||
bioset_exit(&crypto_bio_split);
|
bioset_exit(&crypto_bio_split);
|
||||||
out:
|
out:
|
||||||
|
@ -600,6 +600,9 @@ static const struct usb_device_id blacklist_table[] = {
|
|||||||
{ USB_DEVICE(0x0489, 0xe0d9), .driver_info = BTUSB_MEDIATEK |
|
{ USB_DEVICE(0x0489, 0xe0d9), .driver_info = BTUSB_MEDIATEK |
|
||||||
BTUSB_WIDEBAND_SPEECH |
|
BTUSB_WIDEBAND_SPEECH |
|
||||||
BTUSB_VALID_LE_STATES },
|
BTUSB_VALID_LE_STATES },
|
||||||
|
{ USB_DEVICE(0x0489, 0xe0f5), .driver_info = BTUSB_MEDIATEK |
|
||||||
|
BTUSB_WIDEBAND_SPEECH |
|
||||||
|
BTUSB_VALID_LE_STATES },
|
||||||
{ USB_DEVICE(0x13d3, 0x3568), .driver_info = BTUSB_MEDIATEK |
|
{ USB_DEVICE(0x13d3, 0x3568), .driver_info = BTUSB_MEDIATEK |
|
||||||
BTUSB_WIDEBAND_SPEECH |
|
BTUSB_WIDEBAND_SPEECH |
|
||||||
BTUSB_VALID_LE_STATES },
|
BTUSB_VALID_LE_STATES },
|
||||||
|
@ -2159,6 +2159,8 @@ static int sysc_reset(struct sysc *ddata)
|
|||||||
sysc_val = sysc_read_sysconfig(ddata);
|
sysc_val = sysc_read_sysconfig(ddata);
|
||||||
sysc_val |= sysc_mask;
|
sysc_val |= sysc_mask;
|
||||||
sysc_write(ddata, sysc_offset, sysc_val);
|
sysc_write(ddata, sysc_offset, sysc_val);
|
||||||
|
/* Flush posted write */
|
||||||
|
sysc_val = sysc_read_sysconfig(ddata);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ddata->cfg.srst_udelay)
|
if (ddata->cfg.srst_udelay)
|
||||||
|
@ -117,20 +117,6 @@ static void psci_pd_remove(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool psci_pd_try_set_osi_mode(void)
|
|
||||||
{
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
if (!psci_has_osi_support())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
ret = psci_set_osi_mode(true);
|
|
||||||
if (ret)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void psci_cpuidle_domain_sync_state(struct device *dev)
|
static void psci_cpuidle_domain_sync_state(struct device *dev)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@ -149,15 +135,12 @@ static int psci_cpuidle_domain_probe(struct platform_device *pdev)
|
|||||||
{
|
{
|
||||||
struct device_node *np = pdev->dev.of_node;
|
struct device_node *np = pdev->dev.of_node;
|
||||||
struct device_node *node;
|
struct device_node *node;
|
||||||
bool use_osi;
|
bool use_osi = psci_has_osi_support();
|
||||||
int ret = 0, pd_count = 0;
|
int ret = 0, pd_count = 0;
|
||||||
|
|
||||||
if (!np)
|
if (!np)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
/* If OSI mode is supported, let's try to enable it. */
|
|
||||||
use_osi = psci_pd_try_set_osi_mode();
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Parse child nodes for the "#power-domain-cells" property and
|
* Parse child nodes for the "#power-domain-cells" property and
|
||||||
* initialize a genpd/genpd-of-provider pair when it's found.
|
* initialize a genpd/genpd-of-provider pair when it's found.
|
||||||
@ -167,32 +150,37 @@ static int psci_cpuidle_domain_probe(struct platform_device *pdev)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
ret = psci_pd_init(node, use_osi);
|
ret = psci_pd_init(node, use_osi);
|
||||||
if (ret)
|
if (ret) {
|
||||||
goto put_node;
|
of_node_put(node);
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
pd_count++;
|
pd_count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Bail out if not using the hierarchical CPU topology. */
|
/* Bail out if not using the hierarchical CPU topology. */
|
||||||
if (!pd_count)
|
if (!pd_count)
|
||||||
goto no_pd;
|
return 0;
|
||||||
|
|
||||||
/* Link genpd masters/subdomains to model the CPU topology. */
|
/* Link genpd masters/subdomains to model the CPU topology. */
|
||||||
ret = dt_idle_pd_init_topology(np);
|
ret = dt_idle_pd_init_topology(np);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto remove_pd;
|
goto remove_pd;
|
||||||
|
|
||||||
pr_info("Initialized CPU PM domain topology\n");
|
/* let's try to enable OSI. */
|
||||||
|
ret = psci_set_osi_mode(use_osi);
|
||||||
|
if (ret)
|
||||||
|
goto remove_pd;
|
||||||
|
|
||||||
|
pr_info("Initialized CPU PM domain topology using %s mode\n",
|
||||||
|
use_osi ? "OSI" : "PC");
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
put_node:
|
|
||||||
of_node_put(node);
|
|
||||||
remove_pd:
|
remove_pd:
|
||||||
|
dt_idle_pd_remove_topology(np);
|
||||||
psci_pd_remove();
|
psci_pd_remove();
|
||||||
|
exit:
|
||||||
pr_err("failed to create CPU PM domains ret=%d\n", ret);
|
pr_err("failed to create CPU PM domains ret=%d\n", ret);
|
||||||
no_pd:
|
|
||||||
if (use_osi)
|
|
||||||
psci_set_osi_mode(false);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -479,7 +479,7 @@ static int fwnet_finish_incoming_packet(struct net_device *net,
|
|||||||
struct sk_buff *skb, u16 source_node_id,
|
struct sk_buff *skb, u16 source_node_id,
|
||||||
bool is_broadcast, u16 ether_type)
|
bool is_broadcast, u16 ether_type)
|
||||||
{
|
{
|
||||||
int status;
|
int status, len;
|
||||||
|
|
||||||
switch (ether_type) {
|
switch (ether_type) {
|
||||||
case ETH_P_ARP:
|
case ETH_P_ARP:
|
||||||
@ -533,13 +533,15 @@ static int fwnet_finish_incoming_packet(struct net_device *net,
|
|||||||
}
|
}
|
||||||
skb->protocol = protocol;
|
skb->protocol = protocol;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
len = skb->len;
|
||||||
status = netif_rx(skb);
|
status = netif_rx(skb);
|
||||||
if (status == NET_RX_DROP) {
|
if (status == NET_RX_DROP) {
|
||||||
net->stats.rx_errors++;
|
net->stats.rx_errors++;
|
||||||
net->stats.rx_dropped++;
|
net->stats.rx_dropped++;
|
||||||
} else {
|
} else {
|
||||||
net->stats.rx_packets++;
|
net->stats.rx_packets++;
|
||||||
net->stats.rx_bytes += skb->len;
|
net->stats.rx_bytes += len;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -185,7 +185,7 @@ static int amdgpu_cs_pass1(struct amdgpu_cs_parser *p,
|
|||||||
uint64_t *chunk_array_user;
|
uint64_t *chunk_array_user;
|
||||||
uint64_t *chunk_array;
|
uint64_t *chunk_array;
|
||||||
uint32_t uf_offset = 0;
|
uint32_t uf_offset = 0;
|
||||||
unsigned int size;
|
size_t size;
|
||||||
int ret;
|
int ret;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -1607,15 +1607,15 @@ static int amdgpu_cs_wait_all_fences(struct amdgpu_device *adev,
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
r = dma_fence_wait_timeout(fence, true, timeout);
|
r = dma_fence_wait_timeout(fence, true, timeout);
|
||||||
|
if (r > 0 && fence->error)
|
||||||
|
r = fence->error;
|
||||||
|
|
||||||
dma_fence_put(fence);
|
dma_fence_put(fence);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
if (r == 0)
|
if (r == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (fence->error)
|
|
||||||
return fence->error;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
memset(wait, 0, sizeof(*wait));
|
memset(wait, 0, sizeof(*wait));
|
||||||
|
@ -4232,6 +4232,7 @@ int amdgpu_device_suspend(struct drm_device *dev, bool fbcon)
|
|||||||
drm_fb_helper_set_suspend_unlocked(adev_to_drm(adev)->fb_helper, true);
|
drm_fb_helper_set_suspend_unlocked(adev_to_drm(adev)->fb_helper, true);
|
||||||
|
|
||||||
cancel_delayed_work_sync(&adev->delayed_init_work);
|
cancel_delayed_work_sync(&adev->delayed_init_work);
|
||||||
|
flush_delayed_work(&adev->gfx.gfx_off_delay_work);
|
||||||
|
|
||||||
amdgpu_ras_suspend(adev);
|
amdgpu_ras_suspend(adev);
|
||||||
|
|
||||||
|
@ -501,6 +501,41 @@ int amdgpu_fence_driver_sw_init(struct amdgpu_device *adev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* amdgpu_fence_need_ring_interrupt_restore - helper function to check whether
|
||||||
|
* fence driver interrupts need to be restored.
|
||||||
|
*
|
||||||
|
* @ring: ring that to be checked
|
||||||
|
*
|
||||||
|
* Interrupts for rings that belong to GFX IP don't need to be restored
|
||||||
|
* when the target power state is s0ix.
|
||||||
|
*
|
||||||
|
* Return true if need to restore interrupts, false otherwise.
|
||||||
|
*/
|
||||||
|
static bool amdgpu_fence_need_ring_interrupt_restore(struct amdgpu_ring *ring)
|
||||||
|
{
|
||||||
|
struct amdgpu_device *adev = ring->adev;
|
||||||
|
bool is_gfx_power_domain = false;
|
||||||
|
|
||||||
|
switch (ring->funcs->type) {
|
||||||
|
case AMDGPU_RING_TYPE_SDMA:
|
||||||
|
/* SDMA 5.x+ is part of GFX power domain so it's covered by GFXOFF */
|
||||||
|
if (adev->ip_versions[SDMA0_HWIP][0] >= IP_VERSION(5, 0, 0))
|
||||||
|
is_gfx_power_domain = true;
|
||||||
|
break;
|
||||||
|
case AMDGPU_RING_TYPE_GFX:
|
||||||
|
case AMDGPU_RING_TYPE_COMPUTE:
|
||||||
|
case AMDGPU_RING_TYPE_KIQ:
|
||||||
|
case AMDGPU_RING_TYPE_MES:
|
||||||
|
is_gfx_power_domain = true;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return !(adev->in_s0ix && is_gfx_power_domain);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* amdgpu_fence_driver_hw_fini - tear down the fence driver
|
* amdgpu_fence_driver_hw_fini - tear down the fence driver
|
||||||
* for all possible rings.
|
* for all possible rings.
|
||||||
@ -529,7 +564,8 @@ void amdgpu_fence_driver_hw_fini(struct amdgpu_device *adev)
|
|||||||
amdgpu_fence_driver_force_completion(ring);
|
amdgpu_fence_driver_force_completion(ring);
|
||||||
|
|
||||||
if (!drm_dev_is_unplugged(adev_to_drm(adev)) &&
|
if (!drm_dev_is_unplugged(adev_to_drm(adev)) &&
|
||||||
ring->fence_drv.irq_src)
|
ring->fence_drv.irq_src &&
|
||||||
|
amdgpu_fence_need_ring_interrupt_restore(ring))
|
||||||
amdgpu_irq_put(adev, ring->fence_drv.irq_src,
|
amdgpu_irq_put(adev, ring->fence_drv.irq_src,
|
||||||
ring->fence_drv.irq_type);
|
ring->fence_drv.irq_type);
|
||||||
|
|
||||||
@ -604,7 +640,8 @@ void amdgpu_fence_driver_hw_init(struct amdgpu_device *adev)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* enable the interrupt */
|
/* enable the interrupt */
|
||||||
if (ring->fence_drv.irq_src)
|
if (ring->fence_drv.irq_src &&
|
||||||
|
amdgpu_fence_need_ring_interrupt_restore(ring))
|
||||||
amdgpu_irq_get(adev, ring->fence_drv.irq_src,
|
amdgpu_irq_get(adev, ring->fence_drv.irq_src,
|
||||||
ring->fence_drv.irq_type);
|
ring->fence_drv.irq_type);
|
||||||
}
|
}
|
||||||
|
@ -585,15 +585,8 @@ void amdgpu_gfx_off_ctrl(struct amdgpu_device *adev, bool enable)
|
|||||||
|
|
||||||
if (adev->gfx.gfx_off_req_count == 0 &&
|
if (adev->gfx.gfx_off_req_count == 0 &&
|
||||||
!adev->gfx.gfx_off_state) {
|
!adev->gfx.gfx_off_state) {
|
||||||
/* If going to s2idle, no need to wait */
|
schedule_delayed_work(&adev->gfx.gfx_off_delay_work,
|
||||||
if (adev->in_s0ix) {
|
|
||||||
if (!amdgpu_dpm_set_powergating_by_smu(adev,
|
|
||||||
AMD_IP_BLOCK_TYPE_GFX, true))
|
|
||||||
adev->gfx.gfx_off_state = true;
|
|
||||||
} else {
|
|
||||||
schedule_delayed_work(&adev->gfx.gfx_off_delay_work,
|
|
||||||
delay);
|
delay);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (adev->gfx.gfx_off_req_count == 0) {
|
if (adev->gfx.gfx_off_req_count == 0) {
|
||||||
|
@ -160,7 +160,6 @@ void amdgpu_irq_disable_all(struct amdgpu_device *adev)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
for (k = 0; k < src->num_types; ++k) {
|
for (k = 0; k < src->num_types; ++k) {
|
||||||
atomic_set(&src->enabled_types[k], 0);
|
|
||||||
r = src->funcs->set(adev, src, k,
|
r = src->funcs->set(adev, src, k,
|
||||||
AMDGPU_IRQ_STATE_DISABLE);
|
AMDGPU_IRQ_STATE_DISABLE);
|
||||||
if (r)
|
if (r)
|
||||||
|
@ -514,6 +514,8 @@ static int psp_sw_fini(void *handle)
|
|||||||
kfree(cmd);
|
kfree(cmd);
|
||||||
cmd = NULL;
|
cmd = NULL;
|
||||||
|
|
||||||
|
psp_free_shared_bufs(psp);
|
||||||
|
|
||||||
if (psp->km_ring.ring_mem)
|
if (psp->km_ring.ring_mem)
|
||||||
amdgpu_bo_free_kernel(&adev->firmware.rbuf,
|
amdgpu_bo_free_kernel(&adev->firmware.rbuf,
|
||||||
&psp->km_ring.ring_mem_mc_addr,
|
&psp->km_ring.ring_mem_mc_addr,
|
||||||
@ -2673,8 +2675,6 @@ static int psp_hw_fini(void *handle)
|
|||||||
|
|
||||||
psp_ring_destroy(psp, PSP_RING_TYPE__KM);
|
psp_ring_destroy(psp, PSP_RING_TYPE__KM);
|
||||||
|
|
||||||
psp_free_shared_bufs(psp);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -361,6 +361,8 @@ void amdgpu_ring_fini(struct amdgpu_ring *ring)
|
|||||||
amdgpu_bo_free_kernel(&ring->ring_obj,
|
amdgpu_bo_free_kernel(&ring->ring_obj,
|
||||||
&ring->gpu_addr,
|
&ring->gpu_addr,
|
||||||
(void **)&ring->ring);
|
(void **)&ring->ring);
|
||||||
|
} else {
|
||||||
|
kfree(ring->fence_drv.fences);
|
||||||
}
|
}
|
||||||
|
|
||||||
dma_fence_put(ring->vmid_wait);
|
dma_fence_put(ring->vmid_wait);
|
||||||
|
@ -1352,6 +1352,7 @@ struct amdgpu_bo_va *amdgpu_vm_bo_add(struct amdgpu_device *adev,
|
|||||||
amdgpu_vm_bo_base_init(&bo_va->base, vm, bo);
|
amdgpu_vm_bo_base_init(&bo_va->base, vm, bo);
|
||||||
|
|
||||||
bo_va->ref_count = 1;
|
bo_va->ref_count = 1;
|
||||||
|
bo_va->last_pt_update = dma_fence_get_stub();
|
||||||
INIT_LIST_HEAD(&bo_va->valids);
|
INIT_LIST_HEAD(&bo_va->valids);
|
||||||
INIT_LIST_HEAD(&bo_va->invalids);
|
INIT_LIST_HEAD(&bo_va->invalids);
|
||||||
|
|
||||||
@ -2073,7 +2074,8 @@ int amdgpu_vm_init(struct amdgpu_device *adev, struct amdgpu_vm *vm)
|
|||||||
vm->update_funcs = &amdgpu_vm_cpu_funcs;
|
vm->update_funcs = &amdgpu_vm_cpu_funcs;
|
||||||
else
|
else
|
||||||
vm->update_funcs = &amdgpu_vm_sdma_funcs;
|
vm->update_funcs = &amdgpu_vm_sdma_funcs;
|
||||||
vm->last_update = NULL;
|
|
||||||
|
vm->last_update = dma_fence_get_stub();
|
||||||
vm->last_unlocked = dma_fence_get_stub();
|
vm->last_unlocked = dma_fence_get_stub();
|
||||||
vm->last_tlb_flush = dma_fence_get_stub();
|
vm->last_tlb_flush = dma_fence_get_stub();
|
||||||
|
|
||||||
@ -2198,7 +2200,7 @@ int amdgpu_vm_make_compute(struct amdgpu_device *adev, struct amdgpu_vm *vm)
|
|||||||
goto unreserve_bo;
|
goto unreserve_bo;
|
||||||
|
|
||||||
dma_fence_put(vm->last_update);
|
dma_fence_put(vm->last_update);
|
||||||
vm->last_update = NULL;
|
vm->last_update = dma_fence_get_stub();
|
||||||
vm->is_compute_context = true;
|
vm->is_compute_context = true;
|
||||||
|
|
||||||
/* Free the shadow bo for compute VM */
|
/* Free the shadow bo for compute VM */
|
||||||
|
@ -7397,27 +7397,55 @@ is_scaling_state_different(const struct dm_connector_state *dm_state,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_DRM_AMD_DC_HDCP
|
#ifdef CONFIG_DRM_AMD_DC_HDCP
|
||||||
static bool is_content_protection_different(struct drm_connector_state *state,
|
static bool is_content_protection_different(struct drm_crtc_state *new_crtc_state,
|
||||||
const struct drm_connector_state *old_state,
|
struct drm_crtc_state *old_crtc_state,
|
||||||
const struct drm_connector *connector, struct hdcp_workqueue *hdcp_w)
|
struct drm_connector_state *new_conn_state,
|
||||||
|
struct drm_connector_state *old_conn_state,
|
||||||
|
const struct drm_connector *connector,
|
||||||
|
struct hdcp_workqueue *hdcp_w)
|
||||||
{
|
{
|
||||||
struct amdgpu_dm_connector *aconnector = to_amdgpu_dm_connector(connector);
|
struct amdgpu_dm_connector *aconnector = to_amdgpu_dm_connector(connector);
|
||||||
struct dm_connector_state *dm_con_state = to_dm_connector_state(connector->state);
|
struct dm_connector_state *dm_con_state = to_dm_connector_state(connector->state);
|
||||||
|
|
||||||
/* Handle: Type0/1 change */
|
pr_debug("[HDCP_DM] connector->index: %x connect_status: %x dpms: %x\n",
|
||||||
if (old_state->hdcp_content_type != state->hdcp_content_type &&
|
connector->index, connector->status, connector->dpms);
|
||||||
state->content_protection != DRM_MODE_CONTENT_PROTECTION_UNDESIRED) {
|
pr_debug("[HDCP_DM] state protection old: %x new: %x\n",
|
||||||
state->content_protection = DRM_MODE_CONTENT_PROTECTION_DESIRED;
|
old_conn_state->content_protection, new_conn_state->content_protection);
|
||||||
|
|
||||||
|
if (old_crtc_state)
|
||||||
|
pr_debug("[HDCP_DM] old crtc en: %x a: %x m: %x a-chg: %x c-chg: %x\n",
|
||||||
|
old_crtc_state->enable,
|
||||||
|
old_crtc_state->active,
|
||||||
|
old_crtc_state->mode_changed,
|
||||||
|
old_crtc_state->active_changed,
|
||||||
|
old_crtc_state->connectors_changed);
|
||||||
|
|
||||||
|
if (new_crtc_state)
|
||||||
|
pr_debug("[HDCP_DM] NEW crtc en: %x a: %x m: %x a-chg: %x c-chg: %x\n",
|
||||||
|
new_crtc_state->enable,
|
||||||
|
new_crtc_state->active,
|
||||||
|
new_crtc_state->mode_changed,
|
||||||
|
new_crtc_state->active_changed,
|
||||||
|
new_crtc_state->connectors_changed);
|
||||||
|
|
||||||
|
/* hdcp content type change */
|
||||||
|
if (old_conn_state->hdcp_content_type != new_conn_state->hdcp_content_type &&
|
||||||
|
new_conn_state->content_protection != DRM_MODE_CONTENT_PROTECTION_UNDESIRED) {
|
||||||
|
new_conn_state->content_protection = DRM_MODE_CONTENT_PROTECTION_DESIRED;
|
||||||
|
pr_debug("[HDCP_DM] Type0/1 change %s :true\n", __func__);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* CP is being re enabled, ignore this
|
/* CP is being re enabled, ignore this */
|
||||||
*
|
if (old_conn_state->content_protection == DRM_MODE_CONTENT_PROTECTION_ENABLED &&
|
||||||
* Handles: ENABLED -> DESIRED
|
new_conn_state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED) {
|
||||||
*/
|
if (new_crtc_state && new_crtc_state->mode_changed) {
|
||||||
if (old_state->content_protection == DRM_MODE_CONTENT_PROTECTION_ENABLED &&
|
new_conn_state->content_protection = DRM_MODE_CONTENT_PROTECTION_DESIRED;
|
||||||
state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED) {
|
pr_debug("[HDCP_DM] ENABLED->DESIRED & mode_changed %s :true\n", __func__);
|
||||||
state->content_protection = DRM_MODE_CONTENT_PROTECTION_ENABLED;
|
return true;
|
||||||
|
};
|
||||||
|
new_conn_state->content_protection = DRM_MODE_CONTENT_PROTECTION_ENABLED;
|
||||||
|
pr_debug("[HDCP_DM] ENABLED -> DESIRED %s :false\n", __func__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -7425,9 +7453,9 @@ static bool is_content_protection_different(struct drm_connector_state *state,
|
|||||||
*
|
*
|
||||||
* Handles: UNDESIRED -> ENABLED
|
* Handles: UNDESIRED -> ENABLED
|
||||||
*/
|
*/
|
||||||
if (old_state->content_protection == DRM_MODE_CONTENT_PROTECTION_UNDESIRED &&
|
if (old_conn_state->content_protection == DRM_MODE_CONTENT_PROTECTION_UNDESIRED &&
|
||||||
state->content_protection == DRM_MODE_CONTENT_PROTECTION_ENABLED)
|
new_conn_state->content_protection == DRM_MODE_CONTENT_PROTECTION_ENABLED)
|
||||||
state->content_protection = DRM_MODE_CONTENT_PROTECTION_DESIRED;
|
new_conn_state->content_protection = DRM_MODE_CONTENT_PROTECTION_DESIRED;
|
||||||
|
|
||||||
/* Stream removed and re-enabled
|
/* Stream removed and re-enabled
|
||||||
*
|
*
|
||||||
@ -7437,10 +7465,12 @@ static bool is_content_protection_different(struct drm_connector_state *state,
|
|||||||
*
|
*
|
||||||
* Handles: DESIRED -> DESIRED (Special case)
|
* Handles: DESIRED -> DESIRED (Special case)
|
||||||
*/
|
*/
|
||||||
if (!(old_state->crtc && old_state->crtc->enabled) &&
|
if (!(old_conn_state->crtc && old_conn_state->crtc->enabled) &&
|
||||||
state->crtc && state->crtc->enabled &&
|
new_conn_state->crtc && new_conn_state->crtc->enabled &&
|
||||||
connector->state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED) {
|
connector->state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED) {
|
||||||
dm_con_state->update_hdcp = false;
|
dm_con_state->update_hdcp = false;
|
||||||
|
pr_debug("[HDCP_DM] DESIRED->DESIRED (Stream removed and re-enabled) %s :true\n",
|
||||||
|
__func__);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -7452,35 +7482,42 @@ static bool is_content_protection_different(struct drm_connector_state *state,
|
|||||||
*
|
*
|
||||||
* Handles: DESIRED -> DESIRED (Special case)
|
* Handles: DESIRED -> DESIRED (Special case)
|
||||||
*/
|
*/
|
||||||
if (dm_con_state->update_hdcp && state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED &&
|
if (dm_con_state->update_hdcp &&
|
||||||
connector->dpms == DRM_MODE_DPMS_ON && aconnector->dc_sink != NULL) {
|
new_conn_state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED &&
|
||||||
|
connector->dpms == DRM_MODE_DPMS_ON && aconnector->dc_sink != NULL) {
|
||||||
dm_con_state->update_hdcp = false;
|
dm_con_state->update_hdcp = false;
|
||||||
|
pr_debug("[HDCP_DM] DESIRED->DESIRED (Hot-plug, headless s3, dpms) %s :true\n",
|
||||||
|
__func__);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
if (old_conn_state->content_protection == new_conn_state->content_protection) {
|
||||||
* Handles: UNDESIRED -> UNDESIRED
|
if (new_conn_state->content_protection >= DRM_MODE_CONTENT_PROTECTION_DESIRED) {
|
||||||
* DESIRED -> DESIRED
|
if (new_crtc_state && new_crtc_state->mode_changed) {
|
||||||
* ENABLED -> ENABLED
|
pr_debug("[HDCP_DM] DESIRED->DESIRED or ENABLE->ENABLE mode_change %s :true\n",
|
||||||
*/
|
__func__);
|
||||||
if (old_state->content_protection == state->content_protection)
|
return true;
|
||||||
|
};
|
||||||
|
pr_debug("[HDCP_DM] DESIRED->DESIRED & ENABLE->ENABLE %s :false\n",
|
||||||
|
__func__);
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
pr_debug("[HDCP_DM] UNDESIRED->UNDESIRED %s :false\n", __func__);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
if (new_conn_state->content_protection != DRM_MODE_CONTENT_PROTECTION_ENABLED) {
|
||||||
* Handles: UNDESIRED -> DESIRED
|
pr_debug("[HDCP_DM] UNDESIRED->DESIRED or DESIRED->UNDESIRED or ENABLED->UNDESIRED %s :true\n",
|
||||||
* DESIRED -> UNDESIRED
|
__func__);
|
||||||
* ENABLED -> UNDESIRED
|
|
||||||
*/
|
|
||||||
if (state->content_protection != DRM_MODE_CONTENT_PROTECTION_ENABLED)
|
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
pr_debug("[HDCP_DM] DESIRED->ENABLED %s :false\n", __func__);
|
||||||
* Handles: DESIRED -> ENABLED
|
|
||||||
*/
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void remove_stream(struct amdgpu_device *adev,
|
static void remove_stream(struct amdgpu_device *adev,
|
||||||
struct amdgpu_crtc *acrtc,
|
struct amdgpu_crtc *acrtc,
|
||||||
struct dc_stream_state *stream)
|
struct dc_stream_state *stream)
|
||||||
@ -8335,10 +8372,67 @@ static void amdgpu_dm_atomic_commit_tail(struct drm_atomic_state *state)
|
|||||||
struct amdgpu_crtc *acrtc = to_amdgpu_crtc(dm_new_con_state->base.crtc);
|
struct amdgpu_crtc *acrtc = to_amdgpu_crtc(dm_new_con_state->base.crtc);
|
||||||
struct amdgpu_dm_connector *aconnector = to_amdgpu_dm_connector(connector);
|
struct amdgpu_dm_connector *aconnector = to_amdgpu_dm_connector(connector);
|
||||||
|
|
||||||
new_crtc_state = NULL;
|
if (!adev->dm.hdcp_workqueue)
|
||||||
|
continue;
|
||||||
|
|
||||||
if (acrtc)
|
pr_debug("[HDCP_DM] -------------- i : %x ----------\n", i);
|
||||||
|
|
||||||
|
if (!connector)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
pr_debug("[HDCP_DM] connector->index: %x connect_status: %x dpms: %x\n",
|
||||||
|
connector->index, connector->status, connector->dpms);
|
||||||
|
pr_debug("[HDCP_DM] state protection old: %x new: %x\n",
|
||||||
|
old_con_state->content_protection, new_con_state->content_protection);
|
||||||
|
|
||||||
|
if (aconnector->dc_sink) {
|
||||||
|
if (aconnector->dc_sink->sink_signal != SIGNAL_TYPE_VIRTUAL &&
|
||||||
|
aconnector->dc_sink->sink_signal != SIGNAL_TYPE_NONE) {
|
||||||
|
pr_debug("[HDCP_DM] pipe_ctx dispname=%s\n",
|
||||||
|
aconnector->dc_sink->edid_caps.display_name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
new_crtc_state = NULL;
|
||||||
|
old_crtc_state = NULL;
|
||||||
|
|
||||||
|
if (acrtc) {
|
||||||
new_crtc_state = drm_atomic_get_new_crtc_state(state, &acrtc->base);
|
new_crtc_state = drm_atomic_get_new_crtc_state(state, &acrtc->base);
|
||||||
|
old_crtc_state = drm_atomic_get_old_crtc_state(state, &acrtc->base);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (old_crtc_state)
|
||||||
|
pr_debug("old crtc en: %x a: %x m: %x a-chg: %x c-chg: %x\n",
|
||||||
|
old_crtc_state->enable,
|
||||||
|
old_crtc_state->active,
|
||||||
|
old_crtc_state->mode_changed,
|
||||||
|
old_crtc_state->active_changed,
|
||||||
|
old_crtc_state->connectors_changed);
|
||||||
|
|
||||||
|
if (new_crtc_state)
|
||||||
|
pr_debug("NEW crtc en: %x a: %x m: %x a-chg: %x c-chg: %x\n",
|
||||||
|
new_crtc_state->enable,
|
||||||
|
new_crtc_state->active,
|
||||||
|
new_crtc_state->mode_changed,
|
||||||
|
new_crtc_state->active_changed,
|
||||||
|
new_crtc_state->connectors_changed);
|
||||||
|
}
|
||||||
|
|
||||||
|
for_each_oldnew_connector_in_state(state, connector, old_con_state, new_con_state, i) {
|
||||||
|
struct dm_connector_state *dm_new_con_state = to_dm_connector_state(new_con_state);
|
||||||
|
struct amdgpu_crtc *acrtc = to_amdgpu_crtc(dm_new_con_state->base.crtc);
|
||||||
|
struct amdgpu_dm_connector *aconnector = to_amdgpu_dm_connector(connector);
|
||||||
|
|
||||||
|
if (!adev->dm.hdcp_workqueue)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
new_crtc_state = NULL;
|
||||||
|
old_crtc_state = NULL;
|
||||||
|
|
||||||
|
if (acrtc) {
|
||||||
|
new_crtc_state = drm_atomic_get_new_crtc_state(state, &acrtc->base);
|
||||||
|
old_crtc_state = drm_atomic_get_old_crtc_state(state, &acrtc->base);
|
||||||
|
}
|
||||||
|
|
||||||
dm_new_crtc_state = to_dm_crtc_state(new_crtc_state);
|
dm_new_crtc_state = to_dm_crtc_state(new_crtc_state);
|
||||||
|
|
||||||
@ -8350,11 +8444,44 @@ static void amdgpu_dm_atomic_commit_tail(struct drm_atomic_state *state)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_content_protection_different(new_con_state, old_con_state, connector, adev->dm.hdcp_workqueue))
|
if (is_content_protection_different(new_crtc_state, old_crtc_state, new_con_state,
|
||||||
|
old_con_state, connector, adev->dm.hdcp_workqueue)) {
|
||||||
|
/* when display is unplugged from mst hub, connctor will
|
||||||
|
* be destroyed within dm_dp_mst_connector_destroy. connector
|
||||||
|
* hdcp perperties, like type, undesired, desired, enabled,
|
||||||
|
* will be lost. So, save hdcp properties into hdcp_work within
|
||||||
|
* amdgpu_dm_atomic_commit_tail. if the same display is
|
||||||
|
* plugged back with same display index, its hdcp properties
|
||||||
|
* will be retrieved from hdcp_work within dm_dp_mst_get_modes
|
||||||
|
*/
|
||||||
|
|
||||||
|
bool enable_encryption = false;
|
||||||
|
|
||||||
|
if (new_con_state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED)
|
||||||
|
enable_encryption = true;
|
||||||
|
|
||||||
|
if (aconnector->dc_link && aconnector->dc_sink &&
|
||||||
|
aconnector->dc_link->type == dc_connection_mst_branch) {
|
||||||
|
struct hdcp_workqueue *hdcp_work = adev->dm.hdcp_workqueue;
|
||||||
|
struct hdcp_workqueue *hdcp_w =
|
||||||
|
&hdcp_work[aconnector->dc_link->link_index];
|
||||||
|
|
||||||
|
hdcp_w->hdcp_content_type[connector->index] =
|
||||||
|
new_con_state->hdcp_content_type;
|
||||||
|
hdcp_w->content_protection[connector->index] =
|
||||||
|
new_con_state->content_protection;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (new_crtc_state && new_crtc_state->mode_changed &&
|
||||||
|
new_con_state->content_protection >= DRM_MODE_CONTENT_PROTECTION_DESIRED)
|
||||||
|
enable_encryption = true;
|
||||||
|
|
||||||
|
DRM_INFO("[HDCP_DM] hdcp_update_display enable_encryption = %x\n", enable_encryption);
|
||||||
|
|
||||||
hdcp_update_display(
|
hdcp_update_display(
|
||||||
adev->dm.hdcp_workqueue, aconnector->dc_link->link_index, aconnector,
|
adev->dm.hdcp_workqueue, aconnector->dc_link->link_index, aconnector,
|
||||||
new_con_state->hdcp_content_type,
|
new_con_state->hdcp_content_type, enable_encryption);
|
||||||
new_con_state->content_protection == DRM_MODE_CONTENT_PROTECTION_DESIRED);
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -52,6 +52,20 @@ struct hdcp_workqueue {
|
|||||||
struct mod_hdcp_link link;
|
struct mod_hdcp_link link;
|
||||||
|
|
||||||
enum mod_hdcp_encryption_status encryption_status;
|
enum mod_hdcp_encryption_status encryption_status;
|
||||||
|
|
||||||
|
/* when display is unplugged from mst hub, connctor will be
|
||||||
|
* destroyed within dm_dp_mst_connector_destroy. connector
|
||||||
|
* hdcp perperties, like type, undesired, desired, enabled,
|
||||||
|
* will be lost. So, save hdcp properties into hdcp_work within
|
||||||
|
* amdgpu_dm_atomic_commit_tail. if the same display is
|
||||||
|
* plugged back with same display index, its hdcp properties
|
||||||
|
* will be retrieved from hdcp_work within dm_dp_mst_get_modes
|
||||||
|
*/
|
||||||
|
/* un-desired, desired, enabled */
|
||||||
|
unsigned int content_protection[AMDGPU_DM_MAX_DISPLAY_INDEX];
|
||||||
|
/* hdcp1.x, hdcp2.x */
|
||||||
|
unsigned int hdcp_content_type[AMDGPU_DM_MAX_DISPLAY_INDEX];
|
||||||
|
|
||||||
uint8_t max_link;
|
uint8_t max_link;
|
||||||
|
|
||||||
uint8_t *srm;
|
uint8_t *srm;
|
||||||
|
@ -32,6 +32,10 @@
|
|||||||
#include "amdgpu_dm.h"
|
#include "amdgpu_dm.h"
|
||||||
#include "amdgpu_dm_mst_types.h"
|
#include "amdgpu_dm_mst_types.h"
|
||||||
|
|
||||||
|
#ifdef CONFIG_DRM_AMD_DC_HDCP
|
||||||
|
#include "amdgpu_dm_hdcp.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "dc.h"
|
#include "dc.h"
|
||||||
#include "dm_helpers.h"
|
#include "dm_helpers.h"
|
||||||
|
|
||||||
@ -363,6 +367,32 @@ static int dm_dp_mst_get_modes(struct drm_connector *connector)
|
|||||||
/* dc_link_add_remote_sink returns a new reference */
|
/* dc_link_add_remote_sink returns a new reference */
|
||||||
aconnector->dc_sink = dc_sink;
|
aconnector->dc_sink = dc_sink;
|
||||||
|
|
||||||
|
/* when display is unplugged from mst hub, connctor will be
|
||||||
|
* destroyed within dm_dp_mst_connector_destroy. connector
|
||||||
|
* hdcp perperties, like type, undesired, desired, enabled,
|
||||||
|
* will be lost. So, save hdcp properties into hdcp_work within
|
||||||
|
* amdgpu_dm_atomic_commit_tail. if the same display is
|
||||||
|
* plugged back with same display index, its hdcp properties
|
||||||
|
* will be retrieved from hdcp_work within dm_dp_mst_get_modes
|
||||||
|
*/
|
||||||
|
#ifdef CONFIG_DRM_AMD_DC_HDCP
|
||||||
|
if (aconnector->dc_sink && connector->state) {
|
||||||
|
struct drm_device *dev = connector->dev;
|
||||||
|
struct amdgpu_device *adev = drm_to_adev(dev);
|
||||||
|
|
||||||
|
if (adev->dm.hdcp_workqueue) {
|
||||||
|
struct hdcp_workqueue *hdcp_work = adev->dm.hdcp_workqueue;
|
||||||
|
struct hdcp_workqueue *hdcp_w =
|
||||||
|
&hdcp_work[aconnector->dc_link->link_index];
|
||||||
|
|
||||||
|
connector->state->hdcp_content_type =
|
||||||
|
hdcp_w->hdcp_content_type[connector->index];
|
||||||
|
connector->state->content_protection =
|
||||||
|
hdcp_w->content_protection[connector->index];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (aconnector->dc_sink) {
|
if (aconnector->dc_sink) {
|
||||||
amdgpu_dm_update_freesync_caps(
|
amdgpu_dm_update_freesync_caps(
|
||||||
connector, aconnector->edid);
|
connector, aconnector->edid);
|
||||||
|
@ -230,7 +230,8 @@
|
|||||||
type DTBCLK_P2_SRC_SEL;\
|
type DTBCLK_P2_SRC_SEL;\
|
||||||
type DTBCLK_P2_EN;\
|
type DTBCLK_P2_EN;\
|
||||||
type DTBCLK_P3_SRC_SEL;\
|
type DTBCLK_P3_SRC_SEL;\
|
||||||
type DTBCLK_P3_EN;
|
type DTBCLK_P3_EN;\
|
||||||
|
type DENTIST_DISPCLK_CHG_DONE;
|
||||||
|
|
||||||
struct dccg_shift {
|
struct dccg_shift {
|
||||||
DCCG_REG_FIELD_LIST(uint8_t)
|
DCCG_REG_FIELD_LIST(uint8_t)
|
||||||
|
@ -47,6 +47,14 @@ void dccg31_update_dpp_dto(struct dccg *dccg, int dpp_inst, int req_dppclk)
|
|||||||
{
|
{
|
||||||
struct dcn_dccg *dccg_dcn = TO_DCN_DCCG(dccg);
|
struct dcn_dccg *dccg_dcn = TO_DCN_DCCG(dccg);
|
||||||
|
|
||||||
|
if (dccg->dpp_clock_gated[dpp_inst]) {
|
||||||
|
/*
|
||||||
|
* Do not update the DPPCLK DTO if the clock is stopped.
|
||||||
|
* It is treated the same as if the pipe itself were in PG.
|
||||||
|
*/
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (dccg->ref_dppclk && req_dppclk) {
|
if (dccg->ref_dppclk && req_dppclk) {
|
||||||
int ref_dppclk = dccg->ref_dppclk;
|
int ref_dppclk = dccg->ref_dppclk;
|
||||||
int modulo, phase;
|
int modulo, phase;
|
||||||
|
@ -296,6 +296,9 @@ static void dccg314_dpp_root_clock_control(
|
|||||||
{
|
{
|
||||||
struct dcn_dccg *dccg_dcn = TO_DCN_DCCG(dccg);
|
struct dcn_dccg *dccg_dcn = TO_DCN_DCCG(dccg);
|
||||||
|
|
||||||
|
if (dccg->dpp_clock_gated[dpp_inst] != clock_on)
|
||||||
|
return;
|
||||||
|
|
||||||
if (clock_on) {
|
if (clock_on) {
|
||||||
/* turn off the DTO and leave phase/modulo at max */
|
/* turn off the DTO and leave phase/modulo at max */
|
||||||
REG_UPDATE(DPPCLK_DTO_CTRL, DPPCLK_DTO_ENABLE[dpp_inst], 0);
|
REG_UPDATE(DPPCLK_DTO_CTRL, DPPCLK_DTO_ENABLE[dpp_inst], 0);
|
||||||
@ -309,6 +312,8 @@ static void dccg314_dpp_root_clock_control(
|
|||||||
DPPCLK0_DTO_PHASE, 0,
|
DPPCLK0_DTO_PHASE, 0,
|
||||||
DPPCLK0_DTO_MODULO, 1);
|
DPPCLK0_DTO_MODULO, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dccg->dpp_clock_gated[dpp_inst] = !clock_on;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct dccg_funcs dccg314_funcs = {
|
static const struct dccg_funcs dccg314_funcs = {
|
||||||
|
@ -920,6 +920,22 @@ static const struct dc_debug_options debug_defaults_drv = {
|
|||||||
.afmt = true,
|
.afmt = true,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
.root_clock_optimization = {
|
||||||
|
.bits = {
|
||||||
|
.dpp = true,
|
||||||
|
.dsc = false,
|
||||||
|
.hdmistream = false,
|
||||||
|
.hdmichar = false,
|
||||||
|
.dpstream = false,
|
||||||
|
.symclk32_se = false,
|
||||||
|
.symclk32_le = false,
|
||||||
|
.symclk_fe = false,
|
||||||
|
.physymclk = false,
|
||||||
|
.dpiasymclk = false,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
.seamless_boot_odm_combine = true
|
.seamless_boot_odm_combine = true
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1917,6 +1933,10 @@ static bool dcn314_resource_construct(
|
|||||||
dc->debug = debug_defaults_drv;
|
dc->debug = debug_defaults_drv;
|
||||||
else
|
else
|
||||||
dc->debug = debug_defaults_diags;
|
dc->debug = debug_defaults_diags;
|
||||||
|
|
||||||
|
/* Disable root clock optimization */
|
||||||
|
dc->debug.root_clock_optimization.u32All = 0;
|
||||||
|
|
||||||
// Init the vm_helper
|
// Init the vm_helper
|
||||||
if (dc->vm_helper)
|
if (dc->vm_helper)
|
||||||
vm_helper_init(dc->vm_helper, 16);
|
vm_helper_init(dc->vm_helper, 16);
|
||||||
|
@ -42,6 +42,20 @@
|
|||||||
#define DC_LOGGER \
|
#define DC_LOGGER \
|
||||||
dccg->ctx->logger
|
dccg->ctx->logger
|
||||||
|
|
||||||
|
/* This function is a workaround for writing to OTG_PIXEL_RATE_DIV
|
||||||
|
* without the probability of causing a DIG FIFO error.
|
||||||
|
*/
|
||||||
|
static void dccg32_wait_for_dentist_change_done(
|
||||||
|
struct dccg *dccg)
|
||||||
|
{
|
||||||
|
struct dcn_dccg *dccg_dcn = TO_DCN_DCCG(dccg);
|
||||||
|
|
||||||
|
uint32_t dentist_dispclk_value = REG_READ(DENTIST_DISPCLK_CNTL);
|
||||||
|
|
||||||
|
REG_WRITE(DENTIST_DISPCLK_CNTL, dentist_dispclk_value);
|
||||||
|
REG_WAIT(DENTIST_DISPCLK_CNTL, DENTIST_DISPCLK_CHG_DONE, 1, 50, 2000);
|
||||||
|
}
|
||||||
|
|
||||||
static void dccg32_get_pixel_rate_div(
|
static void dccg32_get_pixel_rate_div(
|
||||||
struct dccg *dccg,
|
struct dccg *dccg,
|
||||||
uint32_t otg_inst,
|
uint32_t otg_inst,
|
||||||
@ -110,21 +124,29 @@ static void dccg32_set_pixel_rate_div(
|
|||||||
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
||||||
OTG0_PIXEL_RATE_DIVK1, k1,
|
OTG0_PIXEL_RATE_DIVK1, k1,
|
||||||
OTG0_PIXEL_RATE_DIVK2, k2);
|
OTG0_PIXEL_RATE_DIVK2, k2);
|
||||||
|
|
||||||
|
dccg32_wait_for_dentist_change_done(dccg);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
||||||
OTG1_PIXEL_RATE_DIVK1, k1,
|
OTG1_PIXEL_RATE_DIVK1, k1,
|
||||||
OTG1_PIXEL_RATE_DIVK2, k2);
|
OTG1_PIXEL_RATE_DIVK2, k2);
|
||||||
|
|
||||||
|
dccg32_wait_for_dentist_change_done(dccg);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
||||||
OTG2_PIXEL_RATE_DIVK1, k1,
|
OTG2_PIXEL_RATE_DIVK1, k1,
|
||||||
OTG2_PIXEL_RATE_DIVK2, k2);
|
OTG2_PIXEL_RATE_DIVK2, k2);
|
||||||
|
|
||||||
|
dccg32_wait_for_dentist_change_done(dccg);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
REG_UPDATE_2(OTG_PIXEL_RATE_DIV,
|
||||||
OTG3_PIXEL_RATE_DIVK1, k1,
|
OTG3_PIXEL_RATE_DIVK1, k1,
|
||||||
OTG3_PIXEL_RATE_DIVK2, k2);
|
OTG3_PIXEL_RATE_DIVK2, k2);
|
||||||
|
|
||||||
|
dccg32_wait_for_dentist_change_done(dccg);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
BREAK_TO_DEBUGGER();
|
BREAK_TO_DEBUGGER();
|
||||||
|
@ -147,7 +147,8 @@
|
|||||||
DCCG_SF(DTBCLK_P_CNTL, DTBCLK_P3_SRC_SEL, mask_sh),\
|
DCCG_SF(DTBCLK_P_CNTL, DTBCLK_P3_SRC_SEL, mask_sh),\
|
||||||
DCCG_SF(DTBCLK_P_CNTL, DTBCLK_P3_EN, mask_sh),\
|
DCCG_SF(DTBCLK_P_CNTL, DTBCLK_P3_EN, mask_sh),\
|
||||||
DCCG_SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO_SEL, mask_sh),\
|
DCCG_SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO_SEL, mask_sh),\
|
||||||
DCCG_SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO0_SOURCE_SEL, mask_sh)
|
DCCG_SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO0_SOURCE_SEL, mask_sh),\
|
||||||
|
DCCG_SF(DENTIST_DISPCLK_CNTL, DENTIST_DISPCLK_CHG_DONE, mask_sh)
|
||||||
|
|
||||||
|
|
||||||
struct dccg *dccg32_create(
|
struct dccg *dccg32_create(
|
||||||
|
@ -1177,7 +1177,7 @@ unsigned int dcn32_calculate_dccg_k1_k2_values(struct pipe_ctx *pipe_ctx, unsign
|
|||||||
*k2_div = PIXEL_RATE_DIV_BY_2;
|
*k2_div = PIXEL_RATE_DIV_BY_2;
|
||||||
else
|
else
|
||||||
*k2_div = PIXEL_RATE_DIV_BY_4;
|
*k2_div = PIXEL_RATE_DIV_BY_4;
|
||||||
} else if (dc_is_dp_signal(stream->signal)) {
|
} else if (dc_is_dp_signal(stream->signal) || dc_is_virtual_signal(stream->signal)) {
|
||||||
if (two_pix_per_container) {
|
if (two_pix_per_container) {
|
||||||
*k1_div = PIXEL_RATE_DIV_BY_1;
|
*k1_div = PIXEL_RATE_DIV_BY_1;
|
||||||
*k2_div = PIXEL_RATE_DIV_BY_2;
|
*k2_div = PIXEL_RATE_DIV_BY_2;
|
||||||
|
@ -1272,7 +1272,8 @@ unsigned int dcn32_calc_num_avail_chans_for_mall(struct dc *dc, int num_chans);
|
|||||||
DCCG_SRII(PHASE, DTBCLK_DTO, 0), DCCG_SRII(PHASE, DTBCLK_DTO, 1), \
|
DCCG_SRII(PHASE, DTBCLK_DTO, 0), DCCG_SRII(PHASE, DTBCLK_DTO, 1), \
|
||||||
DCCG_SRII(PHASE, DTBCLK_DTO, 2), DCCG_SRII(PHASE, DTBCLK_DTO, 3), \
|
DCCG_SRII(PHASE, DTBCLK_DTO, 2), DCCG_SRII(PHASE, DTBCLK_DTO, 3), \
|
||||||
SR(DCCG_AUDIO_DTBCLK_DTO_MODULO), SR(DCCG_AUDIO_DTBCLK_DTO_PHASE), \
|
SR(DCCG_AUDIO_DTBCLK_DTO_MODULO), SR(DCCG_AUDIO_DTBCLK_DTO_PHASE), \
|
||||||
SR(OTG_PIXEL_RATE_DIV), SR(DTBCLK_P_CNTL), SR(DCCG_AUDIO_DTO_SOURCE) \
|
SR(OTG_PIXEL_RATE_DIV), SR(DTBCLK_P_CNTL), \
|
||||||
|
SR(DCCG_AUDIO_DTO_SOURCE), SR(DENTIST_DISPCLK_CNTL) \
|
||||||
)
|
)
|
||||||
|
|
||||||
/* VMID */
|
/* VMID */
|
||||||
|
@ -808,7 +808,7 @@ static void DISPCLKDPPCLKDCFCLKDeepSleepPrefetchParametersWatermarksAndPerforman
|
|||||||
v->SwathHeightC[k],
|
v->SwathHeightC[k],
|
||||||
TWait,
|
TWait,
|
||||||
(v->DRAMSpeedPerState[mode_lib->vba.VoltageLevel] <= MEM_STROBE_FREQ_MHZ ||
|
(v->DRAMSpeedPerState[mode_lib->vba.VoltageLevel] <= MEM_STROBE_FREQ_MHZ ||
|
||||||
v->DCFCLKPerState[mode_lib->vba.VoltageLevel] <= MIN_DCFCLK_FREQ_MHZ) ?
|
v->DCFCLKPerState[mode_lib->vba.VoltageLevel] <= DCFCLK_FREQ_EXTRA_PREFETCH_REQ_MHZ) ?
|
||||||
mode_lib->vba.ip.min_prefetch_in_strobe_us : 0,
|
mode_lib->vba.ip.min_prefetch_in_strobe_us : 0,
|
||||||
/* Output */
|
/* Output */
|
||||||
&v->DSTXAfterScaler[k],
|
&v->DSTXAfterScaler[k],
|
||||||
@ -3289,7 +3289,7 @@ void dml32_ModeSupportAndSystemConfigurationFull(struct display_mode_lib *mode_l
|
|||||||
v->swath_width_chroma_ub_this_state[k],
|
v->swath_width_chroma_ub_this_state[k],
|
||||||
v->SwathHeightYThisState[k],
|
v->SwathHeightYThisState[k],
|
||||||
v->SwathHeightCThisState[k], v->TWait,
|
v->SwathHeightCThisState[k], v->TWait,
|
||||||
(v->DRAMSpeedPerState[i] <= MEM_STROBE_FREQ_MHZ || v->DCFCLKState[i][j] <= MIN_DCFCLK_FREQ_MHZ) ?
|
(v->DRAMSpeedPerState[i] <= MEM_STROBE_FREQ_MHZ || v->DCFCLKState[i][j] <= DCFCLK_FREQ_EXTRA_PREFETCH_REQ_MHZ) ?
|
||||||
mode_lib->vba.ip.min_prefetch_in_strobe_us : 0,
|
mode_lib->vba.ip.min_prefetch_in_strobe_us : 0,
|
||||||
|
|
||||||
/* Output */
|
/* Output */
|
||||||
|
@ -52,7 +52,7 @@
|
|||||||
#define BPP_BLENDED_PIPE 0xffffffff
|
#define BPP_BLENDED_PIPE 0xffffffff
|
||||||
|
|
||||||
#define MEM_STROBE_FREQ_MHZ 1600
|
#define MEM_STROBE_FREQ_MHZ 1600
|
||||||
#define MIN_DCFCLK_FREQ_MHZ 200
|
#define DCFCLK_FREQ_EXTRA_PREFETCH_REQ_MHZ 300
|
||||||
#define MEM_STROBE_MAX_DELIVERY_TIME_US 60.0
|
#define MEM_STROBE_MAX_DELIVERY_TIME_US 60.0
|
||||||
|
|
||||||
struct display_mode_lib;
|
struct display_mode_lib;
|
||||||
|
@ -68,6 +68,7 @@ struct dccg {
|
|||||||
const struct dccg_funcs *funcs;
|
const struct dccg_funcs *funcs;
|
||||||
int pipe_dppclk_khz[MAX_PIPES];
|
int pipe_dppclk_khz[MAX_PIPES];
|
||||||
int ref_dppclk;
|
int ref_dppclk;
|
||||||
|
bool dpp_clock_gated[MAX_PIPES];
|
||||||
//int dtbclk_khz[MAX_PIPES];/* TODO needs to be removed */
|
//int dtbclk_khz[MAX_PIPES];/* TODO needs to be removed */
|
||||||
//int audio_dtbclk_khz;/* TODO needs to be removed */
|
//int audio_dtbclk_khz;/* TODO needs to be removed */
|
||||||
//int ref_dtbclk_khz;/* TODO needs to be removed */
|
//int ref_dtbclk_khz;/* TODO needs to be removed */
|
||||||
|
@ -1562,9 +1562,9 @@ static int smu_disable_dpms(struct smu_context *smu)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* For SMU 13.0.4/11, PMFW will handle the features disablement properly
|
* For SMU 13.0.4/11, PMFW will handle the features disablement properly
|
||||||
* for gpu reset case. Driver involvement is unnecessary.
|
* for gpu reset and S0i3 cases. Driver involvement is unnecessary.
|
||||||
*/
|
*/
|
||||||
if (amdgpu_in_reset(adev)) {
|
if (amdgpu_in_reset(adev) || adev->in_s0ix) {
|
||||||
switch (adev->ip_versions[MP1_HWIP][0]) {
|
switch (adev->ip_versions[MP1_HWIP][0]) {
|
||||||
case IP_VERSION(13, 0, 4):
|
case IP_VERSION(13, 0, 4):
|
||||||
case IP_VERSION(13, 0, 11):
|
case IP_VERSION(13, 0, 11):
|
||||||
|
@ -588,7 +588,9 @@ static int sienna_cichlid_tables_init(struct smu_context *smu)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t sienna_cichlid_get_throttler_status_locked(struct smu_context *smu)
|
static uint32_t sienna_cichlid_get_throttler_status_locked(struct smu_context *smu,
|
||||||
|
bool use_metrics_v3,
|
||||||
|
bool use_metrics_v2)
|
||||||
{
|
{
|
||||||
struct smu_table_context *smu_table= &smu->smu_table;
|
struct smu_table_context *smu_table= &smu->smu_table;
|
||||||
SmuMetricsExternal_t *metrics_ext =
|
SmuMetricsExternal_t *metrics_ext =
|
||||||
@ -596,13 +598,11 @@ static uint32_t sienna_cichlid_get_throttler_status_locked(struct smu_context *s
|
|||||||
uint32_t throttler_status = 0;
|
uint32_t throttler_status = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if ((smu->adev->ip_versions[MP1_HWIP][0] == IP_VERSION(11, 0, 7)) &&
|
if (use_metrics_v3) {
|
||||||
(smu->smc_fw_version >= 0x3A4900)) {
|
|
||||||
for (i = 0; i < THROTTLER_COUNT; i++)
|
for (i = 0; i < THROTTLER_COUNT; i++)
|
||||||
throttler_status |=
|
throttler_status |=
|
||||||
(metrics_ext->SmuMetrics_V3.ThrottlingPercentage[i] ? 1U << i : 0);
|
(metrics_ext->SmuMetrics_V3.ThrottlingPercentage[i] ? 1U << i : 0);
|
||||||
} else if ((smu->adev->ip_versions[MP1_HWIP][0] == IP_VERSION(11, 0, 7)) &&
|
} else if (use_metrics_v2) {
|
||||||
(smu->smc_fw_version >= 0x3A4300)) {
|
|
||||||
for (i = 0; i < THROTTLER_COUNT; i++)
|
for (i = 0; i < THROTTLER_COUNT; i++)
|
||||||
throttler_status |=
|
throttler_status |=
|
||||||
(metrics_ext->SmuMetrics_V2.ThrottlingPercentage[i] ? 1U << i : 0);
|
(metrics_ext->SmuMetrics_V2.ThrottlingPercentage[i] ? 1U << i : 0);
|
||||||
@ -864,7 +864,7 @@ static int sienna_cichlid_get_smu_metrics_data(struct smu_context *smu,
|
|||||||
metrics->TemperatureVrSoc) * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
|
metrics->TemperatureVrSoc) * SMU_TEMPERATURE_UNITS_PER_CENTIGRADES;
|
||||||
break;
|
break;
|
||||||
case METRICS_THROTTLER_STATUS:
|
case METRICS_THROTTLER_STATUS:
|
||||||
*value = sienna_cichlid_get_throttler_status_locked(smu);
|
*value = sienna_cichlid_get_throttler_status_locked(smu, use_metrics_v3, use_metrics_v2);
|
||||||
break;
|
break;
|
||||||
case METRICS_CURR_FANSPEED:
|
case METRICS_CURR_FANSPEED:
|
||||||
*value = use_metrics_v3 ? metrics_v3->CurrFanSpeed :
|
*value = use_metrics_v3 ? metrics_v3->CurrFanSpeed :
|
||||||
@ -4017,7 +4017,7 @@ static ssize_t sienna_cichlid_get_gpu_metrics(struct smu_context *smu,
|
|||||||
gpu_metrics->current_dclk1 = use_metrics_v3 ? metrics_v3->CurrClock[PPCLK_DCLK_1] :
|
gpu_metrics->current_dclk1 = use_metrics_v3 ? metrics_v3->CurrClock[PPCLK_DCLK_1] :
|
||||||
use_metrics_v2 ? metrics_v2->CurrClock[PPCLK_DCLK_1] : metrics->CurrClock[PPCLK_DCLK_1];
|
use_metrics_v2 ? metrics_v2->CurrClock[PPCLK_DCLK_1] : metrics->CurrClock[PPCLK_DCLK_1];
|
||||||
|
|
||||||
gpu_metrics->throttle_status = sienna_cichlid_get_throttler_status_locked(smu);
|
gpu_metrics->throttle_status = sienna_cichlid_get_throttler_status_locked(smu, use_metrics_v3, use_metrics_v2);
|
||||||
gpu_metrics->indep_throttle_status =
|
gpu_metrics->indep_throttle_status =
|
||||||
smu_cmn_get_indep_throttler_status(gpu_metrics->throttle_status,
|
smu_cmn_get_indep_throttler_status(gpu_metrics->throttle_status,
|
||||||
sienna_cichlid_throttler_map);
|
sienna_cichlid_throttler_map);
|
||||||
|
@ -2727,7 +2727,7 @@ static struct intel_sdvo_connector *intel_sdvo_connector_alloc(void)
|
|||||||
__drm_atomic_helper_connector_reset(&sdvo_connector->base.base,
|
__drm_atomic_helper_connector_reset(&sdvo_connector->base.base,
|
||||||
&conn_state->base.base);
|
&conn_state->base.base);
|
||||||
|
|
||||||
INIT_LIST_HEAD(&sdvo_connector->base.panel.fixed_modes);
|
intel_panel_init_alloc(&sdvo_connector->base);
|
||||||
|
|
||||||
return sdvo_connector;
|
return sdvo_connector;
|
||||||
}
|
}
|
||||||
|
@ -1407,8 +1407,7 @@ nouveau_connector_create(struct drm_device *dev,
|
|||||||
ret = nvif_conn_ctor(&disp->disp, nv_connector->base.name, nv_connector->index,
|
ret = nvif_conn_ctor(&disp->disp, nv_connector->base.name, nv_connector->index,
|
||||||
&nv_connector->conn);
|
&nv_connector->conn);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
kfree(nv_connector);
|
goto drm_conn_err;
|
||||||
return ERR_PTR(ret);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1470,4 +1469,9 @@ nouveau_connector_create(struct drm_device *dev,
|
|||||||
|
|
||||||
drm_connector_register(connector);
|
drm_connector_register(connector);
|
||||||
return connector;
|
return connector;
|
||||||
|
|
||||||
|
drm_conn_err:
|
||||||
|
drm_connector_cleanup(connector);
|
||||||
|
kfree(nv_connector);
|
||||||
|
return ERR_PTR(ret);
|
||||||
}
|
}
|
||||||
|
@ -969,21 +969,21 @@ static const struct panel_desc auo_g104sn02 = {
|
|||||||
.connector_type = DRM_MODE_CONNECTOR_LVDS,
|
.connector_type = DRM_MODE_CONNECTOR_LVDS,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct drm_display_mode auo_g121ean01_mode = {
|
static const struct display_timing auo_g121ean01_timing = {
|
||||||
.clock = 66700,
|
.pixelclock = { 60000000, 74400000, 90000000 },
|
||||||
.hdisplay = 1280,
|
.hactive = { 1280, 1280, 1280 },
|
||||||
.hsync_start = 1280 + 58,
|
.hfront_porch = { 20, 50, 100 },
|
||||||
.hsync_end = 1280 + 58 + 8,
|
.hback_porch = { 20, 50, 100 },
|
||||||
.htotal = 1280 + 58 + 8 + 70,
|
.hsync_len = { 30, 100, 200 },
|
||||||
.vdisplay = 800,
|
.vactive = { 800, 800, 800 },
|
||||||
.vsync_start = 800 + 6,
|
.vfront_porch = { 2, 10, 25 },
|
||||||
.vsync_end = 800 + 6 + 4,
|
.vback_porch = { 2, 10, 25 },
|
||||||
.vtotal = 800 + 6 + 4 + 10,
|
.vsync_len = { 4, 18, 50 },
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct panel_desc auo_g121ean01 = {
|
static const struct panel_desc auo_g121ean01 = {
|
||||||
.modes = &auo_g121ean01_mode,
|
.timings = &auo_g121ean01_timing,
|
||||||
.num_modes = 1,
|
.num_timings = 1,
|
||||||
.bpc = 8,
|
.bpc = 8,
|
||||||
.size = {
|
.size = {
|
||||||
.width = 261,
|
.width = 261,
|
||||||
|
@ -312,7 +312,7 @@ int qxl_gem_object_create_with_handle(struct qxl_device *qdev,
|
|||||||
u32 domain,
|
u32 domain,
|
||||||
size_t size,
|
size_t size,
|
||||||
struct qxl_surface *surf,
|
struct qxl_surface *surf,
|
||||||
struct qxl_bo **qobj,
|
struct drm_gem_object **gobj,
|
||||||
uint32_t *handle);
|
uint32_t *handle);
|
||||||
void qxl_gem_object_free(struct drm_gem_object *gobj);
|
void qxl_gem_object_free(struct drm_gem_object *gobj);
|
||||||
int qxl_gem_object_open(struct drm_gem_object *obj, struct drm_file *file_priv);
|
int qxl_gem_object_open(struct drm_gem_object *obj, struct drm_file *file_priv);
|
||||||
|
@ -34,6 +34,7 @@ int qxl_mode_dumb_create(struct drm_file *file_priv,
|
|||||||
{
|
{
|
||||||
struct qxl_device *qdev = to_qxl(dev);
|
struct qxl_device *qdev = to_qxl(dev);
|
||||||
struct qxl_bo *qobj;
|
struct qxl_bo *qobj;
|
||||||
|
struct drm_gem_object *gobj;
|
||||||
uint32_t handle;
|
uint32_t handle;
|
||||||
int r;
|
int r;
|
||||||
struct qxl_surface surf;
|
struct qxl_surface surf;
|
||||||
@ -62,11 +63,13 @@ int qxl_mode_dumb_create(struct drm_file *file_priv,
|
|||||||
|
|
||||||
r = qxl_gem_object_create_with_handle(qdev, file_priv,
|
r = qxl_gem_object_create_with_handle(qdev, file_priv,
|
||||||
QXL_GEM_DOMAIN_CPU,
|
QXL_GEM_DOMAIN_CPU,
|
||||||
args->size, &surf, &qobj,
|
args->size, &surf, &gobj,
|
||||||
&handle);
|
&handle);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
qobj = gem_to_qxl_bo(gobj);
|
||||||
qobj->is_dumb = true;
|
qobj->is_dumb = true;
|
||||||
|
drm_gem_object_put(gobj);
|
||||||
args->pitch = pitch;
|
args->pitch = pitch;
|
||||||
args->handle = handle;
|
args->handle = handle;
|
||||||
return 0;
|
return 0;
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user