Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

of: reserved_mem: Accessor for acquiring reserved_mem

In some cases drivers referencing a reserved-memory region might want to
remap the entire region, but when defining the reserved-memory by "size"
the client driver has no means to know the associated base address of
the reserved memory region.

This patch adds an accessor for such drivers to acquire a handle to
their associated reserved-memory for this purpose.

A complicating factor for the implementation is that the reserved_mem
objects are created from the flattened DeviceTree, as such we can't
use the device_node address for comparison. Fortunately the name of the
node will be used as "name" of the reserved_mem and will be used when
building the full_name, so we can compare the "name" with the basename
of the full_name to find the match.

Reviewed-by: Rob Herring <robh@kernel.org>
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: Andy Gross <andy.gross@linaro.org>

authored by

Bjorn Andersson and committed by
Andy Gross
eb297bc7 a50ff19d

+31
+26
drivers/of/of_reserved_mem.c
··· 397 397 rmem->ops->device_release(rmem, dev); 398 398 } 399 399 EXPORT_SYMBOL_GPL(of_reserved_mem_device_release); 400 + 401 + /** 402 + * of_reserved_mem_lookup() - acquire reserved_mem from a device node 403 + * @np: node pointer of the desired reserved-memory region 404 + * 405 + * This function allows drivers to acquire a reference to the reserved_mem 406 + * struct based on a device node handle. 407 + * 408 + * Returns a reserved_mem reference, or NULL on error. 409 + */ 410 + struct reserved_mem *of_reserved_mem_lookup(struct device_node *np) 411 + { 412 + const char *name; 413 + int i; 414 + 415 + if (!np->full_name) 416 + return NULL; 417 + 418 + name = kbasename(np->full_name); 419 + for (i = 0; i < reserved_mem_count; i++) 420 + if (!strcmp(reserved_mem[i].name, name)) 421 + return &reserved_mem[i]; 422 + 423 + return NULL; 424 + } 425 + EXPORT_SYMBOL_GPL(of_reserved_mem_lookup);
+5
include/linux/of_reserved_mem.h
··· 44 44 void fdt_init_reserved_mem(void); 45 45 void fdt_reserved_mem_save_node(unsigned long node, const char *uname, 46 46 phys_addr_t base, phys_addr_t size); 47 + struct reserved_mem *of_reserved_mem_lookup(struct device_node *np); 47 48 #else 48 49 static inline int of_reserved_mem_device_init_by_idx(struct device *dev, 49 50 struct device_node *np, int idx) ··· 56 55 static inline void fdt_init_reserved_mem(void) { } 57 56 static inline void fdt_reserved_mem_save_node(unsigned long node, 58 57 const char *uname, phys_addr_t base, phys_addr_t size) { } 58 + static inline struct reserved_mem *of_reserved_mem_lookup(struct device_node *np) 59 + { 60 + return NULL; 61 + } 59 62 #endif 60 63 61 64 /**