Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp4280415pxb; Tue, 31 Aug 2021 00:56:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxO4LYpQa0qkchT1HhtsxqXHVWbkLrssBo9NrSanUvMpu3sh12GuilAki/6nja8xMbAIaYc X-Received: by 2002:a05:6e02:2183:: with SMTP id j3mr7196520ila.149.1630396608340; Tue, 31 Aug 2021 00:56:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630396608; cv=none; d=google.com; s=arc-20160816; b=gkSIQMEpKJHUE2hT/PBFz1gkTF1PVleEhB4chKsHSG7F3bhtJCMzTD4ZeOH0oduZE/ rIUX0QwAKN273hVlmffUBGrNdVNWEsvo9Bptnru0fcIm/Xki0yOyMD5qyWJZImM5PFo5 scsvXNTQ4GF8HAs0I3BjxG3h/NelScvYoNKIaRDwvQ6exzEsVXsHFZrCKa7Zba/YVY2K tkzjvsdt5DyNMZos20132D+s6tZ0PWjm88nUMabrS8KCm5cWZvFKJn7QwIiC+zx/Ma6d pjjL9a/7nJE1JiujIPu43exwVwn7M/5c114qk7pu69At05ict0U1K5q0PrGeunXttiqn 6KTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=fme9h69zK593h9CIRwDOuhMVznkiprdDwzSR2H3i16U=; b=KJBR2dKjYhvqP9MpcfcWsRRUTYgaEYq4HXHePfWWQXXvx1KJb8YXKIFsOiu+UrDO/Q zpo5EYE3iUu8vB2cCvLkbhRyUXYgyRS97usaz4wIpsWOeAg0ngpmOlBVyVoF4QLH/+N2 /0/y2OTgSpfFAddaeXKZpiUXTEUUm3rDD/hQaoHzi5tqtfPE/WMzkEM1JKcW74zg3N3M /KtKGPkKv40TKxSvvpjVI716j71zGlggMeIg50dLGZf/bt4BsNTGxDLva9F7go28eCpr jZNdFnGGZPLJuW/xeQqAxx3xRIPtdVEap39smve27QwbHS1JSdf+NKWwWZ/kbn2zFWVA YZ0A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v7si19190172ilu.137.2021.08.31.00.56.36; Tue, 31 Aug 2021 00:56:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240113AbhHaH4u (ORCPT + 99 others); Tue, 31 Aug 2021 03:56:50 -0400 Received: from mailgw.kylinos.cn ([123.150.8.42]:15037 "EHLO nksmu.kylinos.cn" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S240042AbhHaH4t (ORCPT ); Tue, 31 Aug 2021 03:56:49 -0400 X-UUID: f110768550af4e67adecc495e18cfae1-20210831 X-CPASD-INFO: 28d840706ec84b87ac91782c99a21c10 @e4ieWGFiZWBihaWEg6WDcYGUaWFnZFKye3OBYl- TXVCVhH5xTWJsXVKBfG5QZWNdYVN_eGpQYl9gZFB5i3-XblBgXoZgUZB3gXqeWGReZw== X-CPASD-FEATURE: 0.0 X-CLOUD-ID: 28d840706ec84b87ac91782c99a21c10 X-CPASD-SUMMARY: SIP:-1,APTIP:-2.0,KEY:0.0,FROMBLOCK:1,EXT:0.0,OB:0.0,URL:-5,T VAL:196.0,ESV:0.0,ECOM:-5.0,ML:0.0,FD:0.0,CUTS:174.0,IP:-2.0,MAL:0.0,ATTNUM:0 .0,PHF:-5.0,PHC:-5.0,SPF:4.0,EDMS:-3,IPLABEL:4480.0,FROMTO:0,AD:0,FFOB:0.0,CF OB:0.0,SPC:0.0,SIG:-5,AUF:2,DUF:10512,ACD:27,DCD:129,SL:0,AG:0,CFC:0.647,CFSR :0.029,UAT:0,RAF:0,VERSION:2.3.4 X-CPASD-ID: f110768550af4e67adecc495e18cfae1-20210831 X-CPASD-BLOCK: 1000 X-CPASD-STAGE: 1, 1 X-UUID: f110768550af4e67adecc495e18cfae1-20210831 X-User: lizhenneng@kylinos.cn Received: from localhost.localdomain [(116.128.244.169)] by nksmu.kylinos.cn (envelope-from ) (Generic MTA) with ESMTP id 1145832434; Tue, 31 Aug 2021 15:53:40 +0800 From: Zhenneng Li To: Bjorn Helgaas Cc: linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Zhenneng Li Subject: [PATCH] PCI/sysfs: add write attribute for boot_vga Date: Tue, 31 Aug 2021 15:55:28 +0800 Message-Id: <20210831075528.535909-1-lizhenneng@kylinos.cn> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add writing attribute for boot_vga sys node, so we can config default video display output dynamically when there are two video cards on a machine. Xorg server will determine running on which video card based on boot_vga node's value. Signed-off-by: Zhenneng Li --- drivers/pci/pci-sysfs.c | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c index 7bbf2673c7f2..a6ba19ce7adb 100644 --- a/drivers/pci/pci-sysfs.c +++ b/drivers/pci/pci-sysfs.c @@ -664,7 +664,29 @@ static ssize_t boot_vga_show(struct device *dev, struct device_attribute *attr, !!(pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW)); } -static DEVICE_ATTR_RO(boot_vga); + +static ssize_t boot_vga_store(struct device *dev, struct device_attribute *attr, + const char *buf, size_t count) +{ + unsigned long val; + struct pci_dev *pdev = to_pci_dev(dev); + struct pci_dev *vga_dev = vga_default_device(); + + if (kstrtoul(buf, 0, &val) < 0) + return -EINVAL; + + if (val != 1) + return -EINVAL; + + if (!capable(CAP_SYS_ADMIN)) + return -EPERM; + + if (pdev != vga_dev) + vga_set_default_device(pdev); + + return count; +} +static DEVICE_ATTR_RW(boot_vga); static ssize_t pci_read_config(struct file *filp, struct kobject *kobj, struct bin_attribute *bin_attr, char *buf, -- 2.25.1 No virus found Checked by Hillstone Network AntiVirus