Philippe Bergheaud | 49fd644 | 2014-12-12 11:28:53 +0100 | [diff] [blame] | 1 | Note: Attributes that are shared between devices are stored in the directory |
| 2 | pointed to by the symlink device/. |
| 3 | Example: The real path of the attribute /sys/class/cxl/afu0.0s/irqs_max is |
| 4 | /sys/class/cxl/afu0.0s/device/irqs_max, i.e. /sys/class/cxl/afu0.0/irqs_max. |
| 5 | |
| 6 | |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 7 | Slave contexts (eg. /sys/class/cxl/afu0.0s): |
| 8 | |
Vaibhav Jain | e36f6fe | 2015-05-22 10:56:05 +0530 | [diff] [blame] | 9 | What: /sys/class/cxl/<afu>/afu_err_buf |
| 10 | Date: September 2014 |
| 11 | Contact: linuxppc-dev@lists.ozlabs.org |
| 12 | Description: read only |
| 13 | AFU Error Buffer contents. The contents of this file are |
| 14 | application specific and depends on the AFU being used. |
| 15 | Applications interacting with the AFU can use this attribute |
| 16 | to know about the current error condition and take appropriate |
| 17 | action like logging the event etc. |
| 18 | |
| 19 | |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 20 | What: /sys/class/cxl/<afu>/irqs_max |
| 21 | Date: September 2014 |
| 22 | Contact: linuxppc-dev@lists.ozlabs.org |
| 23 | Description: read/write |
| 24 | Decimal value of maximum number of interrupts that can be |
| 25 | requested by userspace. The default on probe is the maximum |
| 26 | that hardware can support (eg. 2037). Write values will limit |
| 27 | userspace applications to that many userspace interrupts. Must |
| 28 | be >= irqs_min. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 29 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 30 | |
| 31 | What: /sys/class/cxl/<afu>/irqs_min |
| 32 | Date: September 2014 |
| 33 | Contact: linuxppc-dev@lists.ozlabs.org |
| 34 | Description: read only |
| 35 | Decimal value of the minimum number of interrupts that |
| 36 | userspace must request on a CXL_START_WORK ioctl. Userspace may |
| 37 | omit the num_interrupts field in the START_WORK IOCTL to get |
| 38 | this minimum automatically. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 39 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 40 | |
| 41 | What: /sys/class/cxl/<afu>/mmio_size |
| 42 | Date: September 2014 |
| 43 | Contact: linuxppc-dev@lists.ozlabs.org |
| 44 | Description: read only |
| 45 | Decimal value of the size of the MMIO space that may be mmaped |
| 46 | by userspace. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 47 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 48 | |
| 49 | What: /sys/class/cxl/<afu>/modes_supported |
| 50 | Date: September 2014 |
| 51 | Contact: linuxppc-dev@lists.ozlabs.org |
| 52 | Description: read only |
| 53 | List of the modes this AFU supports. One per line. |
| 54 | Valid entries are: "dedicated_process" and "afu_directed" |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 55 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 56 | |
| 57 | What: /sys/class/cxl/<afu>/mode |
| 58 | Date: September 2014 |
| 59 | Contact: linuxppc-dev@lists.ozlabs.org |
| 60 | Description: read/write |
| 61 | The current mode the AFU is using. Will be one of the modes |
| 62 | given in modes_supported. Writing will change the mode |
| 63 | provided that no user contexts are attached. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 64 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 65 | |
| 66 | |
| 67 | What: /sys/class/cxl/<afu>/prefault_mode |
| 68 | Date: September 2014 |
| 69 | Contact: linuxppc-dev@lists.ozlabs.org |
| 70 | Description: read/write |
| 71 | Set the mode for prefaulting in segments into the segment table |
Vaibhav Jain | b6c84ba | 2018-05-18 15:12:23 +0530 | [diff] [blame] | 72 | when performing the START_WORK ioctl. Only applicable when |
| 73 | running under hashed page table mmu. |
| 74 | Possible values: |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 75 | none: No prefaulting (default) |
| 76 | work_element_descriptor: Treat the work element |
| 77 | descriptor as an effective address and |
| 78 | prefault what it points to. |
| 79 | all: all segments process calling START_WORK maps. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 80 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 81 | |
| 82 | What: /sys/class/cxl/<afu>/reset |
| 83 | Date: September 2014 |
| 84 | Contact: linuxppc-dev@lists.ozlabs.org |
| 85 | Description: write only |
| 86 | Writing 1 here will reset the AFU provided there are not |
| 87 | contexts active on the AFU. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 88 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 89 | |
| 90 | What: /sys/class/cxl/<afu>/api_version |
| 91 | Date: September 2014 |
| 92 | Contact: linuxppc-dev@lists.ozlabs.org |
| 93 | Description: read only |
| 94 | Decimal value of the current version of the kernel/user API. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 95 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 96 | |
Philippe Bergheaud | 49fd644 | 2014-12-12 11:28:53 +0100 | [diff] [blame] | 97 | What: /sys/class/cxl/<afu>/api_version_compatible |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 98 | Date: September 2014 |
| 99 | Contact: linuxppc-dev@lists.ozlabs.org |
| 100 | Description: read only |
| 101 | Decimal value of the the lowest version of the userspace API |
| 102 | this this kernel supports. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 103 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 104 | |
| 105 | |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 106 | AFU configuration records (eg. /sys/class/cxl/afu0.0/cr0): |
| 107 | |
| 108 | An AFU may optionally export one or more PCIe like configuration records, known |
| 109 | as AFU configuration records, which will show up here (if present). |
| 110 | |
| 111 | What: /sys/class/cxl/<afu>/cr<config num>/vendor |
| 112 | Date: February 2015 |
| 113 | Contact: linuxppc-dev@lists.ozlabs.org |
| 114 | Description: read only |
| 115 | Hexadecimal value of the vendor ID found in this AFU |
| 116 | configuration record. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 117 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 118 | |
| 119 | What: /sys/class/cxl/<afu>/cr<config num>/device |
| 120 | Date: February 2015 |
| 121 | Contact: linuxppc-dev@lists.ozlabs.org |
| 122 | Description: read only |
| 123 | Hexadecimal value of the device ID found in this AFU |
| 124 | configuration record. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 125 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 126 | |
Philippe Bergheaud | 52fd475 | 2015-03-26 11:46:56 +0100 | [diff] [blame] | 127 | What: /sys/class/cxl/<afu>/cr<config num>/class |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 128 | Date: February 2015 |
| 129 | Contact: linuxppc-dev@lists.ozlabs.org |
| 130 | Description: read only |
| 131 | Hexadecimal value of the class code found in this AFU |
| 132 | configuration record. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 133 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 134 | |
| 135 | What: /sys/class/cxl/<afu>/cr<config num>/config |
| 136 | Date: February 2015 |
| 137 | Contact: linuxppc-dev@lists.ozlabs.org |
| 138 | Description: read only |
| 139 | This binary file provides raw access to the AFU configuration |
| 140 | record. The format is expected to match the either the standard |
| 141 | or extended configuration space defined by the PCIe |
| 142 | specification. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 143 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | b087e61 | 2015-02-04 19:09:01 +1100 | [diff] [blame] | 144 | |
| 145 | |
| 146 | |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 147 | Master contexts (eg. /sys/class/cxl/afu0.0m) |
| 148 | |
| 149 | What: /sys/class/cxl/<afu>m/mmio_size |
| 150 | Date: September 2014 |
| 151 | Contact: linuxppc-dev@lists.ozlabs.org |
| 152 | Description: read only |
| 153 | Decimal value of the size of the MMIO space that may be mmaped |
| 154 | by userspace. This includes all slave contexts space also. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 155 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 156 | |
| 157 | What: /sys/class/cxl/<afu>m/pp_mmio_len |
| 158 | Date: September 2014 |
| 159 | Contact: linuxppc-dev@lists.ozlabs.org |
| 160 | Description: read only |
| 161 | Decimal value of the Per Process MMIO space length. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 162 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 163 | |
Christophe Lombard | 4752876 | 2016-03-04 12:26:37 +0100 | [diff] [blame] | 164 | What: /sys/class/cxl/<afu>m/pp_mmio_off (not in a guest) |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 165 | Date: September 2014 |
| 166 | Contact: linuxppc-dev@lists.ozlabs.org |
| 167 | Description: read only |
| 168 | Decimal value of the Per Process MMIO space offset. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 169 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 170 | |
| 171 | |
| 172 | Card info (eg. /sys/class/cxl/card0) |
| 173 | |
| 174 | What: /sys/class/cxl/<card>/caia_version |
| 175 | Date: September 2014 |
| 176 | Contact: linuxppc-dev@lists.ozlabs.org |
| 177 | Description: read only |
| 178 | Identifies the CAIA Version the card implements. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 179 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 180 | |
Philippe Bergheaud | 49fd644 | 2014-12-12 11:28:53 +0100 | [diff] [blame] | 181 | What: /sys/class/cxl/<card>/psl_revision |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 182 | Date: September 2014 |
| 183 | Contact: linuxppc-dev@lists.ozlabs.org |
| 184 | Description: read only |
| 185 | Identifies the revision level of the PSL. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 186 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 187 | |
Christophe Lombard | 4752876 | 2016-03-04 12:26:37 +0100 | [diff] [blame] | 188 | What: /sys/class/cxl/<card>/base_image (not in a guest) |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 189 | Date: September 2014 |
| 190 | Contact: linuxppc-dev@lists.ozlabs.org |
| 191 | Description: read only |
| 192 | Identifies the revision level of the base image for devices |
| 193 | that support loadable PSLs. For FPGAs this field identifies |
| 194 | the image contained in the on-adapter flash which is loaded |
| 195 | during the initial program load. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 196 | Users: https://github.com/ibm-capi/libcxl |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 197 | |
Christophe Lombard | 4752876 | 2016-03-04 12:26:37 +0100 | [diff] [blame] | 198 | What: /sys/class/cxl/<card>/image_loaded (not in a guest) |
Ian Munsie | a9282d0 | 2014-10-08 19:55:05 +1100 | [diff] [blame] | 199 | Date: September 2014 |
| 200 | Contact: linuxppc-dev@lists.ozlabs.org |
| 201 | Description: read only |
| 202 | Will return "user" or "factory" depending on the image loaded |
| 203 | onto the card. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 204 | Users: https://github.com/ibm-capi/libcxl |
Ryan Grimm | 95bc11b | 2015-01-19 11:52:49 -0600 | [diff] [blame] | 205 | |
Christophe Lombard | 4752876 | 2016-03-04 12:26:37 +0100 | [diff] [blame] | 206 | What: /sys/class/cxl/<card>/load_image_on_perst (not in a guest) |
Ryan Grimm | 95bc11b | 2015-01-19 11:52:49 -0600 | [diff] [blame] | 207 | Date: December 2014 |
| 208 | Contact: linuxppc-dev@lists.ozlabs.org |
| 209 | Description: read/write |
| 210 | Valid entries are "none", "user", and "factory". |
| 211 | "none" means PERST will not cause image to be loaded to the |
| 212 | card. A power cycle is required to load the image. |
| 213 | "none" could be useful for debugging because the trace arrays |
| 214 | are preserved. |
| 215 | "user" and "factory" means PERST will cause either the user or |
| 216 | user or factory image to be loaded. |
| 217 | Default is to reload on PERST whichever image the card has |
| 218 | loaded. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 219 | Users: https://github.com/ibm-capi/libcxl |
Ryan Grimm | 62fa19d | 2015-01-19 11:52:51 -0600 | [diff] [blame] | 220 | |
| 221 | What: /sys/class/cxl/<card>/reset |
| 222 | Date: October 2014 |
| 223 | Contact: linuxppc-dev@lists.ozlabs.org |
| 224 | Description: write only |
Vaibhav Jain | 70b565b | 2016-10-14 15:08:36 +0530 | [diff] [blame] | 225 | Writing 1 will issue a PERST to card provided there are no |
| 226 | contexts active on any one of the card AFUs. This may cause |
| 227 | the card to reload the FPGA depending on load_image_on_perst. |
| 228 | Writing -1 will do a force PERST irrespective of any active |
| 229 | contexts on the card AFUs. |
Michael Neuling | aee85fb | 2015-05-27 16:07:01 +1000 | [diff] [blame] | 230 | Users: https://github.com/ibm-capi/libcxl |
Daniel Axtens | 13e68d8 | 2015-08-14 17:41:25 +1000 | [diff] [blame] | 231 | |
Christophe Lombard | 4752876 | 2016-03-04 12:26:37 +0100 | [diff] [blame] | 232 | What: /sys/class/cxl/<card>/perst_reloads_same_image (not in a guest) |
Daniel Axtens | 13e68d8 | 2015-08-14 17:41:25 +1000 | [diff] [blame] | 233 | Date: July 2015 |
| 234 | Contact: linuxppc-dev@lists.ozlabs.org |
| 235 | Description: read/write |
| 236 | Trust that when an image is reloaded via PERST, it will not |
| 237 | have changed. |
| 238 | 0 = don't trust, the image may be different (default) |
| 239 | 1 = trust that the image will not change. |
| 240 | Users: https://github.com/ibm-capi/libcxl |
Frederic Barrat | e009a7e | 2016-03-21 14:32:48 -0500 | [diff] [blame] | 241 | |
| 242 | What: /sys/class/cxl/<card>/psl_timebase_synced |
| 243 | Date: March 2016 |
| 244 | Contact: linuxppc-dev@lists.ozlabs.org |
| 245 | Description: read only |
| 246 | Returns 1 if the psl timebase register is synchronized |
| 247 | with the core timebase register, 0 otherwise. |
| 248 | Users: https://github.com/ibm-capi/libcxl |
Philippe Bergheaud | 497a079 | 2018-05-14 10:27:36 +0200 | [diff] [blame] | 249 | |
| 250 | What: /sys/class/cxl/<card>/tunneled_ops_supported |
| 251 | Date: May 2018 |
| 252 | Contact: linuxppc-dev@lists.ozlabs.org |
| 253 | Description: read only |
| 254 | Returns 1 if tunneled operations are supported in capi mode, |
| 255 | 0 otherwise. |
| 256 | Users: https://github.com/ibm-capi/libcxl |