diff options
| author | Roland McGrath <[email protected]> | 2006-01-12 03:08:35 +0000 |
|---|---|---|
| committer | Roland McGrath <[email protected]> | 2006-01-12 03:08:35 +0000 |
| commit | 5f38a2c1a4724bb210c62de469a367497942c72a (patch) | |
| tree | 72c4fa35463d69ecc5a69a1322fbf12d2801b29b /backends/s390_regs.c | |
| parent | ef6fbff9407492d4f54ddcd6ab99fb463c0a7980 (diff) | |
2006-01-11 Roland McGrath <[email protected]>
* s390_regs.c: New file.
* Makefile.am (s390_SRCS): Add it.
* s390_init.c (s390_init): Install register_name hook.
Diffstat (limited to 'backends/s390_regs.c')
| -rw-r--r-- | backends/s390_regs.c | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/backends/s390_regs.c b/backends/s390_regs.c new file mode 100644 index 00000000..a0133e48 --- /dev/null +++ b/backends/s390_regs.c @@ -0,0 +1,116 @@ +/* Register names and numbers for S/390 DWARF. + Copyright (C) 2006 Red Hat, Inc. + + This program is Open Source software; you can redistribute it and/or + modify it under the terms of the Open Software License version 1.0 as + published by the Open Source Initiative. + + You should have received a copy of the Open Software License along + with this program; if not, you may obtain a copy of the Open Software + License version 1.0 from http://www.opensource.org/licenses/osl.php or + by writing the Open Source Initiative c/o Lawrence Rosen, Esq., + 3001 King Ranch Road, Ukiah, CA 95482. */ + +#ifdef HAVE_CONFIG_H +# include <config.h> +#endif + +#include <string.h> + +#define BACKEND s390_ +#include "libebl_CPU.h" + + +/* +zseries (64) + +0-15 gpr0-gpr15 x +16-19 fpr[0246] +20-24 fpr[13578] +25-27 fpr1[024] +28 fpr9 +29-31 fpr1[135] +32-47 cr0-cr15 x +48-63 ar0-ar15 x +64 psw_mask +65 psw_address +*/ + + +ssize_t +s390_register_name (Ebl *ebl __attribute__ ((unused)), + int regno, char *name, size_t namelen, + const char **prefix, const char **setname) +{ + if (name == NULL) + return 66; + + if (regno < 0 || regno > 65 || namelen < 7) + return -1; + + *prefix = "%"; + + if (regno < 16) + *setname = "integer"; + else if (regno < 32) + *setname = "FPU"; + else if (regno < 48 || regno > 63) + *setname = "control"; /* XXX ? */ + else + *setname = "address"; /* XXX ? */ + + switch (regno) + { + case 0 ... 9: + name[0] = 'r'; + name[1] = regno + '0'; + namelen = 2; + break; + + case 10 ... 15: + name[0] = 'r'; + name[1] = '1'; + name[2] = regno - 10 + '0'; + namelen = 3; + break; + + case 16 ... 31: + name[0] = 'f'; + regno = (regno & 8) | ((regno & 4) >> 2) | ((regno & 3) << 1); + namelen = 1; + if (regno >= 10) + { + regno -= 10; + name[namelen++] = '1'; + } + name[namelen++] = regno + '0'; + break; + + case 32 + 0 ... 32 + 9: + case 48 + 0 ... 48 + 9: + name[0] = regno < 48 ? 'c' : 'a'; + name[1] = (regno & 15) + '0'; + namelen = 2; + break; + + case 32 + 10 ... 32 + 15: + case 48 + 10 ... 48 + 15: + name[0] = regno < 48 ? 'c' : 'a'; + name[1] = '1'; + name[2] = (regno & 15) - 10 + '0'; + namelen = 3; + break; + + case 64: + return stpcpy (name, "pswm") - name; + case 65: + return stpcpy (name, "pswa") - name; + + default: + *setname = NULL; + return 0; + } + + name[namelen++] = '\0'; + return namelen; +} |
