diff options
Diffstat (limited to 'rust/helpers')
| -rw-r--r-- | rust/helpers/auxiliary.c | 10 | ||||
| -rw-r--r-- | rust/helpers/device.c | 17 | ||||
| -rw-r--r-- | rust/helpers/dma.c | 5 | ||||
| -rw-r--r-- | rust/helpers/helpers.c | 4 | ||||
| -rw-r--r-- | rust/helpers/io.c | 41 | ||||
| -rw-r--r-- | rust/helpers/of.c | 8 | ||||
| -rw-r--r-- | rust/helpers/pci.c | 10 | ||||
| -rw-r--r-- | rust/helpers/platform.c | 10 | ||||
| -rw-r--r-- | rust/helpers/poll.c | 10 | ||||
| -rw-r--r-- | rust/helpers/property.c | 8 | ||||
| -rw-r--r-- | rust/helpers/regulator.c | 43 | ||||
| -rw-r--r-- | rust/helpers/task.c | 6 | 
12 files changed, 142 insertions, 30 deletions
| diff --git a/rust/helpers/auxiliary.c b/rust/helpers/auxiliary.c index 0db3860d774e..8b5e0fea4493 100644 --- a/rust/helpers/auxiliary.c +++ b/rust/helpers/auxiliary.c @@ -2,16 +2,6 @@  #include <linux/auxiliary_bus.h> -void rust_helper_auxiliary_set_drvdata(struct auxiliary_device *adev, void *data) -{ -	auxiliary_set_drvdata(adev, data); -} - -void *rust_helper_auxiliary_get_drvdata(struct auxiliary_device *adev) -{ -	return auxiliary_get_drvdata(adev); -} -  void rust_helper_auxiliary_device_uninit(struct auxiliary_device *adev)  {  	return auxiliary_device_uninit(adev); diff --git a/rust/helpers/device.c b/rust/helpers/device.c index b2135c6686b0..9a4316bafedf 100644 --- a/rust/helpers/device.c +++ b/rust/helpers/device.c @@ -8,3 +8,20 @@ int rust_helper_devm_add_action(struct device *dev,  {  	return devm_add_action(dev, action, data);  } + +int rust_helper_devm_add_action_or_reset(struct device *dev, +					 void (*action)(void *), +					 void *data) +{ +	return devm_add_action_or_reset(dev, action, data); +} + +void *rust_helper_dev_get_drvdata(const struct device *dev) +{ +	return dev_get_drvdata(dev); +} + +void rust_helper_dev_set_drvdata(struct device *dev, void *data) +{ +	dev_set_drvdata(dev, data); +} diff --git a/rust/helpers/dma.c b/rust/helpers/dma.c index df8b8a77355a..6e741c197242 100644 --- a/rust/helpers/dma.c +++ b/rust/helpers/dma.c @@ -14,3 +14,8 @@ void rust_helper_dma_free_attrs(struct device *dev, size_t size, void *cpu_addr,  {  	dma_free_attrs(dev, size, cpu_addr, dma_handle, attrs);  } + +int rust_helper_dma_set_mask_and_coherent(struct device *dev, u64 mask) +{ +	return dma_set_mask_and_coherent(dev, mask); +} diff --git a/rust/helpers/helpers.c b/rust/helpers/helpers.c index b15b3cddad4e..2bb13285825b 100644 --- a/rust/helpers/helpers.c +++ b/rust/helpers/helpers.c @@ -28,11 +28,15 @@  #include "kunit.c"  #include "mm.c"  #include "mutex.c" +#include "of.c"  #include "page.c"  #include "platform.c"  #include "pci.c"  #include "pid_namespace.c" +#include "poll.c" +#include "property.c"  #include "rbtree.c" +#include "regulator.c"  #include "rcu.c"  #include "refcount.c"  #include "security.c" diff --git a/rust/helpers/io.c b/rust/helpers/io.c index 15ea187c5466..c475913c69e6 100644 --- a/rust/helpers/io.c +++ b/rust/helpers/io.c @@ -1,12 +1,18 @@  // SPDX-License-Identifier: GPL-2.0  #include <linux/io.h> +#include <linux/ioport.h>  void __iomem *rust_helper_ioremap(phys_addr_t offset, size_t size)  {  	return ioremap(offset, size);  } +void __iomem *rust_helper_ioremap_np(phys_addr_t offset, size_t size) +{ +	return ioremap_np(offset, size); +} +  void rust_helper_iounmap(void __iomem *addr)  {  	iounmap(addr); @@ -99,3 +105,38 @@ void rust_helper_writeq_relaxed(u64 value, void __iomem *addr)  	writeq_relaxed(value, addr);  }  #endif + +resource_size_t rust_helper_resource_size(struct resource *res) +{ +	return resource_size(res); +} + +struct resource *rust_helper_request_mem_region(resource_size_t start, +						resource_size_t n, +						const char *name) +{ +	return request_mem_region(start, n, name); +} + +void rust_helper_release_mem_region(resource_size_t start, resource_size_t n) +{ +	release_mem_region(start, n); +} + +struct resource *rust_helper_request_region(resource_size_t start, +					    resource_size_t n, const char *name) +{ +	return request_region(start, n, name); +} + +struct resource *rust_helper_request_muxed_region(resource_size_t start, +						  resource_size_t n, +						  const char *name) +{ +	return request_muxed_region(start, n, name); +} + +void rust_helper_release_region(resource_size_t start, resource_size_t n) +{ +	release_region(start, n); +} diff --git a/rust/helpers/of.c b/rust/helpers/of.c new file mode 100644 index 000000000000..86b51167c913 --- /dev/null +++ b/rust/helpers/of.c @@ -0,0 +1,8 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include <linux/of.h> + +bool rust_helper_is_of_node(const struct fwnode_handle *fwnode) +{ +	return is_of_node(fwnode); +} diff --git a/rust/helpers/pci.c b/rust/helpers/pci.c index cd0e6bf2cc4d..ef9cb38c81a6 100644 --- a/rust/helpers/pci.c +++ b/rust/helpers/pci.c @@ -2,16 +2,6 @@  #include <linux/pci.h> -void rust_helper_pci_set_drvdata(struct pci_dev *pdev, void *data) -{ -	pci_set_drvdata(pdev, data); -} - -void *rust_helper_pci_get_drvdata(struct pci_dev *pdev) -{ -	return pci_get_drvdata(pdev); -} -  resource_size_t rust_helper_pci_resource_len(struct pci_dev *pdev, int bar)  {  	return pci_resource_len(pdev, bar); diff --git a/rust/helpers/platform.c b/rust/helpers/platform.c index 82171233d12f..1ce89c1a36f7 100644 --- a/rust/helpers/platform.c +++ b/rust/helpers/platform.c @@ -2,16 +2,6 @@  #include <linux/platform_device.h> -void *rust_helper_platform_get_drvdata(const struct platform_device *pdev) -{ -	return platform_get_drvdata(pdev); -} - -void rust_helper_platform_set_drvdata(struct platform_device *pdev, void *data) -{ -	platform_set_drvdata(pdev, data); -} -  bool rust_helper_dev_is_platform(const struct device *dev)  {  	return dev_is_platform(dev); diff --git a/rust/helpers/poll.c b/rust/helpers/poll.c new file mode 100644 index 000000000000..7e5b1751c2d5 --- /dev/null +++ b/rust/helpers/poll.c @@ -0,0 +1,10 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include <linux/export.h> +#include <linux/poll.h> + +void rust_helper_poll_wait(struct file *filp, wait_queue_head_t *wait_address, +			   poll_table *p) +{ +	poll_wait(filp, wait_address, p); +} diff --git a/rust/helpers/property.c b/rust/helpers/property.c new file mode 100644 index 000000000000..08f68e2dac4a --- /dev/null +++ b/rust/helpers/property.c @@ -0,0 +1,8 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include <linux/property.h> + +void rust_helper_fwnode_handle_put(struct fwnode_handle *fwnode) +{ +	fwnode_handle_put(fwnode); +} diff --git a/rust/helpers/regulator.c b/rust/helpers/regulator.c new file mode 100644 index 000000000000..cd8b7ba648ee --- /dev/null +++ b/rust/helpers/regulator.c @@ -0,0 +1,43 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include <linux/regulator/consumer.h> + +#ifndef CONFIG_REGULATOR + +void rust_helper_regulator_put(struct regulator *regulator) +{ +	regulator_put(regulator); +} + +int rust_helper_regulator_set_voltage(struct regulator *regulator, int min_uV, +				      int max_uV) +{ +	return regulator_set_voltage(regulator, min_uV, max_uV); +} + +int rust_helper_regulator_get_voltage(struct regulator *regulator) +{ +	return regulator_get_voltage(regulator); +} + +struct regulator *rust_helper_regulator_get(struct device *dev, const char *id) +{ +	return regulator_get(dev, id); +} + +int rust_helper_regulator_enable(struct regulator *regulator) +{ +	return regulator_enable(regulator); +} + +int rust_helper_regulator_disable(struct regulator *regulator) +{ +	return regulator_disable(regulator); +} + +int rust_helper_regulator_is_enabled(struct regulator *regulator) +{ +	return regulator_is_enabled(regulator); +} + +#endif diff --git a/rust/helpers/task.c b/rust/helpers/task.c index 31c33ea2dce6..2c85bbc2727e 100644 --- a/rust/helpers/task.c +++ b/rust/helpers/task.c @@ -1,7 +1,13 @@  // SPDX-License-Identifier: GPL-2.0 +#include <linux/kernel.h>  #include <linux/sched/task.h> +void rust_helper_might_resched(void) +{ +	might_resched(); +} +  struct task_struct *rust_helper_get_current(void)  {  	return current; | 
