mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
regulator: core: allow regulator_register() with
Merge series from André Draszik <andre.draszik@linaro.org>: With these attached patches it becomes possible again to support hardware designs with multiple PMICs where individual rails of each act as required supplies for rails of the other (due to the latter being e.g. always-on), and vice-versa. Google Pixel 6 and 6 Pro (oriole and raven) are examples of such designs. Rather than returning -EPORBE_DEFER in regulator_register() when set_machine_constraints() fails with -EPROBE_DEFER (due to missing required supplies), we still allow rail registration and try to reresolve supplies each time a new rail gets registered. This is implemented using a bus (regulator bus), which allows the core to reresolve supplies for regulators that still need them whenever new regulators (i.e. devices) are added. Using a bus also solves existing problems around late resolution of supplies as mentioned in the commit message introducing that bus. The series starts with a few bug fixes and the last two commits implement the changes mentioned above, but do depend on the bug fixes.
This commit is contained in:
@@ -19,3 +19,24 @@ int rust_helper_dma_set_mask_and_coherent(struct device *dev, u64 mask)
|
||||
{
|
||||
return dma_set_mask_and_coherent(dev, mask);
|
||||
}
|
||||
|
||||
int rust_helper_dma_set_mask(struct device *dev, u64 mask)
|
||||
{
|
||||
return dma_set_mask(dev, mask);
|
||||
}
|
||||
|
||||
int rust_helper_dma_set_coherent_mask(struct device *dev, u64 mask)
|
||||
{
|
||||
return dma_set_coherent_mask(dev, mask);
|
||||
}
|
||||
|
||||
int rust_helper_dma_map_sgtable(struct device *dev, struct sg_table *sgt,
|
||||
enum dma_data_direction dir, unsigned long attrs)
|
||||
{
|
||||
return dma_map_sgtable(dev, sgt, dir, attrs);
|
||||
}
|
||||
|
||||
size_t rust_helper_dma_max_mapping_size(struct device *dev)
|
||||
{
|
||||
return dma_max_mapping_size(dev);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user