Home
last modified time | relevance | path

Searched full:scom (Results 1 – 25 of 30) sorted by relevance

12

/linux-6.12.1/drivers/fsi/
Dfsi-scom.c3 * SCOM FSI Client device driver
22 /* SCOM engine register set */
47 /* SCOM address encodings */
51 /* SCOM indirect stuff */
145 static int put_indirect_scom_form0(struct scom_device *scom, uint64_t value, in put_indirect_scom_form0() argument
156 rc = __put_scom(scom, ind_data, ind_addr, status); in put_indirect_scom_form0()
160 rc = __get_scom(scom, &ind_data, addr, status); in put_indirect_scom_form0()
170 static int put_indirect_scom_form1(struct scom_device *scom, uint64_t value, in put_indirect_scom_form1() argument
180 return __put_scom(scom, ind_data, ind_addr, status); in put_indirect_scom_form1()
183 static int get_indirect_scom_form0(struct scom_device *scom, uint64_t *value, in get_indirect_scom_form0() argument
[all …]
Di2cr-scom.c37 struct i2cr_scom *scom = filep->private_data; in i2cr_scom_read() local
44 ret = fsi_master_i2cr_read(scom->i2cr, (u32)*offset, &data); in i2cr_scom_read()
58 struct i2cr_scom *scom = filep->private_data; in i2cr_scom_write() local
69 ret = fsi_master_i2cr_write(scom->i2cr, (u32)*offset, data); in i2cr_scom_write()
87 struct i2cr_scom *scom; in i2cr_scom_probe() local
94 scom = devm_kzalloc(dev, sizeof(*scom), GFP_KERNEL); in i2cr_scom_probe()
95 if (!scom) in i2cr_scom_probe()
98 scom->i2cr = to_fsi_master_i2cr(fsi_dev->slave->master); in i2cr_scom_probe()
99 dev_set_drvdata(dev, scom); in i2cr_scom_probe()
101 scom->dev.type = &fsi_cdev_type; in i2cr_scom_probe()
[all …]
DKconfig71 that translates I2C commands to CFAM or SCOM operations, effectively
75 tristate "SCOM FSI client device driver"
77 This option enables an FSI based SCOM device driver.
98 tristate "IBM I2C Responder SCOM driver"
101 This option enables an I2C Responder based SCOM device driver. The
102 I2CR has the capability to directly perform SCOM operations instead
DMakefile9 obj-$(CONFIG_FSI_SCOM) += fsi-scom.o
12 obj-$(CONFIG_I2CR_SCOM) += i2cr-scom.o
/linux-6.12.1/arch/powerpc/platforms/powernv/
Dopal-prd.c275 struct opal_prd_scom scom; in opal_prd_ioctl() local
288 rc = copy_from_user(&scom, (void __user *)param, sizeof(scom)); in opal_prd_ioctl()
292 scom.rc = opal_xscom_read(scom.chip, scom.addr, in opal_prd_ioctl()
293 (__be64 *)&scom.data); in opal_prd_ioctl()
294 scom.data = be64_to_cpu(scom.data); in opal_prd_ioctl()
296 scom.chip, scom.addr, scom.data, scom.rc); in opal_prd_ioctl()
298 rc = copy_to_user((void __user *)param, &scom, sizeof(scom)); in opal_prd_ioctl()
304 rc = copy_from_user(&scom, (void __user *)param, sizeof(scom)); in opal_prd_ioctl()
308 scom.rc = opal_xscom_write(scom.chip, scom.addr, scom.data); in opal_prd_ioctl()
310 scom.chip, scom.addr, scom.data, scom.rc); in opal_prd_ioctl()
[all …]
Dopal-xscom.c3 * PowerNV SCOM bus debugfs interface
197 root = debugfs_create_dir("scom", arch_debugfs_dir); in scom_debug_init()
202 for_each_node_with_property(dn, "scom-controller") { in scom_debug_init()
DKconfig37 bool "Expose SCOM controllers via debugfs"
Dopal-hmi.c211 "SCOM has set a reserved FIR bit to cause recovery", in print_hmi_event_info()
/linux-6.12.1/arch/arm/boot/dts/aspeed/
Dibm-power10-quad.dtsi19 scom100: scom@1000 {
20 compatible = "ibm,i2cr-scom";
47 scom101: scom@1000 {
48 compatible = "ibm,i2cr-scom";
75 scom110: scom@1000 {
76 compatible = "ibm,i2cr-scom";
103 scom111: scom@1000 {
104 compatible = "ibm,i2cr-scom";
131 scom112: scom@1000 {
132 compatible = "ibm,i2cr-scom";
[all …]
Dibm-power11-quad.dtsi137 scom@1000 {
138 compatible = "ibm,p9-scom";
165 scom100: scom@1000 {
166 compatible = "ibm,i2cr-scom";
195 scom101: scom@1000 {
196 compatible = "ibm,i2cr-scom";
225 scom110: scom@1000 {
226 compatible = "ibm,i2cr-scom";
255 scom111: scom@1000 {
256 compatible = "ibm,i2cr-scom";
[all …]
Daspeed-bmc-ibm-fuji.dts2475 scom@1000 {
2476 compatible = "ibm,p9-scom";
2503 scom500: scom@1000 {
2504 compatible = "ibm,i2cr-scom";
2533 scom501: scom@1000 {
2534 compatible = "ibm,i2cr-scom";
2563 scom510: scom@1000 {
2564 compatible = "ibm,i2cr-scom";
2593 scom511: scom@1000 {
2594 compatible = "ibm,i2cr-scom";
[all …]
Daspeed-bmc-ibm-everest.dts2509 scom@1000 {
2537 scom500: scom@1000 {
2538 compatible = "ibm,i2cr-scom";
2569 scom501: scom@1000 {
2570 compatible = "ibm,i2cr-scom";
2601 scom510: scom@1000 {
2602 compatible = "ibm,i2cr-scom";
2633 scom511: scom@1000 {
2634 compatible = "ibm,i2cr-scom";
2665 scom512: scom@1000 {
[all …]
Dibm-power9-dual.dtsi11 scom@1000 {
112 scom@1000 {
Dibm-power10-dual.dtsi18 scom@1000 {
185 scom@1000 {
Daspeed-bmc-opp-palmetto.dts360 scom@1000 {
Daspeed-bmc-opp-tacoma.dts205 scom@1000 {
306 scom@1000 {
/linux-6.12.1/Documentation/devicetree/bindings/fsi/
Dibm,p9-scom.yaml4 $id: http://devicetree.org/schemas/fsi/ibm,p9-scom.yaml#
7 title: IBM FSI-attached SCOM engine
13 The SCOM engine is an interface to the POWER processor PIB (Pervasive
19 - ibm,p9-scom
20 - ibm,i2cr-scom
34 scom@1000 {
35 compatible = "ibm,p9-scom";
Dibm,i2cr-fsi-master.yaml15 writes or SCOM operations, thereby acting as an FSI master.
/linux-6.12.1/include/uapi/linux/
Dfsi.h9 * /dev/scom "raw" ioctl interface
18 /* Structure for SCOM read/write */
20 __u64 addr; /* SCOM address, supports indirect */
21 __u64 data; /* SCOM data (in for write, out for read) */
45 /* Flags for SCOM check */
49 /* Flags for SCOM reset */
/linux-6.12.1/arch/powerpc/kernel/
Dmisc_64.S179 * SCOM access functions for 970 (FX only for now)
195 /* rotate 24 bits SCOM address 8 bits left and mask out its low 8 bits
202 /* do the actual scom read */
213 * the scom on any of the bogus CPUs yet, but may have to be done
229 /* rotate 24 bits SCOM address 8 bits left and mask out its low 8 bits
Dmce_power.c686 * On specific SCOM read via MMIO we may get a machine check in mce_handle_ue_error()
688 * case OPAL may have recovery address to re-read SCOM data in in mce_handle_ue_error()
/linux-6.12.1/drivers/cpufreq/
Dmaple-cpufreq.c32 #define SCOM_PCR 0x0aa001 /* PCR scom addr */
47 #define SCOM_PSR 0x408001 /* PSR scom addr */
75 * SCOM based frequency switching for 970FX rev3
Dpmac64-cpufreq.c38 #define SCOM_PCR 0x0aa001 /* PCR scom addr */
53 #define SCOM_PSR 0x408001 /* PSR scom addr */
145 * SCOM based frequency switching for 970FX rev3
444 freq_method = "SCOM"; in g5_neo2_cpufreq_init()
/linux-6.12.1/Documentation/arch/powerpc/
Dimc.rst98 Trace mode, the 64 bit trace SCOM value is initialized with the event
99 information. The CPMCxSEL and CPMC_LOAD in the trace SCOM, specifies the event
/linux-6.12.1/drivers/hwmon/occ/
Dp8_i2c.c48 /* address is a scom address; bus-endian */ in p8_i2c_occ_getscom()

12