On Mon, 2023-11-20 at 12:40 +0000, Jonathan Cameron wrote:
> On Mon, 06 Nov 2023 10:26:38 +1030
> Andrew Jeffery <and...@codeconstruct.com.au> wrote:
> 
> > On Fri, 2023-11-03 at 15:05 +0000, Jonathan Cameron wrote:
> > > On Fri,  3 Nov 2023 16:45:20 +1030
> > > Andrew Jeffery <and...@codeconstruct.com.au> wrote:
> > >   
> > > > I ran out of spoons before I could come up with a better client tracking
> > > > scheme back in the original refactoring series:
> > > > 
> > > > https://lore.kernel.org/all/20210608104757.582199-1-and...@aj.id.au/
> > > > 
> > > > Jonathan prodded Konstantin about the issue in a review of Konstantin's
> > > > MCTP patches[1], prompting an attempt to clean it up.
> > > > 
> > > > [1]: https://lore.kernel.org/all/20230929120835.00001...@huawei.com/
> > > > 
> > > > Prevent client modules from having to track their own instances by
> > > > requiring they return a pointer to a client object from their
> > > > add_device() implementation. We can then track this in the core, and
> > > > provide it as the argument to the remove_device() implementation to save
> > > > the client module from further work. The usual container_of() pattern
> > > > gets the client module access to its private data.
> > > > 
> > > > Signed-off-by: Andrew Jeffery <and...@codeconstruct.com.au>  
> > > 
> > > Hi Andrew,
> > > 
> > > A few comments inline.
> > > More generally, whilst this is definitely an improvement I'd have been 
> > > tempted
> > > to make more use of the linux device model for this with the clients added
> > > as devices with a parent of the kcs_bmc_device.  That would then allow for
> > > simple dependency tracking, binding of individual drivers and all that.
> > > 
> > > What you have here feels fine though and is a much less invasive change.  
> > 
> Sorry for slow reply, been traveling.

No worries, I've just got back from travel myself :)

> 
> > Yeah, I had this debate with myself before posting the patches. My
> > reasoning for the current approach is that the clients don't typically
> > represent a device, rather a protocol implementation that is
> > communicated over a KCS device (maybe more like pairing a line
> > discipline with a UART). It was unclear to me whether associating a
> > `struct device` with a protocol implementation was stretching the
> > abstraction a bit, or whether I haven't considered some other
> > perspective hard enough - maybe we treat the client as the remote
> > device, similar to e.g. a `struct i2c_client`?
> 
> That was my thinking.  The protocol is used to talk to someone - the endpoint
> (similar to i2c_client) so represent that. If that device is handling multiple
> protocols (no idea if that is possible) - that is fine as well, it just 
> becomes
> like having multiple i2c_clients in a single package (fairly common for 
> sensors),
> or the many other cases where we use a struct device to represent just part
> of a larger device that operates largely independently of other parts (or with
> well defined boundaries).

Alright, let me think about that a bit more.

Thanks for the feedback,

Andrew


_______________________________________________
Openipmi-developer mailing list
Openipmi-developer@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/openipmi-developer

Reply via email to