提交 273b177c 编写于 作者: L Logan Gunthorpe 提交者: Bjorn Helgaas

PCI: Move pci_[get|set]_resource_alignment_param() into their callers

Both the functions pci_get_resource_alignment_param() and
pci_set_resource_alignment_param() are now only called in one place:
resource_alignment_show() and resource_alignment_store() respectively.

There is no value in this extra set of functions so move both into their
callers respectively.

[bhelgaas: fold in "GFP_KERNEL while atomic" fix from Christoph Hellwig
<hch@infradead.org>
https://lore.kernel.org/r/20190902075006.GB754@infradead.org]
Link: https://lore.kernel.org/r/20190822161013.5481-3-logang@deltatee.comSigned-off-by: NLogan Gunthorpe <logang@deltatee.com>
Signed-off-by: NBjorn Helgaas <bhelgaas@google.com>
上级 70aaf61a
...@@ -6117,39 +6117,31 @@ void pci_reassigndev_resource_alignment(struct pci_dev *dev) ...@@ -6117,39 +6117,31 @@ void pci_reassigndev_resource_alignment(struct pci_dev *dev)
} }
} }
static ssize_t pci_set_resource_alignment_param(const char *buf, size_t count) static ssize_t resource_alignment_show(struct bus_type *bus, char *buf)
{
spin_lock(&resource_alignment_lock);
kfree(resource_alignment_param);
resource_alignment_param = kstrndup(buf, count, GFP_KERNEL);
spin_unlock(&resource_alignment_lock);
return resource_alignment_param ? count : -ENOMEM;
}
static ssize_t pci_get_resource_alignment_param(char *buf, size_t size)
{ {
size_t count = 0; size_t count = 0;
spin_lock(&resource_alignment_lock); spin_lock(&resource_alignment_lock);
if (resource_alignment_param) if (resource_alignment_param)
count = snprintf(buf, size, "%s", resource_alignment_param); count = snprintf(buf, PAGE_SIZE, "%s", resource_alignment_param);
spin_unlock(&resource_alignment_lock); spin_unlock(&resource_alignment_lock);
return count; return count;
} }
static ssize_t resource_alignment_show(struct bus_type *bus, char *buf)
{
return pci_get_resource_alignment_param(buf, PAGE_SIZE);
}
static ssize_t resource_alignment_store(struct bus_type *bus, static ssize_t resource_alignment_store(struct bus_type *bus,
const char *buf, size_t count) const char *buf, size_t count)
{ {
return pci_set_resource_alignment_param(buf, count); char *param = kstrndup(buf, count, GFP_KERNEL);
if (!param)
return -ENOMEM;
spin_lock(&resource_alignment_lock);
kfree(resource_alignment_param);
resource_alignment_param = param;
spin_unlock(&resource_alignment_lock);
return count;
} }
static BUS_ATTR_RW(resource_alignment); static BUS_ATTR_RW(resource_alignment);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册