Hi Heikki, Thank you for the reply! > From: Heikki Krogerus, Sent: Tuesday, May 15, 2018 5:29 PM > > On Tue, May 15, 2018 at 02:19:14AM +0000, Yoshihiro Shimoda wrote: > > Hi Heikki, > > > > > From: Heikki Krogerus, Sent: Monday, May 14, 2018 10:28 PM > > > > > > On Mon, May 14, 2018 at 06:15:57PM +0900, Yoshihiro Shimoda wrote: <snip> > > > > +struct device *device_connection_find_by_graph(struct device *dev, u32 port, > > > > + u32 endpoint) > > > > +{ > > > > + struct bus_type *bus; > > > > + struct fwnode_handle *remote; > > > > + struct device *conn; > > > > + > > > > + remote = fwnode_graph_get_remote_node(dev_fwnode(dev), port, endpoint); > > > > + if (!remote) > > > > + return NULL; > > > > + > > > > + for (bus = generic_match_buses[0]; bus; bus++) { > > > > + conn = bus_find_device(bus, NULL, remote, generic_graph_match); > > > > + if (conn) > > > > + return conn; > > > > + } > > > > + > > > > + /* > > > > + * We only get called if a connection was found, tell the caller to > > > > + * wait for the other device to show up. > > > > + */ > > > > + return ERR_PTR(-EPROBE_DEFER); > > > > +} > > > > +EXPORT_SYMBOL_GPL(device_connection_find_by_graph); > > > > > > Why do we need more API for walking through the graph? > > > > I thought there is difficult to find if a device has multiple ports or endpoints. > > So, I'd like to use port and endpoint number for finding a device. > > > > > I'm not sure exactly sure what is going on here, I'll try to study > > > your patches more when I have time, but the approach looks wrong. That > > > function looks like a helper, but just not that useful one. > > > > > > We really should be able to use the existing functions. In practice > > > device_connection_find_match() should eventually parse the graph, then > > > fallback to build-in connections if no graph is found. Otherwise > > > parsing graph here is not really useful at all. > > > > I think using device_connection_find_match() for finding the graph becomes complicated. > > The current arguments of the function is the below: > > > > void *device_connection_find_match(struct device *dev, const char *con_id, > > void *data, > > void *(*match)(struct device_connection *con, > > int ep, void *data)) > > > > If finding the graph, the following arguments will be not used. > > - con_id > > - *con and ep of "match" arguments. > > > > This is because these arguments are for the build-in connections. > > No they're not. You do realize that we can build a temporary struct > device_connection there and then (in stack) to be supplied for the > ->match callback. I understood it. > > So, should I modify the arguments of the function for finding both > > the graph and built-in connections somehow? > > I don't see any need for that. We may need to modify struct > device_connection, but there should not be any need to touch the API. > > Your plan to use port and endpoint number is wrong, as they are just > indexes, and therefore not reliable. Luckily it should be completely > unnecessary to use them. > > The way I see this working is that we parse all the endpoints the > caller device has. If we can't take advantage of the con_id for > identification (though ideally we can), we just need to call ->match > with every one of them. The implementation for the ->match callback is > then responsible of figuring out if the endpoint is the one we are > looking for or not in that case. I understood it. But, I need to investigate how to find a device. > The only problem I see with that is that we may not have a reliable > way to convert the fwnode pointing to the remote-endpoint parent into > struct device (if one has already been enumerated) in order to get the > device name and use it as the second endpoint name in struct > device_connection. To solve that, we could consider for example just > adding a new member, fwnode pointer perhaps, to the structure. Or > perhaps use the endpoint members for something else than device names > when graph is used, and add a member defining the type of match: > graph, build-in, etc. There are many things we can consider. I don't understand why adding such new member(s) can solve that. Anyway, I will investigate this more... > I don't know if I'm able to explain what I'm after with this, so if > you like, I can propose something for this myself. Though that will > have to wait for few weeks. Right now I'm too busy with other stuff. Thank you for your proposal! However, I'd like to try to investigate once more while you are too busy. Best regards, Yoshihiro Shimoda > > Thanks, > > -- > heikki