/linux-6.12.1/drivers/nvmem/ |
D | core.c | 3 * nvmem framework core. 16 #include <linux/nvmem-consumer.h> 17 #include <linux/nvmem-provider.h> 37 struct nvmem_device *nvmem; member 58 static int __nvmem_reg_read(struct nvmem_device *nvmem, unsigned int offset, in __nvmem_reg_read() argument 61 if (nvmem->reg_read) in __nvmem_reg_read() 62 return nvmem->reg_read(nvmem->priv, offset, val, bytes); in __nvmem_reg_read() 67 static int __nvmem_reg_write(struct nvmem_device *nvmem, unsigned int offset, in __nvmem_reg_write() argument 72 if (nvmem->reg_write) { in __nvmem_reg_write() 73 gpiod_set_value_cansleep(nvmem->wp_gpio, 0); in __nvmem_reg_write() [all …]
|
D | Makefile | 3 # Makefile for nvmem drivers. 13 obj-$(CONFIG_NVMEM_APPLE_EFUSES) += nvmem-apple-efuses.o 14 nvmem-apple-efuses-y := apple-efuses.o 15 obj-$(CONFIG_NVMEM_BCM_OCOTP) += nvmem-bcm-ocotp.o 16 nvmem-bcm-ocotp-y := bcm-ocotp.o 19 obj-$(CONFIG_NVMEM_IMX_IIM) += nvmem-imx-iim.o 20 nvmem-imx-iim-y := imx-iim.o 21 obj-$(CONFIG_NVMEM_IMX_OCOTP) += nvmem-imx-ocotp.o 22 nvmem-imx-ocotp-y := imx-ocotp.o 23 obj-$(CONFIG_NVMEM_IMX_OCOTP_ELE) += nvmem-imx-ocotp-ele.o [all …]
|
D | layouts.c | 3 * NVMEM layout bus handling 11 #include <linux/nvmem-consumer.h> 12 #include <linux/nvmem-provider.h> 49 .name = "nvmem-layout", 79 static int nvmem_layout_create_device(struct nvmem_device *nvmem, in nvmem_layout_create_device() argument 91 layout->nvmem = nvmem; in nvmem_layout_create_device() 92 nvmem->layout = layout; in nvmem_layout_create_device() 97 dev->parent = &nvmem->dev; in nvmem_layout_create_device() 120 static int nvmem_layout_bus_populate(struct nvmem_device *nvmem, in nvmem_layout_bus_populate() argument 145 /* NVMEM layout buses expect only a single device representing the layout */ in nvmem_layout_bus_populate() [all …]
|
D | Kconfig | 2 menuconfig NVMEM config 3 bool "NVMEM Support" 6 Support for NVMEM(Non Volatile Memory) devices like EEPROM, EFUSES... 8 This framework is designed to provide a generic interface to NVMEM 13 if NVMEM 16 bool "/sys/bus/nvmem/devices/*/nvmem (sysfs interface)" 20 Say Y here to add a sysfs interface for NVMEM. 23 read/write directly into nvmem. 27 source "drivers/nvmem/layouts/Kconfig" 41 be called nvmem-apple-efuses. [all …]
|
/linux-6.12.1/Documentation/driver-api/ |
D | nvmem.rst | 4 NVMEM Subsystem 9 This document explains the NVMEM Framework along with the APIs provided, 14 *NVMEM* is the abbreviation for Non Volatile Memory layer. It is used to 18 Before this framework existed, NVMEM drivers like eeprom were stored in 31 NVMEM Providers 34 NVMEM provider refers to an entity that implements methods to initialize, read 37 2. Registering/Unregistering the NVMEM provider 40 A NVMEM provider can register with NVMEM core by supplying relevant 41 nvmem configuration to nvmem_register(), on success core would return a valid 62 Users of board files can define and register nvmem cells using the [all …]
|
/linux-6.12.1/Documentation/devicetree/bindings/nvmem/ |
D | nvmem-consumer.yaml | 4 $id: http://devicetree.org/schemas/nvmem/nvmem-consumer.yaml# 7 title: NVMEM (Non Volatile Memory) Consumer 15 nvmem: 18 List of phandle to the nvmem providers. 20 nvmem-cells: 23 List of phandle to the nvmem data cells. 25 nvmem-names: 27 Names for the each nvmem provider. 29 nvmem-cell-names: 31 Names for each nvmem-cells specified. [all …]
|
D | nvmem.yaml | 4 $id: http://devicetree.org/schemas/nvmem/nvmem.yaml# 7 title: NVMEM (Non Volatile Memory) 17 some data on NVMEM, for the OS to be able to retrieve these 42 nvmem-layout: 43 $ref: /schemas/nvmem/layouts/nvmem-layout.yaml 45 Alternative to the statically defined nvmem cells, this 65 nvmem-layout {
|
D | xlnx,zynqmp-nvmem.yaml | 4 $id: http://devicetree.org/schemas/nvmem/xlnx,zynqmp-nvmem.yaml# 18 - $ref: nvmem.yaml# 22 const: xlnx,zynqmp-nvmem-fw 31 soc-nvmem { 32 compatible = "xlnx,zynqmp-nvmem-fw"; 33 nvmem-layout {
|
/linux-6.12.1/Documentation/devicetree/bindings/mtd/partitions/ |
D | nvmem-cells.yaml | 4 $id: http://devicetree.org/schemas/mtd/partitions/nvmem-cells.yaml# 7 title: Nvmem cells 10 Any partition containing the compatible "nvmem-cells" will register as a 11 nvmem provider. 12 Each direct subnodes represents a nvmem cell following the nvmem binding. 13 Nvmem binding to declare nvmem-cells can be found in: 14 Documentation/devicetree/bindings/nvmem/nvmem.yaml 21 - $ref: /schemas/nvmem/nvmem.yaml# 22 - $ref: /schemas/nvmem/nvmem-deprecated-cells.yaml# 26 const: nvmem-cells [all …]
|
/linux-6.12.1/include/linux/ |
D | nvmem-provider.h | 3 * nvmem framework provider. 40 * struct nvmem_keepout - NVMEM register keepout range. 53 * struct nvmem_cell_info - NVMEM cell description 55 * @offset: Offset within the NVMEM device. 78 * struct nvmem_config - NVMEM device configuration 84 * @cells: Optional array of pre-defined NVMEM cells. 86 * @add_legacy_fixed_of_cells: Read fixed NVMEM cells from old OF syntax. 91 * @type: Type of the nvmem storage 102 * @layout: Fixed layout associated with this nvmem device. 104 * Note: A default "nvmem<id>" name will be assigned to the device if [all …]
|
D | nvmem-consumer.h | 3 * nvmem framework consumer. 27 * @cell_name: Name of the nvmem cell as defined in the name field of 68 /* direct nvmem device read/write interface */ 72 void nvmem_device_put(struct nvmem_device *nvmem); 73 void devm_nvmem_device_put(struct device *dev, struct nvmem_device *nvmem); 74 int nvmem_device_read(struct nvmem_device *nvmem, unsigned int offset, 76 int nvmem_device_write(struct nvmem_device *nvmem, unsigned int offset, 78 ssize_t nvmem_device_cell_read(struct nvmem_device *nvmem, 80 int nvmem_device_cell_write(struct nvmem_device *nvmem, 83 const char *nvmem_dev_name(struct nvmem_device *nvmem); [all …]
|
/linux-6.12.1/Documentation/devicetree/bindings/thermal/ |
D | sprd-thermal.yaml | 30 nvmem-cells: 33 Reference to nvmem nodes for the calibration data. 35 nvmem-cell-names: 60 nvmem-cells: 63 Reference to an nvmem node for the calibration data. 65 nvmem-cell-names: 70 - nvmem-cells 71 - nvmem-cell-names 80 - nvmem-cells 81 - nvmem-cell-names [all …]
|
D | mediatek,lvts-thermal.yaml | 43 nvmem-cells: 49 nvmem-cell-names: 72 nvmem-cells: 75 nvmem-cell-names: 88 nvmem-cells: 91 nvmem-cell-names: 100 - nvmem-cells 101 - nvmem-cell-names 122 nvmem-cells = <&lvts_efuse_data1 &lvts_efuse_data2>; 123 nvmem-cell-names = "lvts-calib-data-1", "lvts-calib-data-2";
|
/linux-6.12.1/Documentation/devicetree/bindings/power/reset/ |
D | nvmem-reboot-mode.yaml | 4 $id: http://devicetree.org/schemas/power/reset/nvmem-reboot-mode.yaml# 7 title: Generic NVMEM reboot mode 14 and stores it in the NVMEM cell named "reboot-mode". The bootloader can 19 const: nvmem-reboot-mode 21 nvmem-cells: 23 A phandle pointing to the nvmem-cells node where the vendor-specific 27 nvmem-cell-names: 36 - nvmem-cells 37 - nvmem-cell-names 44 compatible = "nvmem-reboot-mode"; [all …]
|
/linux-6.12.1/Documentation/devicetree/bindings/nvmem/layouts/ |
D | fixed-layout.yaml | 4 $id: http://devicetree.org/schemas/nvmem/layouts/fixed-layout.yaml# 7 title: NVMEM layout for fixed NVMEM cells 10 Many NVMEM devices have hardcoded cells layout (offset and size of defined 11 NVMEM content doesn't change). 13 This binding allows defining such NVMEM layout with its cells. It can be used 14 on top of any NVMEM device. 42 nvmem-layout { 50 #nvmem-cell-cells = <1>; 56 #nvmem-cell-cells = <1>;
|
/linux-6.12.1/Documentation/devicetree/bindings/iio/adc/ |
D | sprd,sc2720-adc.yaml | 37 nvmem-cells: true 39 nvmem-cell-names: true 51 nvmem-cells: 53 nvmem-cell-names: 60 nvmem-cells: 62 nvmem-cell-names: 77 - nvmem-cells 78 - nvmem-cell-names 95 nvmem-cells = <&adc_big_scale>, <&adc_small_scale>; 96 nvmem-cell-names = "big_scale_calib", "small_scale_calib"; [all …]
|
/linux-6.12.1/arch/arm64/boot/dts/freescale/ |
D | fsl-ls1028a-kontron-kbox-a-230-ls.dts | 59 nvmem-cells = <&base_mac_address 2>; 60 nvmem-cell-names = "mac-address"; 65 nvmem-cells = <&base_mac_address 3>; 66 nvmem-cell-names = "mac-address"; 87 nvmem-cells = <&base_mac_address 4>; 88 nvmem-cell-names = "mac-address"; 97 nvmem-cells = <&base_mac_address 5>; 98 nvmem-cell-names = "mac-address"; 107 nvmem-cells = <&base_mac_address 6>; 108 nvmem-cell-names = "mac-address"; [all …]
|
/linux-6.12.1/Documentation/ABI/stable/ |
D | sysfs-bus-nvmem | 1 What: /sys/bus/nvmem/devices/.../force_ro 18 What: /sys/bus/nvmem/devices/.../nvmem 23 This file allows user to read/write the raw NVMEM contents. 24 Permissions for write to this file depends on the nvmem 31 hexdump /sys/bus/nvmem/devices/qfprom0/nvmem 41 What: /sys/bus/nvmem/devices/.../type 46 This read-only attribute allows user to read the NVMEM
|
/linux-6.12.1/Documentation/devicetree/bindings/net/ |
D | sunplus,sp7021-emac.yaml | 62 nvmem-cells: 64 - description: nvmem cell address of MAC address 66 nvmem-cell-names: 67 description: names corresponding to the nvmem cells 75 - nvmem-cells 76 - nvmem-cell-names 117 nvmem-cells = <&mac_addr0>; 118 nvmem-cell-names = "mac-address"; 125 nvmem-cells = <&mac_addr1>; 126 nvmem-cell-names = "mac-address";
|
/linux-6.12.1/drivers/mtd/ubi/ |
D | nvmem.c | 6 /* UBI NVMEM provider */ 8 #include <linux/nvmem-provider.h> 10 /* List of all NVMEM devices */ 15 struct nvmem_device *nvmem; member 71 if (!of_get_child_by_name(np, "nvmem-layout")) in ubi_nvmem_add() 99 unv->nvmem = nvmem_register(&config); in ubi_nvmem_add() 100 if (IS_ERR(unv->nvmem)) { in ubi_nvmem_add() 101 ret = dev_err_probe(vi->dev, PTR_ERR(unv->nvmem), in ubi_nvmem_add() 102 "Failed to register NVMEM device\n"); in ubi_nvmem_add() 132 nvmem_unregister(unv->nvmem); in ubi_nvmem_remove() [all …]
|
/linux-6.12.1/arch/arm/boot/dts/broadcom/ |
D | bcm47094-asus-rt-ac3100.dts | 16 #nvmem-cell-cells = <1>; 22 nvmem-cells = <&et0macaddr 0>; 23 nvmem-cell-names = "mac-address"; 27 nvmem-cells = <&et0macaddr 1>; 28 nvmem-cell-names = "mac-address"; 32 nvmem-cells = <&et0macaddr 2>; 33 nvmem-cell-names = "mac-address";
|
/linux-6.12.1/drivers/rtc/ |
D | nvmem.c | 3 * RTC subsystem, nvmem interface 10 #include <linux/nvmem-consumer.h> 17 struct nvmem_device *nvmem; in devm_rtc_nvmem_register() local 25 nvmem = devm_nvmem_register(dev, nvmem_config); in devm_rtc_nvmem_register() 26 if (IS_ERR(nvmem)) in devm_rtc_nvmem_register() 27 dev_err(dev, "failed to register nvmem device for RTC\n"); in devm_rtc_nvmem_register() 29 return PTR_ERR_OR_ZERO(nvmem); in devm_rtc_nvmem_register()
|
/linux-6.12.1/drivers/nvmem/layouts/ |
D | sl28vpd.c | 5 #include <linux/nvmem-consumer.h> 6 #include <linux/nvmem-provider.h> 56 static int sl28vpd_v1_check_crc(struct device *dev, struct nvmem_device *nvmem) in sl28vpd_v1_check_crc() argument 65 ret = nvmem_device_read(nvmem, 0, sizeof(data_v1), &data_v1); in sl28vpd_v1_check_crc() 85 struct nvmem_device *nvmem = layout->nvmem; in sl28vpd_add_cells() local 94 ret = nvmem_device_read(nvmem, 0, sizeof(hdr), &hdr); in sl28vpd_add_cells() 110 ret = sl28vpd_v1_check_crc(dev, nvmem); in sl28vpd_add_cells() 114 layout_np = of_nvmem_layout_get_container(nvmem); in sl28vpd_add_cells() 127 ret = nvmem_add_one_cell(nvmem, &info); in sl28vpd_add_cells() 169 MODULE_DESCRIPTION("NVMEM layout driver for the VPD of Kontron sl28 boards");
|
/linux-6.12.1/Documentation/devicetree/bindings/phy/ |
D | sunplus,sp7021-usb2-phy.yaml | 36 nvmem-cell-names: 37 description: names corresponding to the nvmem cells of disconnect voltage 40 nvmem-cells: 41 description: nvmem cell address of disconnect voltage 55 - nvmem-cell-names 56 - nvmem-cells 70 nvmem-cell-names = "disc_vol"; 71 nvmem-cells = <&disc_vol>;
|
/linux-6.12.1/drivers/soc/tegra/fuse/ |
D | fuse-tegra.c | 13 #include <linux/nvmem-consumer.h> 14 #include <linux/nvmem-provider.h> 143 struct nvmem_config nvmem; in tegra_fuse_probe() local 210 memset(&nvmem, 0, sizeof(nvmem)); in tegra_fuse_probe() 211 nvmem.dev = &pdev->dev; in tegra_fuse_probe() 212 nvmem.name = "fuse"; in tegra_fuse_probe() 213 nvmem.id = -1; in tegra_fuse_probe() 214 nvmem.owner = THIS_MODULE; in tegra_fuse_probe() 215 nvmem.cells = fuse->soc->cells; in tegra_fuse_probe() 216 nvmem.ncells = fuse->soc->num_cells; in tegra_fuse_probe() [all …]
|