Hi Tejun, I would like to submit patch v10. Can you please confirm that you are ok (or not) with the current design and below changes should be good enough? I am ok if you directly want to jump to review v10 too. Changes from v9: * Included documentation of resources in v2.txt and v1.txt * Fixed issue of race condition of process migration during charging stage. * Fixed comments and code to adhere to CodingStyle. * Simplified and removed support to charge/uncharge multiple resource. * Fixed removed refcnt with usage_num that tracks how many resources are unused to trigger freeing the object. * Removed inline for query_limit and other function as its not necessary. Design that remains same from v6 to v10. * spin lock is still fine grained at cgroup level instead of one global shared lock among all cgroups. In future it can be optimized further to do per cpu or using single lock if required. * file type enums are still present for max and current, as read/write call to those files is already taken care by common functions with required if/else. * Resource limit setting is as it is, because number of devices are in range of 1 to 4 count in most use cases (as explained in documentation), and its not hot path. Parav On Thu, Mar 3, 2016 at 8:19 AM, Parav Pandit <pandit.parav@xxxxxxxxx> wrote: > Hi Tejun, Haggai, > > On Thu, Mar 3, 2016 at 1:28 AM, Parav Pandit <pandit.parav@xxxxxxxxx> wrote: >>>> + rpool->refcnt--; >>>> + if (rpool->refcnt == 0 && rpool->num_max_cnt == pool_info->table_len) { >>> >>> If the caller charges 2 and then uncharges 1 two times, the refcnt >>> underflows? Why not just track how many usages are zero? >>> >> This is certainly must fix bug. Changed refcnt to usage_sum and changed to do >> usage_sum -= num during uncharging >> and >> usage_sum += num during charing. > > This is not sufficient as css_get() and put are done only once per > call, which leads to similar problem as of refcnt. > As I think more, I realised that this particular test is missing that > resulted in this related bug, I realize that we don't have use case to > have "num" field from the IB stack side. > For bulk free IB stack will have to keep track of different or same > rdmacg returned values to call uncharge() with right number of > resources, all of that complexity just doesn't make sense and not > required. > So as first step to further simplify this, I am removing "num" input > field from charge and uncharge API. -- To unsubscribe from this list: send the line "unsubscribe cgroups" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html