/openbmc/linux/include/linux/ |
H A D | peci.h | 13 * Currently we don't support any PECI command over 32 bytes. 21 * struct peci_controller_ops - PECI controller specific methods 22 * @xfer: PECI transfer function 24 * PECI controllers may have different hardware interfaces - the drivers 25 * implementing PECI controllers can use this structure to abstract away those 26 * differences by exposing a common interface for PECI core. 33 * struct peci_controller - PECI controller 34 * @dev: device object to register PECI controller to the device model 37 * @id: PECI controller ID 39 * PECI controllers usually connect to their drivers using non-PECI bus, [all …]
|
/openbmc/linux/Documentation/peci/ |
H A D | peci.rst | 7 The Platform Environment Control Interface (PECI) is a communication 10 PECI provides services that allow the management controller to 13 controller is acting as a PECI originator and the processor - as 14 a PECI responder. 15 PECI can be used in both single processor and multiple-processor based 19 Intel PECI specification is not released as a dedicated document, 24 PECI Wire 27 PECI Wire interface uses a single wire for self-clocking and data 32 value is logic '0' or logic '1'. PECI Wire also includes variable data 35 For PECI Wire, each processor package will utilize unique, fixed [all …]
|
/openbmc/linux/drivers/hwmon/peci/ |
H A D | Kconfig | 4 tristate "PECI CPU temperature monitoring client" 5 depends on PECI 9 If you say yes here you get support for the generic Intel PECI 12 the processor PECI interface. 15 will be called peci-cputemp. 18 tristate "PECI DIMM temperature monitoring client" 19 depends on PECI 23 If you say yes here you get support for the generic Intel PECI hwmon 25 accessible via the processor PECI interface. 28 will be called peci-dimmtemp.
|
H A D | Makefile | 3 peci-cputemp-y := cputemp.o 4 peci-dimmtemp-y := dimmtemp.o 6 obj-$(CONFIG_SENSORS_PECI_CPUTEMP) += peci-cputemp.o 7 obj-$(CONFIG_SENSORS_PECI_DIMMTEMP) += peci-dimmtemp.o
|
/openbmc/linux/drivers/peci/ |
H A D | Kconfig | 3 menuconfig PECI config 4 tristate "PECI support" 6 The Platform Environment Control Interface (PECI) is an interface 15 will be called peci. 17 if PECI 20 tristate "PECI CPU" 23 This option enables peci-cpu driver for Intel processors. It is 32 will be called peci-cpu. 34 source "drivers/peci/controller/Kconfig" 36 endif # PECI
|
H A D | cpu.c | 6 #include <linux/peci.h> 7 #include <linux/peci-cpu.h> 13 * peci_temp_read() - read the maximum die temperature from PECI target device 14 * @device: PECI device to which request is going to be sent 17 * It uses GetTemp PECI command. 39 * @device: PECI device to which request is going to be sent 44 * It uses RdPkgConfig PECI command. 71 * @device: PECI device to which request is going to be sent 78 * It uses RdPCIConfigLocal PECI command. 106 * @device: PECI device to which request is going to be sent [all …]
|
H A D | request.c | 7 #include <linux/peci.h> 94 * peci_request_status() - return -errno based on PECI completion code 95 * @req: the PECI request that contains response data with completion code 127 WARN_ONCE(1, "Unknown PECI completion code: %#02x\n", cc); in peci_request_status() 131 EXPORT_SYMBOL_NS_GPL(peci_request_status, PECI); 184 * @device: PECI device to which request is going to be sent 202 * PECI controllers that we are using now don't support DMA, this in peci_request_alloc() 216 EXPORT_SYMBOL_NS_GPL(peci_request_alloc, PECI); 220 * @req: the PECI request to be freed 226 EXPORT_SYMBOL_NS_GPL(peci_request_free, PECI); [all …]
|
H A D | core.c | 10 #include <linux/peci.h> 93 * Detach any active PECI devices. This can't fail, thus we do not in unregister_controller() 106 * devm_peci_controller_add() - add PECI controller 111 * devm_peci_controller_add() to register itself with the PECI bus. 125 ret = dev_set_name(&controller->dev, "peci-%d", controller->id); in devm_peci_controller_add() 161 EXPORT_SYMBOL_NS_GPL(devm_peci_controller_add, PECI); 205 .name = "peci", 218 pr_err("peci: failed to register PECI bus type!\n"); in peci_init() 235 MODULE_DESCRIPTION("PECI bus core module");
|
H A D | device.c | 5 #include <linux/peci.h> 6 #include <linux/peci-cpu.h> 12 * PECI device can be removed using sysfs, but the removal can also happen as 14 * Mutex is used to protect PECI device from being double-deleted. 29 * PECI device may be in a state where it is unable to return a proper in peci_get_revision() 119 * PECI Ping is a command encoded by tx_len = 0, rx_len = 0. in peci_detect() 223 pr_err("peci: trying to register driver without probe callback\n"); in __peci_driver_register() 228 pr_err("peci: trying to register driver without device id table\n"); in __peci_driver_register() 234 EXPORT_SYMBOL_NS_GPL(__peci_driver_register, PECI); 240 EXPORT_SYMBOL_NS_GPL(peci_driver_unregister, PECI);
|
H A D | internal.h | 15 /* PECI CPU address range 0x30-0x37 */ 67 * struct peci_device_id - PECI device data to match 88 * struct peci_driver - PECI driver 92 * @id_table: PECI device match table to decide which device to bind 109 * peci_driver_register() - register PECI driver 112 * PECI drivers that don't need to do anything special in module init should 122 * module_peci_driver() - helper macro for registering a modular PECI driver 125 * Helper macro for PECI drivers which do not do anything special in module
|
H A D | Makefile | 4 peci-y := core.o request.o device.o sysfs.o 5 obj-$(CONFIG_PECI) += peci.o 6 peci-cpu-y := cpu.o 7 obj-$(CONFIG_PECI_CPU) += peci-cpu.o
|
/openbmc/linux/Documentation/translations/zh_CN/peci/ |
H A D | peci.rst | 4 :Original: Documentation/peci/peci.rst 16 平台环境控制接口(PECI)是英特尔处理器和管理控制器(如底板管理控制器,BMC) 24 PECI 线 41 include/linux/peci.h 43 drivers/peci/internal.h 45 drivers/peci/core.c 47 drivers/peci/request.c 49 PECI CPU 驱动 API 54 drivers/peci/cpu.c
|
/openbmc/linux/Documentation/devicetree/bindings/peci/ |
H A D | peci-aspeed.yaml | 4 $id: http://devicetree.org/schemas/peci/peci-aspeed.yaml# 7 title: Aspeed PECI Bus 14 - $ref: peci-controller.yaml# 19 - aspeed,ast2400-peci 20 - aspeed,ast2500-peci 21 - aspeed,ast2600-peci 31 Clock source for PECI controller. Should reference the external 45 The desired operation frequency of PECI controller in Hz. 63 peci-controller@1e78b000 { 64 compatible = "aspeed,ast2600-peci";
|
H A D | nuvoton,npcm-peci.yaml | 4 $id: http://devicetree.org/schemas/peci/nuvoton,npcm-peci.yaml# 7 title: Nuvoton PECI Bus 13 - $ref: peci-controller.yaml# 18 - nuvoton,npcm750-peci 19 - nuvoton,npcm845-peci 29 Clock source for PECI controller. Should reference the APB clock. 49 peci-controller@f0100000 { 50 compatible = "nuvoton,npcm750-peci";
|
H A D | peci-controller.yaml | 4 $id: http://devicetree.org/schemas/peci/peci-controller.yaml# 7 title: Generic for PECI 13 PECI (Platform Environment Control Interface) is an interface that provides a 19 pattern: "^peci-controller(@.*)?$" 29 peci-controller@1e78b000 {
|
/openbmc/linux/drivers/peci/controller/ |
H A D | Kconfig | 4 tristate "ASPEED PECI support" 10 This option enables PECI controller driver for ASPEED AST2400, 12 connected to it, and communicate with them using PECI protocol. 18 be called peci-aspeed. 21 tristate "Nuvoton NPCM PECI support" 26 This option enables PECI controller driver for Nuvoton NPCM7XX 28 to it and communicate with them using PECI protocol. 31 Interface (PECI) bus adapter driver on the Nuvoton NPCM SoCs. 34 will be called peci-npcm.
|
/openbmc/linux/Documentation/hwmon/ |
H A D | asc7621.rst | 20 Andigilog has both the PECI and pre-PECI versions of the Heceta-6, as 22 added PECI and a 4th thermal zone. The Andigilog aSC7611 is the 65 PECI Extended configuration allows for having more than two domains per 66 PECI address and also provides an enabling function for each PECI 68 assigned to up to 4 PECI addresses. This is not possible in the default 89 Environmental Control Interface (PECI) is included. 114 - Supports PECI interface and monitors internal and remote thermal diodes 137 peci_legacy = 1, PECI Processor Temperature 0 141 4 PECI Processor Temperature 0 142 5 PECI Processor Temperature 1 [all …]
|
H A D | w83795.rst | 83 29/ 30 PECI/TSI (DTS1) 26h temp7 84 29/ 30 PECI/TSI (DTS2) 27h temp8 85 29/ 30 PECI/TSI (DTS3) 28h temp9 86 29/ 30 PECI/TSI (DTS4) 29h temp10 87 29/ 30 PECI/TSI (DTS5) 2Ah temp11 88 29/ 30 PECI/TSI (DTS6) 2Bh temp12 89 29/ 30 PECI/TSI (DTS7) 2Ch temp13 90 29/ 30 PECI/TSI (DTS8) 2Dh temp14 133 23 PECI (DTS1) 26h temp7 134 23 PECI (DTS2) 27h temp8 [all …]
|
/openbmc/dbus-sensors/src/tests/ |
H A D | test_Utils.cpp | 58 peciDir = fs::path(testDir) / "peci"; in createPECIDir() 60 "peci-0/device/0-30/peci-cputemp.0/hwmon/hwmon25"; in createPECIDir() 68 auto devDir = peciDir / "peci-0/peci_dev/peci-0"; in createPECIDir() 70 fs::create_directory_symlink("../../../peci-0", devDir / "device"); in createPECIDir() 71 fs::create_directory_symlink("device/0-30", peciDir / "peci-0/0-30"); in createPECIDir() 119 findFiles(peciDir, R"(peci-\d+/\d+-.+/peci-.+/hwmon/hwmon\d+/aaa$)", in TEST_F() 130 findFiles(peciDir, R"(peci-\d+/\d+-.+/peci-.+/hwmon/hwmon\d+/name$)", in TEST_F() 138 R"(peci-\d+/\d+-.+/peci-.+/hwmon/hwmon\d+/temp\d+_input)", in TEST_F() 159 findFiles(p, R"(peci-\d+/\d+-.+/peci-.+/hwmon/hwmon\d+/temp\d+_input)", in TEST_F() 170 findFiles(peciDir / "peci-0", R"(\d+-.+/peci-.+/hwmon/hwmon\d+/name$)", in TEST_F() [all …]
|
/openbmc/openbmc/meta-phosphor/recipes-x86/libpeci/ |
H A D | libpeci_git.bb | 1 SUMMARY = "PECI Library" 2 DESCRIPTION = "PECI Library" 7 PACKAGECONFIG[dbus-raw-peci] = "-Draw-peci='enabled',-Draw-peci='disabled',boost sdbusplus" 13 SYSTEMD_SERVICE:${PN} += "${@bb.utils.contains('PACKAGECONFIG', 'dbus-raw-peci', 'com.intel.peci.se…
|
/openbmc/u-boot/cmd/aspeed/ |
H A D | peci.c | 49 /* release PECI reset */ in ast2500_peci_init() 55 * 1. disable PECI in ast2500_peci_init() 67 /* enable PECI */ in ast2500_peci_init() 83 /* release PECI reset */ in ast2600_peci_init() 87 * 1. disable PECI in ast2600_peci_init() 100 /* enable PECI */ in ast2600_peci_init() 126 /* make PECI no operation */ in do_ast_peci_ping() 135 /* fire PECI command */ in do_ast_peci_ping() 138 /* wait PECI done for 10 seconds */ in do_ast_peci_ping() 139 printf("Waiting PECI ... "); in do_ast_peci_ping() [all …]
|
/openbmc/openbmc/meta-quanta/meta-olympus-nuvoton/recipes-phosphor/sensors/ |
H A D | phosphor-hwmon_%.bbappend | 29 # PECI 31 peci-0/0-30/peci-cputemp.0 \ 32 peci-0/0-31/peci-cputemp.1\ 33 peci-0/0-30/peci-dimmtemp.0 \ 35 PECIITEMSFMT = "devices/platform/ahb/ahb--apb/f0100000.peci-bus/{0}.conf"
|
/openbmc/phosphor-dbus-interfaces/yaml/com/intel/Protocol/PECI/ |
H A D | Raw.interface.yaml | 2 Implement to provide D-Bus raw PECI access to the CPU. 7 Send raw PECI command(s) to the CPU 12 The path for the PECI device to use for the command 17 bytes for a single PECI command. The larger array allows 18 sending multiple PECI commands in a single transaction. 24 bytes for a single PECI response corresponding to the command in
|
/openbmc/linux/Documentation/ABI/testing/ |
H A D | sysfs-bus-peci | 1 What: /sys/bus/peci/rescan 7 initiate scan for PECI devices on all PECI controllers 10 What: /sys/bus/peci/devices/<controller_id>-<device_addr>/remove 16 remove the PECI device and any of its children.
|
/openbmc/openbmc/meta-phosphor/recipes-phosphor/smbios/ |
H A D | smbios-mdr_git.bb | 1 SUMMARY = "Extract CPU and Memory Inventory from SMSMBIOS Table and PECI" 2 DESCRIPTION = "This package parses SMBIOS tables, reads Intel CPU PIROM and PECI and provides a dedicated IPMI blob to receive SMBIOS tables sent from LinuxBoot" 16 PACKAGECONFIG[cpuinfo-peci] = "-Dcpuinfo-peci=enabled,-Dcpuinfo-peci=disabled,libpeci"
|