Re: Re: [PATCH V3] MIPS: Add get_thread_area syscall

From: ååä
Date: Mon Dec 16 2019 - 20:48:12 EST


Dear Paul,

Thank you very much.
I didn`t know this way asm("rdhwr %0, $29" : "=r"(*ptls)) before.Now I have a test for it and it realy can work normally.
I just find get_thread_area syscall at path arch/x86.so I have a implement on MIPS platform. And I think set_thread_area and get_thread_area is matched in pairs.
Now it seems that the get_thread_area syscall is not necessary for criu.

Thanks,
Guoyun Sun

> -----ååéä-----
&gt; åää: "Paul Burton" <paulburton@xxxxxxxxxx>
&gt; åéæé: 2019-12-17 03:33:33 (ææä)
&gt; æää: "Guoyun Sun" <sunguoyun@xxxxxxxxxxx>
&gt; æé: "Ralf Baechle" <ralf@xxxxxxxxxxxxxx>, "James Hogan" <jhogan@xxxxxxxxxx>, "Peter Zijlstra" <peterz@xxxxxxxxxxxxx>, "Christian Brauner" <christian.brauner@xxxxxxxxxx>, "Arnd Bergmann" <arnd@xxxxxxxx>, "Heiko Carstens" <heiko.carstens@xxxxxxxxxx>, "David Howells" <dhowells@xxxxxxxxxx>, "Geert Uytterhoeven" <geert@xxxxxxxxxxxxxx>, "Catalin Marinas" <catalin.marinas@xxxxxxx>, linux-mips@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx, "Tiezhu Yang" <yangtiezhu@xxxxxxxxxxx>, "Xuefeng Li" <lixuefeng@xxxxxxxxxxx>
&gt; äé: Re: [PATCH V3] MIPS: Add get_thread_area syscall
&gt;
&gt; Hi Guoyun,
&gt;
&gt; On Mon, Dec 16, 2019 at 10:17:51AM +0800, Guoyun Sun wrote:
&gt; &gt; CRIU(https://criu.org/) tools will dump TLS(Thread Local Storage) by
&gt; &gt; get_thread_area during checkpoint and restore TLS by set_thread_area during
&gt; &gt; restore. without this syscall, criu restore will fail on MIPS platform
&gt; &gt; because a variable with GCC __thread will be invalid.
&gt; &gt;
&gt; &gt; The following function will be called when criu restore
&gt; &gt;
&gt; &gt; static inline void restore_tls(tls_t *ptls) {
&gt; &gt; asm volatile(
&gt; &gt; "move $4, %0 \n"
&gt; &gt; "li $2, "__stringify(__NR_set_thread_area)" \n"
&gt; &gt; "syscall \n"
&gt; &gt; :
&gt; &gt; : "r"(*ptls)
&gt; &gt; : "$4","$2","memory");
&gt; &gt;
&gt; &gt; the *ptls can be obtained by get_thread_area on MIPS platform when criu
&gt; &gt; checkpoint. just like this:
&gt; &gt;
&gt; &gt; static inline void arch_get_tls(tls_t *ptls)
&gt; &gt; {
&gt; &gt; asm volatile(
&gt; &gt; "move $4, %0 \n"
&gt; &gt; "li $2, "__stringify(__NR_get_thread_area)" \n"
&gt; &gt; "syscall \n"
&gt; &gt; :
&gt; &gt; : "r"(ptls)
&gt; &gt; : "$4","$2","memory");
&gt; &gt;
&gt; &gt; }
&gt;
&gt; Why would you need a syscall for this?
&gt;
&gt; Why not retrieve the value using the rdhwr instruction just like every
&gt; other bit of code using thread-local storage does?
&gt;
&gt; ie. something like:
&gt;
&gt; static inline void arch_get_tls(tls_t *ptls)
&gt; {
&gt; asm("rdhwr %0, $29" : "=r"(*ptls));
&gt; }
&gt;
&gt; Thanks,
&gt; Paul
</lixuefeng@xxxxxxxxxxx></yangtiezhu@xxxxxxxxxxx></catalin.marinas@xxxxxxx></geert@xxxxxxxxxxxxxx></dhowells@xxxxxxxxxx></heiko.carstens@xxxxxxxxxx></arnd@xxxxxxxx></christian.brauner@xxxxxxxxxx></peterz@xxxxxxxxxxxxx></jhogan@xxxxxxxxxx></ralf@xxxxxxxxxxxxxx></sunguoyun@xxxxxxxxxxx></paulburton@xxxxxxxxxx>