Attached Hurd patch El dom., 27 oct. 2019 a las 20:13, Almudena Garcia (< liberamenso10...@gmail.com>) escribió:
> > Please really add it to thread_sched_info_t. > > Fixed. Now working in Hurd patch > > El dom., 27 oct. 2019 a las 19:56, Samuel Thibault (< > samuel.thiba...@gnu.org>) escribió: > >> Almudena Garcia, le dim. 27 oct. 2019 19:44:23 +0100, a ecrit: >> > > + #if THREAD_BASIC_INFO_COUNT > 10 >> > >> > That will be always true. What you want to check is >> *thread_info_count. >> > >> > --- gnumach/kern/thread.c 2019-09-03 01:22:10.932747830 +0200 >> > +++ GNUMach_SMP/kern/thread.c 2019-10-27 19:42:15.360761959 +0100 >> > @@ -1500,11 +1500,11 @@ >> > if (flavor == THREAD_BASIC_INFO) { >> > thread_basic_info_t basic_info; >> > >> > - /* Allow *thread_info_count to be one smaller than the >> > - usual amount, because creation_time is a new member >> > - that some callers might not know about. */ >> > + /* Allow *thread_info_count to be two smaller than the >> > + usual amount, because creation_time and last_processor >> > + are new members that some callers might not know >> about. */ >> > >> > - if (*thread_info_count < THREAD_BASIC_INFO_COUNT - 1) { >> > + if (*thread_info_count < THREAD_BASIC_INFO_COUNT - 2) { >> [...] >> > + /* Check if the basic_info includes all new members >> (including last_processor) */ >> > + if (*thread_info_count == THREAD_BASIC_INFO_COUNT) { >> >> Yes, that's the idea (though you want a >= instead of ==, so that it >> will work after adding another field). >> >> That being said I now realize you added the field to the >> thread_basic_info_t, while the information really belongs to the >> thread_sched_info_t. Please really add it to thread_sched_info_t. You >> have access to it from procfs's process_file_gc_stat by adding >> >> thread_basic_info_t thsi = proc_stat_thread_sched_info (ps); >> >> Samuel >> >>
--- hurd/procfs/process.c 2019-10-26 23:12:40.495359917 +0200 +++ hurd~/procfs/process.c 2019-10-27 20:18:26.114993614 +0100 @@ -221,14 +221,26 @@ struct procinfo *pi = proc_stat_proc_info (ps); task_basic_info_t tbi = proc_stat_task_basic_info (ps); thread_basic_info_t thbi = proc_stat_thread_basic_info (ps); + thread_sched_info_t thsi = proc_stat_thread_sched_info (ps); const char *fn = args_filename (proc_stat_args (ps)); + integer_t last_processor = 0; + vm_address_t start_code = 1; /* 0 would make killall5.c consider it a kernel process, thus use 1 as default. */ vm_address_t end_code = 1; process_t p; error_t err = proc_pid2proc (ps->context->server, ps->pid, &p); + + + if(sizeof(thsi) >= THREAD_SCHED_INFO_COUNT){ + last_processor = thsi->last_processor; + } + else{ + last_processor = 0; + } + if (! err) { boolean_t essential = 0; @@ -286,7 +298,7 @@ (long unsigned) proc_stat_thread_rpc (ps), /* close enough */ 0L, 0L, 0, - 0, + (long unsigned) last_processor, 0, 0, 0LL); }