[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250908115649.22903-1-shubhrajyoti.datta@amd.com>
Date: Mon, 8 Sep 2025 17:26:44 +0530
From: Shubhrajyoti Datta <shubhrajyoti.datta@....com>
To: <devicetree@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
	<linux-edac@...r.kernel.org>
CC: <git@....com>, <ptsm@...ux.microsoft.com>, <srivatsa@...il.mit.edu>,
	<shubhrajyoti.datta@...il.com>, Shubhrajyoti Datta
	<shubhrajyoti.datta@....com>, Krzysztof Kozlowski <krzk@...nel.org>, "Rob
 Herring" <robh@...nel.org>, Conor Dooley <conor+dt@...nel.org>, "Borislav
 Petkov" <bp@...en8.de>, Tony Luck <tony.luck@...el.com>, James Morse
	<james.morse@....com>, Mauro Carvalho Chehab <mchehab@...nel.org>, "Robert
 Richter" <rric@...nel.org>, Nipun Gupta <nipun.gupta@....com>, Nikhil Agarwal
	<nikhil.agarwal@....com>
Subject: [PATCH v9 0/5] EDAC/Versal NET: Add support for error notification
Adds support for the error notification for the Versal NET EDAC driver.
The driver receives error events via RPMsg instead of directly accessing
hardware registers. The NMC((Network management controller), which has
secure access to DDRMC registers, gathers the necessary information and
transmits it through RPMsg.
During probe, the driver registers with RPMsg and retrieves DDR
configuration by scheduling a work item from the NMC.
Once this is completed, it registers the EDAC controller.
When an error occurs, the NMC sends an RPMsg, notifying the driver.
The EDAC driver handles error reporting for all events.
Also we register the EDAC once and it reports the errors for all the
events including the 8 DDRMC controllers. So while registering we give
the particulars of the 1st controller.
Currently 20 errors has been tested.
Changes in v9:
- Add tabs
- Replace "This function allocates" to Allocate
similarly s/This function handles/Handle/
- Export cdx_mcdi_finish
Change the export log_non_standard_event wording
- Fixup title
- Rewrite commit message
- Fixup Kconfig text
- Zap unused defines and align them
- Simplify rpmsg_cb() considerably
- Drop silly double-brackets in conditionals
- Use proper void * type in mcdi_request()
- Do not clear chinfo in rpmsg_probe() unnecessarily
- Fix indentation
- Do a proper err unwind path in init_versalnet()
- Redo the error unwind path in mc_probe() properly
- Fix the ordering in mc_remove()
- call cdx_mcdi_finish
Changes in v8:
- Split `mcdi.h` into `mcdi.h` and `mcdid.h`
- Removed common code from CDX headers
- Used refactored versions from shared location
- Remove "EDAC" from macros and shoterned them
- Removed redundant parentheses
- Improved the description of the @i field in union ecc_error_info
- Improved logging for memory_failure()
- Merged init_csrows() into mc_init():
- Remove AMD-specific naming for static functions
- Add MAINTAINERS file
- Register all the controllers
- Replace  AMD_ERR use the snprintf in a function
Changes in v7:
- add a minimal header instead moving them
- Add the kernel doc description
- Add the prototype from first patch to here
- Add the reviewed by tag
- Update the header paths
- merge edac_cdx_pcol.h
Changes in v6:
- Patch added
- Update commit description
- Update the commit message.
- update to the chip name as xlnx,versal-net
- Correct indentation
- Update to xlnx,versal-net-ddrmc5
- Update the kconfig message
- Make the messages uniform
- Add some more supported events
- rename regval to reglo
- combine/ reformat functions
- remove trailing comments
- Remove unneeded comments
- make the amd_mcdi function void
- rename versalnet_rpmsg_edac to versalnet_edac
- Remove the column bit and use them directly
- Update the comments
- Update the mod_name to versalnet_edac
- remove the global priv col and rows
- rename edac_priv to mc_priv
- Update the comment description for dwidth
- Remove error_id enum
- rename the variable par to parity
- make get_ddr_config void
- Fix memory leak of the mcdi structure
- Update the spelling
- Remove the workqueue
Changes in v5:
- Update the binding
- Update the compatible
- Update the handle_error documentation
Changes in v4:
- Update the compatible
- align the example
- Enhance the description for rproc
- Update the compatible
Changes in v3:
- make remove void
Changes in v2:
- Export the symbols for module compilation
- New patch addition
- rename EDAC to memory controller
- update the compatible name
- Add remote proc handle
- Read the data width from the registers
- Remove the dwidth, rank and channel number the same is
read from the RpMsg.
- remove reset
- Add the remote proc requests
- remove probe_once
- reorder the rpmsg registration
- the data width , rank and number of channel is read from message.
Shubhrajyoti Datta (5):
  cdx: Split mcdi.h and reorganize headers
  cdx: Export Symbols for MCDI RPC and Initialization
  ras: Export log_non_standard_event for External Usage
  dt-bindings: memory-controllers: Add support for Versal NET EDAC
  EDAC: Add a driver for the AMD Versal NET DDR controller
 .../xlnx,versal-net-ddrmc5.yaml               |  41 +
 MAINTAINERS                                   |   7 +
 drivers/cdx/controller/cdx_controller.c       |   2 +-
 drivers/cdx/controller/cdx_rpmsg.c            |   2 +-
 drivers/cdx/controller/mcdi.c                 |  43 +-
 drivers/cdx/controller/mcdi_functions.c       |   1 -
 drivers/cdx/controller/mcdi_functions.h       |   3 +-
 drivers/cdx/controller/mcdid.h                |  63 ++
 drivers/edac/Kconfig                          |   8 +
 drivers/edac/Makefile                         |   1 +
 drivers/edac/versalnet_edac.c                 | 958 ++++++++++++++++++
 drivers/ras/ras.c                             |   1 +
 .../linux/cdx}/bitfield.h                     |   0
 include/linux/cdx/edac_cdx_pcol.h             |  28 +
 .../controller => include/linux/cdx}/mcdi.h   |  47 +-
 15 files changed, 1154 insertions(+), 51 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/memory-controllers/xlnx,versal-net-ddrmc5.yaml
 create mode 100644 drivers/cdx/controller/mcdid.h
 create mode 100644 drivers/edac/versalnet_edac.c
 rename {drivers/cdx/controller => include/linux/cdx}/bitfield.h (100%)
 create mode 100644 include/linux/cdx/edac_cdx_pcol.h
 rename {drivers/cdx/controller => include/linux/cdx}/mcdi.h (79%)
-- 
2.34.1
Powered by blists - more mailing lists
 
