Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

LoongArch: fix some pci problems(Pull request again) #192

Merged

Conversation

sterling-teng
Copy link
Contributor

Drop a patch:

  • LoongArch: pci root bridige set acpi companion only when not acpi_disabled.

Yanteng Si added 9 commits May 23, 2024 14:43
Signed-off-by: Baoqi Zhang <zhangbaoqi@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Fix patch "LoongArch: Add PCI controller support"

Signed-off-by: Tianli Xiong <xiongtianli@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
…ccess configuration space

Fix patch "PCI: loongson: Use generic 8/16/32-bit
config ops on LS2K/LS7A"

Signed-off-by: Tianli Xiong <xiongtianli@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Don't limit mrrs during resume, so that saved value can be
restored.

Fix patch "PCI: loongson: Improve the MRRS quirk for LS7A"

Signed-off-by: Jianmin Lv <lvjianmin@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
fix kabi error caused by pm_suspend_target_state,used only
by loongson devices.

Signed-off-by: Hongchen Zhang <zhanghongchen@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Fix some pcie card not scanning properly when
bus number is inconsistent during firmware and
kernel scan phases.

Signed-off-by: liuyun <liuyun@loongson.cn>
Signed-off-by: Tianli Xiong <xiongtianli@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Signed-off-by: Jianmin Lv <lvjianmin@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Add window to solve GPU access error

Signed-off-by: Baoqi Zhang <zhangbaoqi@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
According to PCI-to-PCI bridge spec, bit 3 of Bridge Control Register
is VGA Enable bit which modifies the response by the bridge to VGA
compatible addresses.

The Bridge Control register provides extensions to the Command register
that are specific to a bridge. The Bridge Control register provides
many of the same controls for the secondary interface that are provided
by the Command register for the primary interface. There are some bits
that affect the operation of both interfaces of the bridge.

If the VGA Enable bit is set, the bridge will positively decode
and forward the following accesses on the primary interface to
the secondary interface (and, conversely, block the forwarding
of these addresses from the secondary to primary interface)

Forwarding of these accesses is qualified by the I/O Enable and
Memory Enable bits in the Command register.) The default state of
this bit after reset must be 0.

Bit 3 of Bridge Control Register is VGA Enable bit which modifies the
response by the bridge to VGA compatible addresses.

 when 0: do not forward VGA compatible memory and I/O addresses from
         the primary to secondary interface (addresses defined below)
         unless they are enabled for forwarding by the defined I/O
 when 1: forward VGA compatible memory and I/O addresses (addresses
         defined below) from the primary interface to the secondary
		 interface (if the I/O Enable and Memory Enable bits are set)
         independent of the I/O and memory address ranges and
         independent of the ISA Enable bit

 * memory accesses in the range 000A 0000h to 000B FFFFh

 * I/O addresses in the first 64 KB of the I/O address space
   (AD[31:16] are 0000h) where AD[9:: 0] are in the ranges
   3B0h to 3BBh and 3C0h to 3DFh (inclusive of ISA address
   aliases - AD[15::10] are not decoded)

If the VGA Enable bit is set, forwarding of these accesses is
independent of the I/O address range and memory address ranges
defined by the I/O Base and Limit registers, the Memory Base
and Limit registers, and the Prefetchable Memory Base and Limit
registers of the bridge.

Forwarding of these accesses is also independent of the settings
of the ISA Enable bit (in the Bridge Control register) or VGA
Palette Snoop bits (in the Command register).

The AST2500 hardware we are using do not set the VGA Enable bit on
its bridge control reg, this cause vgaarb subsystem don't think the
VGA card behind this pridge as a valid boot vga device which made
X server choose wrong video card to use when multiple video card
present in the system.

Its seems more vgaarb's fault than the ast2500 bmc itself.
even through bit 3 of Bridge Control Register is 0, it should still
allow to forward the accesses when the addresses is in the range of
IO/MEM Base and Limit registers.

Nevertheless, in order to support loongson CPU product line, we
provide a workaround to this bug for the Sugon L620-G30 and Sugon
L820-G30 server.

see similar bug:

https://patchwork.kernel.org/project/linux-pci/patch/20170619023528.11532-1-dja@axtens.net/

Signed-off-by: suijingfeng <suijingfeng@loongson.cn>
Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
@deepin-ci-robot
Copy link

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by:
Once this PR has been reviewed and has the lgtm label, please assign liujianqiang-niu for approval. For more information see the Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@deepin-ci-robot
Copy link

Hi @sterling-teng. Thanks for your PR.

I'm waiting for a deepin-community member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@opsiff
Copy link
Member

opsiff commented May 24, 2024

/ok-to-test

@deepin-ci-robot
Copy link

deepin pr auto review

关键摘要:

  • acpi.c文件中,对于resource_list_for_each_entry_safe的使用可能存在潜在的问题,因为如果entryNULL,这将导致未定义行为。
  • loongson_d3_quirk函数中,pdev->dev_flags |= PCI_DEV_FLAGS_NO_D3;可能会导致pdevdev_flags被覆盖,而不是累加。
  • loongson_display_quirk函数中,maskval的计算可能存在逻辑错误,如果size24,则maskval的计算方式应该是正确的,但如果size1,则maskval的计算方式可能会有问题。
  • pci_loongson_config_read函数中,对于size12的情况,使用了readbreadw,但对于readl的情况,没有明确的错误处理或检查。
  • pci_loongson_map_bus函数中,对于addrNULL的情况,直接返回了NULL,但没有提供错误信息或日志记录。
  • loongson_pci_probe函数中,对num的递增操作没有提供上下文,不清楚其目的和影响。
  • pcie_set_readrq函数中,对于rq的检查逻辑可能不够清晰,特别是在处理ffs(rq) - 8时,可能需要更多的注释或文档说明。
  • suspend_state_t的定义和使用似乎与当前的Linux内核版本不兼容,因为#ifndef CONFIG_PM_SLEEP似乎是一个旧的标准,而新的代码使用了#ifdef CONFIG_MACH_LOONGSON64

是否建议立即修改:

  • 需要修复上述问题,以确保代码的健壮性和可维护性。
  • 特别是对于潜在的未定义行为问题,应该立即进行修改以确保程序的正确性。
  • 对于pci_loongson_config_read函数中readl的错误处理和检查,也应该尽快添加,以避免潜在的运行时错误。
  • 对于loongson_pci_probe函数中num的递增操作,建议添加注释或文档,以便其他开发者理解其目的。
  • 对于pcie_set_readrq函数中rq的检查逻辑,建议添加更多的注释或文档,以便其他开发者理解代码的意图。
  • 需要确认suspend_state_t的定义和使用是否正确,并确保与当前的内核版本兼容。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants