1da0c48c4Sopenharmony_ci/* Fetch live process registers from TID. C-SKY version.
2da0c48c4Sopenharmony_ci   Copyright (C) 2019 Hangzhou C-SKY Microsystems co.,ltd.
3da0c48c4Sopenharmony_ci   This file is part of elfutils.
4da0c48c4Sopenharmony_ci
5da0c48c4Sopenharmony_ci   This file is free software; you can redistribute it and/or modify
6da0c48c4Sopenharmony_ci   it under the terms of either
7da0c48c4Sopenharmony_ci
8da0c48c4Sopenharmony_ci     * the GNU Lesser General Public License as published by the Free
9da0c48c4Sopenharmony_ci       Software Foundation; either version 3 of the License, or (at
10da0c48c4Sopenharmony_ci       your option) any later version
11da0c48c4Sopenharmony_ci
12da0c48c4Sopenharmony_ci   or
13da0c48c4Sopenharmony_ci
14da0c48c4Sopenharmony_ci     * the GNU General Public License as published by the Free
15da0c48c4Sopenharmony_ci       Software Foundation; either version 2 of the License, or (at
16da0c48c4Sopenharmony_ci       your option) any later version
17da0c48c4Sopenharmony_ci
18da0c48c4Sopenharmony_ci   or both in parallel, as here.
19da0c48c4Sopenharmony_ci
20da0c48c4Sopenharmony_ci   elfutils is distributed in the hope that it will be useful, but
21da0c48c4Sopenharmony_ci   WITHOUT ANY WARRANTY; without even the implied warranty of
22da0c48c4Sopenharmony_ci   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
23da0c48c4Sopenharmony_ci   General Public License for more details.
24da0c48c4Sopenharmony_ci
25da0c48c4Sopenharmony_ci   You should have received copies of the GNU General Public License and
26da0c48c4Sopenharmony_ci   the GNU Lesser General Public License along with this program.  If
27da0c48c4Sopenharmony_ci   not, see <http://www.gnu.org/licenses/>.  */
28da0c48c4Sopenharmony_ci
29da0c48c4Sopenharmony_ci#ifdef HAVE_CONFIG_H
30da0c48c4Sopenharmony_ci# include <config.h>
31da0c48c4Sopenharmony_ci#endif
32da0c48c4Sopenharmony_ci
33da0c48c4Sopenharmony_ci#include "system.h"
34da0c48c4Sopenharmony_ci#include <assert.h>
35da0c48c4Sopenharmony_ci#if defined __CSKY__ && defined __linux__
36da0c48c4Sopenharmony_ci# include <sys/uio.h>
37da0c48c4Sopenharmony_ci# include <sys/procfs.h>
38da0c48c4Sopenharmony_ci# include <sys/ptrace.h>
39da0c48c4Sopenharmony_ci#endif
40da0c48c4Sopenharmony_ci
41da0c48c4Sopenharmony_ci#define BACKEND csky_
42da0c48c4Sopenharmony_ci#include "libebl_CPU.h"
43da0c48c4Sopenharmony_ci
44da0c48c4Sopenharmony_cibool
45da0c48c4Sopenharmony_cicsky_set_initial_registers_tid (pid_t tid __attribute__ ((unused)),
46da0c48c4Sopenharmony_ci			ebl_tid_registers_t *setfunc __attribute__ ((unused)),
47da0c48c4Sopenharmony_ci				void *arg __attribute__ ((unused)))
48da0c48c4Sopenharmony_ci{
49da0c48c4Sopenharmony_ci#if !defined __CSKY__ || !defined __linux__
50da0c48c4Sopenharmony_ci  return false;
51da0c48c4Sopenharmony_ci#else /* __CSKY__ */
52da0c48c4Sopenharmony_ci  struct pt_regs user_regs;
53da0c48c4Sopenharmony_ci  struct iovec iovec;
54da0c48c4Sopenharmony_ci  iovec.iov_base = &user_regs;
55da0c48c4Sopenharmony_ci  iovec.iov_len = sizeof (user_regs);
56da0c48c4Sopenharmony_ci  if (ptrace (PTRACE_GETREGSET, tid, NT_PRSTATUS, &iovec) != 0)
57da0c48c4Sopenharmony_ci    return false;
58da0c48c4Sopenharmony_ci
59da0c48c4Sopenharmony_ci  Dwarf_Word dwarf_regs[38];
60da0c48c4Sopenharmony_ci
61da0c48c4Sopenharmony_ci  /* lr.  */
62da0c48c4Sopenharmony_ci  dwarf_regs[15] = user_regs.lr;
63da0c48c4Sopenharmony_ci  /* sp.  */
64da0c48c4Sopenharmony_ci  dwarf_regs[14] = user_regs.usp;
65da0c48c4Sopenharmony_ci  /* r0 ~ r13.  */
66da0c48c4Sopenharmony_ci  dwarf_regs[0] = user_regs.a0;
67da0c48c4Sopenharmony_ci  dwarf_regs[1] = user_regs.a1;
68da0c48c4Sopenharmony_ci  dwarf_regs[2] = user_regs.a2;
69da0c48c4Sopenharmony_ci  dwarf_regs[3] = user_regs.a3;
70da0c48c4Sopenharmony_ci  for (int i = 4; i < 14; i++)
71da0c48c4Sopenharmony_ci    dwarf_regs[i] = user_regs.regs[i - 4];
72da0c48c4Sopenharmony_ci  /* r ~ r13.  */
73da0c48c4Sopenharmony_ci  for (int i = 16; i < 31; i++)
74da0c48c4Sopenharmony_ci    dwarf_regs[i] = user_regs.exregs[i - 16];
75da0c48c4Sopenharmony_ci  /* tls.  */
76da0c48c4Sopenharmony_ci  dwarf_regs[31] = user_regs.tls;
77da0c48c4Sopenharmony_ci  /* hi.  */
78da0c48c4Sopenharmony_ci  dwarf_regs[36] = user_regs.rhi;
79da0c48c4Sopenharmony_ci  /* lo.  */
80da0c48c4Sopenharmony_ci  dwarf_regs[37] = user_regs.rlo;
81da0c48c4Sopenharmony_ci  /* pc.  */
82da0c48c4Sopenharmony_ci  dwarf_regs[32] = user_regs.pc;
83da0c48c4Sopenharmony_ci  setfunc (-1, 1, &dwarf_regs[32], arg);
84da0c48c4Sopenharmony_ci
85da0c48c4Sopenharmony_ci  return setfunc (0, 38, dwarf_regs, arg);
86da0c48c4Sopenharmony_ci#endif
87da0c48c4Sopenharmony_ci}
88