On 5/20/2011 10:37 AM, Arnd Bergmann wrote: > On Friday 20 May 2011 16:26:57 Chris Metcalf wrote: >>>>>> /proc/tile/hardwall >>>>>> Information on the set of currently active hardwalls (note that >>>>>> the implementation is already present in arch/tile/kernel/hardwall.c; >>>>>> this change just enables it) > Ah, I see. I didn't notice that it was in the other file. You are > absolutely right, this does not belong into /sys/hypervisor and > fits well into procfs, we just need to find the right place. >> Perhaps in this case it would be reasonable to just have the hardwall >> subsystem put the file in /proc/driver/hardwall, or even /proc/hardwall? >> Or I could make the /dev/hardwall char device dump out the ASCII text that >> we currently get from /proc/hardwall if you read from it, which is a little >> weird but not inconceivable. For example it currently shows things like this: >> >> # cat /proc/tile/hardwall >> 2x2 1,1 pids: 484@2,1 479@1,1 >> 2x2 0,3 pids: >> >> In this example "2x2 1,1" is a 2x2 grid of cpus starting at grid (x,y) >> position (1,1), with task 484 bound to the cpu at (x,y) position (2,1). > Any chance you can still restructure the information? I would recommend > making it a first-class procfs member, since the data is really per-task. > > You can add a conditional entry to tgid_base_stuff[] in fs/proc/base.c > to make it show up for each pid, and then just have the per-task information > in there to do the lookup the other way round: > > # cat /proc/484/hardwall > 2x2 1,1 @2,1 > > # cat /proc/479/hardwall > 2x2 1,1 @1,1 It's not unreasonable to do what you're suggesting, i.e. "what's this task's hardwall?", but it's not something that we've come up with any kind of use case for in the past, so I'm not currently planning to implement this. If we did, I agree, your solution looks like the right one. The proposed /proc/tile/hardwall really is intended as system-wide information. Each hardwall (one line in the output file example above) corresponds to a "struct file" that may be shared by multiple processes (or threads). Processes may pass the "struct file" to other processes via fork (and maybe exec), or by passing it over Unix sockets. Then those processes can choose a cpu within a hardwall rectangle, affinitize to that cpu only, "activate" the hardwall fd with an ioctl(), and then get access from the OS so they can work together within a hardwall to exchange data across the Tilera "user dynamic network" (a wormhole routed grid network that moves data at 32 bits/cycle with almost no latency). Processes can create a new hardwall as long as it doesn't overlap geometrically with any other existing hardwall on the system. -- Chris Metcalf, Tilera Corp. http://www.tilera.com _______________________________________________ Virtualization mailing list Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/virtualization