€•»oŒsphinx.addnodes”Œdocument”“”)”}”(Œ rawsource”Œ”Œchildren”]”(Œ translations”Œ LanguagesNode”“”)”}”(hhh]”(hŒ pending_xref”“”)”}”(hhh]”Œdocutils.nodes”ŒText”“”ŒChinese (Simplified)”…””}”Œparent”hsbaŒ attributes”}”(Œids”]”Œclasses”]”Œnames”]”Œdupnames”]”Œbackrefs”]”Œ refdomain”Œstd”Œreftype”Œdoc”Œ reftarget”Œ//translations/zh_CN/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuŒtagname”hhh ubh)”}”(hhh]”hŒChinese (Traditional)”…””}”hh2sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/zh_TW/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/it_IT/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/ja_JP/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/ko_KR/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒPortuguese (Brazilian)”…””}”hh‚sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/pt_BR/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒSpanish”…””}”hh–sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ//translations/sp_SP/accounting/taskstats-struct”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubeh}”(h]”h ]”h"]”h$]”h&]”Œcurrent_language”ŒEnglish”uh1h hhŒ _document”hŒsource”NŒline”NubhŒsection”“”)”}”(hhh]”(hŒtitle”“”)”}”(hŒThe struct taskstats”h]”hŒThe struct taskstats”…””}”(hh¼h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hºhh·h²hh³ŒI/var/lib/git/docbuild/linux/Documentation/accounting/taskstats-struct.rst”h´KubhŒ paragraph”“”)”}”(hŒEThis document contains an explanation of the struct taskstats fields.”h]”hŒEThis document contains an explanation of the struct taskstats fields.”…””}”(hhÍh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´Khh·h²hubhÌ)”}”(hŒCThere are three different groups of fields in the struct taskstats:”h]”hŒCThere are three different groups of fields in the struct taskstats:”…””}”(hhÛh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´Khh·h²hubhŒenumerated_list”“”)”}”(hhh]”(hŒ list_item”“”)”}”(hŒÉCommon and basic accounting fields If CONFIG_TASKSTATS is set, the taskstats interface is enabled and the common fields and basic accounting fields are collected for delivery at do_exit() of a task.”h]”hŒdefinition_list”“”)”}”(hhh]”hŒdefinition_list_item”“”)”}”(hŒÆCommon and basic accounting fields If CONFIG_TASKSTATS is set, the taskstats interface is enabled and the common fields and basic accounting fields are collected for delivery at do_exit() of a task.”h]”(hŒterm”“”)”}”(hŒ"Common and basic accounting fields”h]”hŒ"Common and basic accounting fields”…””}”(hjh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÿh³hÊh´K hhûubhŒ definition”“”)”}”(hhh]”hÌ)”}”(hŒ£If CONFIG_TASKSTATS is set, the taskstats interface is enabled and the common fields and basic accounting fields are collected for delivery at do_exit() of a task.”h]”hŒ£If CONFIG_TASKSTATS is set, the taskstats interface is enabled and the common fields and basic accounting fields are collected for delivery at do_exit() of a task.”…””}”(hjh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K hjubah}”(h]”h ]”h"]”h$]”h&]”uh1jhhûubeh}”(h]”h ]”h"]”h$]”h&]”uh1hùh³hÊh´K hhöubah}”(h]”h ]”h"]”h$]”h&]”uh1hôhhðubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³Nh´Nubhï)”}”(hŒÓDelay accounting fields These fields are placed between:: /* Delay accounting fields start */ and:: /* Delay accounting fields end */ Their values are collected if CONFIG_TASK_DELAY_ACCT is set.”h]”hõ)”}”(hhh]”hú)”}”(hŒÎDelay accounting fields These fields are placed between:: /* Delay accounting fields start */ and:: /* Delay accounting fields end */ Their values are collected if CONFIG_TASK_DELAY_ACCT is set.”h]”(j)”}”(hŒDelay accounting fields”h]”hŒDelay accounting fields”…””}”(hjEh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÿh³hÊh´KhjAubj)”}”(hhh]”(hÌ)”}”(hŒ!These fields are placed between::”h]”hŒ These fields are placed between:”…””}”(hjVh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KhjSubhŒ literal_block”“”)”}”(hŒ#/* Delay accounting fields start */”h]”hŒ#/* Delay accounting fields start */”…””}”hjfsbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1jdh³hÊh´KhjSubhÌ)”}”(hŒand::”h]”hŒand:”…””}”(hjvh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KhjSubje)”}”(hŒ!/* Delay accounting fields end */”h]”hŒ!/* Delay accounting fields end */”…””}”hj„sbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KhjSubhÌ)”}”(hŒubah}”(h]”h ]”h"]”h$]”h&]”uh1hôhj:ubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³Nh´Nubhï)”}”(hŒØExtended accounting fields These fields are placed between:: /* Extended accounting fields start */ and:: /* Extended accounting fields end */ Their values are collected if CONFIG_TASK_XACCT is set. ”h]”hõ)”}”(hhh]”hú)”}”(hŒÓExtended accounting fields These fields are placed between:: /* Extended accounting fields start */ and:: /* Extended accounting fields end */ Their values are collected if CONFIG_TASK_XACCT is set. ”h]”(j)”}”(hŒExtended accounting fields”h]”hŒExtended accounting fields”…””}”(hjÃh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÿh³hÊh´K hj¿ubj)”}”(hhh]”(hÌ)”}”(hŒ!These fields are placed between::”h]”hŒ These fields are placed between:”…””}”(hjÔh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KhjÑubje)”}”(hŒ&/* Extended accounting fields start */”h]”hŒ&/* Extended accounting fields start */”…””}”hjâsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KhjÑubhÌ)”}”(hŒand::”h]”hŒand:”…””}”(hjðh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KhjÑubje)”}”(hŒ$/* Extended accounting fields end */”h]”hŒ$/* Extended accounting fields end */”…””}”hjþsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KhjÑubhÌ)”}”(hŒ7Their values are collected if CONFIG_TASK_XACCT is set.”h]”hŒ7Their values are collected if CONFIG_TASK_XACCT is set.”…””}”(hj h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K hjÑubeh}”(h]”h ]”h"]”h$]”h&]”uh1jhj¿ubeh}”(h]”h ]”h"]”h$]”h&]”uh1hùh³hÊh´K hj¼ubah}”(h]”h ]”h"]”h$]”h&]”uh1hôhj¸ubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³Nh´Nubhï)”}”(hŒ8Per-task and per-thread context switch count statistics ”h]”hÌ)”}”(hŒ7Per-task and per-thread context switch count statistics”h]”hŒ7Per-task and per-thread context switch count statistics”…””}”(hj6h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K"hj2ubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³hÊh´Nubhï)”}”(hŒ!Time accounting for SMT machines ”h]”hÌ)”}”(hŒ Time accounting for SMT machines”h]”hŒ Time accounting for SMT machines”…””}”(hjNh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K$hjJubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³hÊh´Nubhï)”}”(hŒ4Extended delay accounting fields for memory reclaim ”h]”hÌ)”}”(hŒ3Extended delay accounting fields for memory reclaim”h]”hŒ3Extended delay accounting fields for memory reclaim”…””}”(hjfh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K&hjbubah}”(h]”h ]”h"]”h$]”h&]”uh1hîhhëh²hh³hÊh´Nubeh}”(h]”h ]”h"]”h$]”h&]”Œenumtype”Œarabic”Œprefix”hŒsuffix”Œ)”uh1héhh·h²hh³hÊh´K ubhÌ)”}”(hŒ“Future extension should add fields to the end of the taskstats struct, and should not change the relative position of each field within the struct.”h]”hŒ“Future extension should add fields to the end of the taskstats struct, and should not change the relative position of each field within the struct.”…””}”(hj…h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K(hh·h²hubje)”}”(hŒstruct taskstats {”h]”hŒstruct taskstats {”…””}”hj“sbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´K-hh·h²hubhê)”}”(hhh]”(hï)”}”(hXŽCommon and basic accounting fields:: /* The version number of this struct. This field is always set to * TASKSTATS_VERSION, which is defined in . * Each time the struct is changed, the value should be incremented. */ __u16 version; /* The exit code of a task. */ __u32 ac_exitcode; /* Exit status */ /* The accounting flags of a task as defined in * Defined values are AFORK, ASU, ACOMPAT, ACORE, and AXSIG. */ __u8 ac_flag; /* Record flags */ /* The value of task_nice() of a task. */ __u8 ac_nice; /* task_nice */ /* The name of the command that started this task. */ char ac_comm[TS_COMM_LEN]; /* Command name */ /* The scheduling discipline as set in task->policy field. */ __u8 ac_sched; /* Scheduling discipline */ __u8 ac_pad[3]; __u32 ac_uid; /* User ID */ __u32 ac_gid; /* Group ID */ __u32 ac_pid; /* Process ID */ __u32 ac_ppid; /* Parent process ID */ /* The time when a task begins, in [secs] since 1970. */ __u32 ac_btime; /* Begin time [sec since 1970] */ /* The elapsed time of a task, in [usec]. */ __u64 ac_etime; /* Elapsed time [usec] */ /* The user CPU time of a task, in [usec]. */ __u64 ac_utime; /* User CPU time [usec] */ /* The system CPU time of a task, in [usec]. */ __u64 ac_stime; /* System CPU time [usec] */ /* The minor page fault count of a task, as set in task->min_flt. */ __u64 ac_minflt; /* Minor Page Fault Count */ /* The major page fault count of a task, as set in task->maj_flt. */ __u64 ac_majflt; /* Major Page Fault Count */ ”h]”(hÌ)”}”(hŒ$Common and basic accounting fields::”h]”hŒ#Common and basic accounting fields:”…””}”(hj¨h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K/hj¤ubje)”}”(hX¼/* The version number of this struct. This field is always set to * TASKSTATS_VERSION, which is defined in . * Each time the struct is changed, the value should be incremented. */ __u16 version; /* The exit code of a task. */ __u32 ac_exitcode; /* Exit status */ /* The accounting flags of a task as defined in * Defined values are AFORK, ASU, ACOMPAT, ACORE, and AXSIG. */ __u8 ac_flag; /* Record flags */ /* The value of task_nice() of a task. */ __u8 ac_nice; /* task_nice */ /* The name of the command that started this task. */ char ac_comm[TS_COMM_LEN]; /* Command name */ /* The scheduling discipline as set in task->policy field. */ __u8 ac_sched; /* Scheduling discipline */ __u8 ac_pad[3]; __u32 ac_uid; /* User ID */ __u32 ac_gid; /* Group ID */ __u32 ac_pid; /* Process ID */ __u32 ac_ppid; /* Parent process ID */ /* The time when a task begins, in [secs] since 1970. */ __u32 ac_btime; /* Begin time [sec since 1970] */ /* The elapsed time of a task, in [usec]. */ __u64 ac_etime; /* Elapsed time [usec] */ /* The user CPU time of a task, in [usec]. */ __u64 ac_utime; /* User CPU time [usec] */ /* The system CPU time of a task, in [usec]. */ __u64 ac_stime; /* System CPU time [usec] */ /* The minor page fault count of a task, as set in task->min_flt. */ __u64 ac_minflt; /* Minor Page Fault Count */ /* The major page fault count of a task, as set in task->maj_flt. */ __u64 ac_majflt; /* Major Page Fault Count */”h]”hX¼/* The version number of this struct. This field is always set to * TASKSTATS_VERSION, which is defined in . * Each time the struct is changed, the value should be incremented. */ __u16 version; /* The exit code of a task. */ __u32 ac_exitcode; /* Exit status */ /* The accounting flags of a task as defined in * Defined values are AFORK, ASU, ACOMPAT, ACORE, and AXSIG. */ __u8 ac_flag; /* Record flags */ /* The value of task_nice() of a task. */ __u8 ac_nice; /* task_nice */ /* The name of the command that started this task. */ char ac_comm[TS_COMM_LEN]; /* Command name */ /* The scheduling discipline as set in task->policy field. */ __u8 ac_sched; /* Scheduling discipline */ __u8 ac_pad[3]; __u32 ac_uid; /* User ID */ __u32 ac_gid; /* Group ID */ __u32 ac_pid; /* Process ID */ __u32 ac_ppid; /* Parent process ID */ /* The time when a task begins, in [secs] since 1970. */ __u32 ac_btime; /* Begin time [sec since 1970] */ /* The elapsed time of a task, in [usec]. */ __u64 ac_etime; /* Elapsed time [usec] */ /* The user CPU time of a task, in [usec]. */ __u64 ac_utime; /* User CPU time [usec] */ /* The system CPU time of a task, in [usec]. */ __u64 ac_stime; /* System CPU time [usec] */ /* The minor page fault count of a task, as set in task->min_flt. */ __u64 ac_minflt; /* Minor Page Fault Count */ /* The major page fault count of a task, as set in task->maj_flt. */ __u64 ac_majflt; /* Major Page Fault Count */”…””}”hj¶sbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´K1hj¤ubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubhï)”}”(hXDelay accounting fields:: /* Delay accounting fields start * * All values, until the comment "Delay accounting fields end" are * available only if delay accounting is enabled, even though the last * few fields are not delays * * xxx_count is the number of delay values recorded * xxx_delay_total is the corresponding cumulative delay in nanoseconds * * xxx_delay_total wraps around to zero on overflow * xxx_count incremented regardless of overflow */ /* Delay waiting for cpu, while runnable * count, delay_total NOT updated atomically */ __u64 cpu_count; __u64 cpu_delay_total; /* Following four fields atomically updated using task->delays->lock */ /* Delay waiting for synchronous block I/O to complete * does not account for delays in I/O submission */ __u64 blkio_count; __u64 blkio_delay_total; /* Delay waiting for page fault I/O (swap in only) */ __u64 swapin_count; __u64 swapin_delay_total; /* cpu "wall-clock" running time * On some architectures, value will adjust for cpu time stolen * from the kernel in involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_real_total; /* cpu "virtual" running time * Uses time intervals seen by the kernel i.e. no adjustment * for kernel's involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_virtual_total; /* Delay accounting fields end */ /* version 1 ends here */ ”h]”(hÌ)”}”(hŒDelay accounting fields::”h]”hŒDelay accounting fields:”…””}”(hjÎh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KahjÊubje)”}”(hX-/* Delay accounting fields start * * All values, until the comment "Delay accounting fields end" are * available only if delay accounting is enabled, even though the last * few fields are not delays * * xxx_count is the number of delay values recorded * xxx_delay_total is the corresponding cumulative delay in nanoseconds * * xxx_delay_total wraps around to zero on overflow * xxx_count incremented regardless of overflow */ /* Delay waiting for cpu, while runnable * count, delay_total NOT updated atomically */ __u64 cpu_count; __u64 cpu_delay_total; /* Following four fields atomically updated using task->delays->lock */ /* Delay waiting for synchronous block I/O to complete * does not account for delays in I/O submission */ __u64 blkio_count; __u64 blkio_delay_total; /* Delay waiting for page fault I/O (swap in only) */ __u64 swapin_count; __u64 swapin_delay_total; /* cpu "wall-clock" running time * On some architectures, value will adjust for cpu time stolen * from the kernel in involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_real_total; /* cpu "virtual" running time * Uses time intervals seen by the kernel i.e. no adjustment * for kernel's involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_virtual_total; /* Delay accounting fields end */ /* version 1 ends here */”h]”hX-/* Delay accounting fields start * * All values, until the comment "Delay accounting fields end" are * available only if delay accounting is enabled, even though the last * few fields are not delays * * xxx_count is the number of delay values recorded * xxx_delay_total is the corresponding cumulative delay in nanoseconds * * xxx_delay_total wraps around to zero on overflow * xxx_count incremented regardless of overflow */ /* Delay waiting for cpu, while runnable * count, delay_total NOT updated atomically */ __u64 cpu_count; __u64 cpu_delay_total; /* Following four fields atomically updated using task->delays->lock */ /* Delay waiting for synchronous block I/O to complete * does not account for delays in I/O submission */ __u64 blkio_count; __u64 blkio_delay_total; /* Delay waiting for page fault I/O (swap in only) */ __u64 swapin_count; __u64 swapin_delay_total; /* cpu "wall-clock" running time * On some architectures, value will adjust for cpu time stolen * from the kernel in involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_real_total; /* cpu "virtual" running time * Uses time intervals seen by the kernel i.e. no adjustment * for kernel's involuntary waits due to virtualization. * Value is cumulative, in nanoseconds, without a corresponding count * and wraps around to zero silently on overflow */ __u64 cpu_run_virtual_total; /* Delay accounting fields end */ /* version 1 ends here */”…””}”hjÜsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KchjÊubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubhï)”}”(hXDExtended accounting fields:: /* Extended accounting fields start */ /* Accumulated RSS usage in duration of a task, in MBytes-usecs. * The current rss usage is added to this counter every time * a tick is charged to a task's system time. So, at the end we * will have memory usage multiplied by system time. Thus an * average usage per system time unit can be calculated. */ __u64 coremem; /* accumulated RSS usage in MB-usec */ /* Accumulated virtual memory usage in duration of a task. * Same as acct_rss_mem1 above except that we keep track of VM usage. */ __u64 virtmem; /* accumulated VM usage in MB-usec */ /* High watermark of RSS usage in duration of a task, in KBytes. */ __u64 hiwater_rss; /* High-watermark of RSS usage */ /* High watermark of VM usage in duration of a task, in KBytes. */ __u64 hiwater_vm; /* High-water virtual memory usage */ /* The following four fields are I/O statistics of a task. */ __u64 read_char; /* bytes read */ __u64 write_char; /* bytes written */ __u64 read_syscalls; /* read syscalls */ __u64 write_syscalls; /* write syscalls */ /* Extended accounting fields end */ ”h]”(hÌ)”}”(hŒExtended accounting fields::”h]”hŒExtended accounting fields:”…””}”(hjôh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K•hjðubje)”}”(hX·/* Extended accounting fields start */ /* Accumulated RSS usage in duration of a task, in MBytes-usecs. * The current rss usage is added to this counter every time * a tick is charged to a task's system time. So, at the end we * will have memory usage multiplied by system time. Thus an * average usage per system time unit can be calculated. */ __u64 coremem; /* accumulated RSS usage in MB-usec */ /* Accumulated virtual memory usage in duration of a task. * Same as acct_rss_mem1 above except that we keep track of VM usage. */ __u64 virtmem; /* accumulated VM usage in MB-usec */ /* High watermark of RSS usage in duration of a task, in KBytes. */ __u64 hiwater_rss; /* High-watermark of RSS usage */ /* High watermark of VM usage in duration of a task, in KBytes. */ __u64 hiwater_vm; /* High-water virtual memory usage */ /* The following four fields are I/O statistics of a task. */ __u64 read_char; /* bytes read */ __u64 write_char; /* bytes written */ __u64 read_syscalls; /* read syscalls */ __u64 write_syscalls; /* write syscalls */ /* Extended accounting fields end */”h]”hX·/* Extended accounting fields start */ /* Accumulated RSS usage in duration of a task, in MBytes-usecs. * The current rss usage is added to this counter every time * a tick is charged to a task's system time. So, at the end we * will have memory usage multiplied by system time. Thus an * average usage per system time unit can be calculated. */ __u64 coremem; /* accumulated RSS usage in MB-usec */ /* Accumulated virtual memory usage in duration of a task. * Same as acct_rss_mem1 above except that we keep track of VM usage. */ __u64 virtmem; /* accumulated VM usage in MB-usec */ /* High watermark of RSS usage in duration of a task, in KBytes. */ __u64 hiwater_rss; /* High-watermark of RSS usage */ /* High watermark of VM usage in duration of a task, in KBytes. */ __u64 hiwater_vm; /* High-water virtual memory usage */ /* The following four fields are I/O statistics of a task. */ __u64 read_char; /* bytes read */ __u64 write_char; /* bytes written */ __u64 read_syscalls; /* read syscalls */ __u64 write_syscalls; /* write syscalls */ /* Extended accounting fields end */”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´K—hjðubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubhï)”}”(hŒÀPer-task and per-thread statistics:: __u64 nvcsw; /* Context voluntary switch counter */ __u64 nivcsw; /* Context involuntary switch counter */ ”h]”(hÌ)”}”(hŒ$Per-task and per-thread statistics::”h]”hŒ#Per-task and per-thread statistics:”…””}”(hjh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K´hjubje)”}”(hŒ__u64 nvcsw; /* Context voluntary switch counter */ __u64 nivcsw; /* Context involuntary switch counter */”h]”hŒ__u64 nvcsw; /* Context voluntary switch counter */ __u64 nivcsw; /* Context involuntary switch counter */”…””}”hj(sbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´K¶hjubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubhï)”}”(hŒþTime accounting for SMT machines:: __u64 ac_utimescaled; /* utime scaled on frequency etc */ __u64 ac_stimescaled; /* stime scaled on frequency etc */ __u64 cpu_scaled_run_real_total; /* scaled cpu_run_real_total */ ”h]”(hÌ)”}”(hŒ"Time accounting for SMT machines::”h]”hŒ!Time accounting for SMT machines:”…””}”(hj@h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K¹hj<ubje)”}”(hŒÊ__u64 ac_utimescaled; /* utime scaled on frequency etc */ __u64 ac_stimescaled; /* stime scaled on frequency etc */ __u64 cpu_scaled_run_real_total; /* scaled cpu_run_real_total */”h]”hŒÊ__u64 ac_utimescaled; /* utime scaled on frequency etc */ __u64 ac_stimescaled; /* stime scaled on frequency etc */ __u64 cpu_scaled_run_real_total; /* scaled cpu_run_real_total */”…””}”hjNsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´K»hj<ubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubhï)”}”(hŒ¥Extended delay accounting fields for memory reclaim:: /* Delay waiting for memory reclaim */ __u64 freepages_count; __u64 freepages_delay_total; ”h]”(hÌ)”}”(hŒ5Extended delay accounting fields for memory reclaim::”h]”hŒ4Extended delay accounting fields for memory reclaim:”…””}”(hjfh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K¿hjbubje)”}”(hŒ^/* Delay waiting for memory reclaim */ __u64 freepages_count; __u64 freepages_delay_total;”h]”hŒ^/* Delay waiting for memory reclaim */ __u64 freepages_count; __u64 freepages_delay_total;”…””}”hjtsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KÁhjbubeh}”(h]”h ]”h"]”h$]”h&]”uh1hîhj¡h²hh³hÊh´Nubeh}”(h]”h ]”h"]”h$]”h&]”j€jj‚hjƒj„uh1héhh·h²hh³hÊh´K/ubje)”}”(hŒ}”h]”hŒ}”…””}”hjŽsbah}”(h]”h ]”h"]”h$]”h&]”jtjuuh1jdh³hÊh´KÇhh·h²hubeh}”(h]”Œthe-struct-taskstats”ah ]”h"]”Œthe struct taskstats”ah$]”h&]”uh1hµhhh²hh³hÊh´Kubeh}”(h]”h ]”h"]”h$]”h&]”Œsource”hÊuh1hŒcurrent_source”NŒ current_line”NŒsettings”Œdocutils.frontend”ŒValues”“”)”}”(hºNŒ generator”NŒ datestamp”NŒ source_link”NŒ source_url”NŒ toc_backlinks”Œentry”Œfootnote_backlinks”KŒ sectnum_xform”KŒstrip_comments”NŒstrip_elements_with_classes”NŒ strip_classes”NŒ report_level”KŒ halt_level”KŒexit_status_level”KŒdebug”NŒwarning_stream”NŒ traceback”ˆŒinput_encoding”Œ utf-8-sig”Œinput_encoding_error_handler”Œstrict”Œoutput_encoding”Œutf-8”Œoutput_encoding_error_handler”jÇŒerror_encoding”Œutf-8”Œerror_encoding_error_handler”Œbackslashreplace”Œ language_code”Œen”Œrecord_dependencies”NŒconfig”NŒ id_prefix”hŒauto_id_prefix”Œid”Œ dump_settings”NŒdump_internals”NŒdump_transforms”NŒdump_pseudo_xml”NŒexpose_internals”NŒstrict_visitor”NŒ_disable_config”NŒ_source”hÊŒ _destination”NŒ _config_files”]”Œ7/var/lib/git/docbuild/linux/Documentation/docutils.conf”aŒfile_insertion_enabled”ˆŒ raw_enabled”KŒline_length_limit”M'Œpep_references”NŒ pep_base_url”Œhttps://peps.python.org/”Œpep_file_url_template”Œpep-%04d”Œrfc_references”NŒ rfc_base_url”Œ&https://datatracker.ietf.org/doc/html/”Œ tab_width”KŒtrim_footnote_reference_space”‰Œsyntax_highlight”Œlong”Œ smart_quotes”ˆŒsmartquotes_locales”]”Œcharacter_level_inline_markup”‰Œdoctitle_xform”‰Œ docinfo_xform”KŒsectsubtitle_xform”‰Œ image_loading”Œlink”Œembed_stylesheet”‰Œcloak_email_addresses”ˆŒsection_self_link”‰Œenv”NubŒreporter”NŒindirect_targets”]”Œsubstitution_defs”}”Œsubstitution_names”}”Œrefnames”}”Œrefids”}”Œnameids”}”j¡jžsŒ nametypes”}”j¡‰sh}”jžh·sŒ footnote_refs”}”Œ citation_refs”}”Œ autofootnotes”]”Œautofootnote_refs”]”Œsymbol_footnotes”]”Œsymbol_footnote_refs”]”Œ footnotes”]”Œ citations”]”Œautofootnote_start”KŒsymbol_footnote_start”KŒ id_counter”Œ collections”ŒCounter”“”}”…”R”Œparse_messages”]”Œtransform_messages”]”Œ transformer”NŒ include_log”]”Œ decoration”Nh²hub.