soc: fsl: dpio: use a cpumask to identify which cpus are unused
The current implementation of the dpio driver uses a static next_cpu variable to keep track of the index of the next cpu available. This approach does not handle well unbinding and binding dpio devices in a random order. For example, unbinding a dpio and then binding it again with the driver, will generate the below error: $ echo dpio.5 > /sys/bus/fsl-mc/drivers/fsl_mc_dpio/unbind $ echo dpio.5 > /sys/bus/fsl-mc/drivers/fsl_mc_dpio/bind [ 103.946380] fsl_mc_dpio dpio.5: probe failed. Number of DPIOs exceeds NR_CPUS. [ 103.955157] fsl_mc_dpio dpio.5: fsl_mc_driver_probe failed: -34 -bash: echo: write error: No such device Fix this error by keeping a global cpumask of unused cpus that will be updated at every dpaa2_dpio_[probe,remove]. Signed-off-by: Ioana Ciornei <ioana.ciornei@nxp.com> Signed-off-by: Li Yang <leoyang.li@nxp.com>
This commit is contained in:
@@ -90,6 +90,8 @@ struct dpaa2_io_notification_ctx {
|
||||
void *dpio_private;
|
||||
};
|
||||
|
||||
int dpaa2_io_get_cpu(struct dpaa2_io *d);
|
||||
|
||||
int dpaa2_io_service_register(struct dpaa2_io *service,
|
||||
struct dpaa2_io_notification_ctx *ctx);
|
||||
void dpaa2_io_service_deregister(struct dpaa2_io *service,
|
||||
|
Reference in New Issue
Block a user