On Fri, Sep 10, 2021 at 01:30:46PM +0800, brookxu <brookxu.cn@xxxxxxxxx> wrote: > I am a bit confused here. For misc_cgroup, we can only be rejected when the count > touch Limit, but there may be other more reasons for other subsystems. Sorry, I wasn't clear about that -- the failures I meant to be counted here were only the ones caused by (an ancestor) limit. Maybe there's a better naem for that. > Therefore, when we are rejected, does it mean that we have touch > Limit? If so, do we still need to distinguish between max and fail? > (for misc_cgroup) r `- c1 `- c2.max `- c3 `- c4.max `- task t `- c5 Assuming c2.max < c4.max, when a task t calls try_charge and it fails because of c2.max, then the 'max' event is counted to c2 (telling that the limit is perhaps low) and the 'fail' event is counted to c4 (telling you where the troubles originated). That is my idea. Although in the case of short-lived cgroups, you'd likely only get the hierarchically aggregated 'fail' events from c3 or higher with lower (spatial) precision. What would be the type of information useful for your troubleshooting? Cheers, Michal