From: Mike Frysinger <vapier@gentoo.org>
To: Jiri Gaisler <jiri@gaisler.se>
Cc: gdb-patches@sourceware.org
Subject: Re: [PATCH v4 03/13] sim/erc32: Switched emulated memory to host endian order.
Date: Sun, 22 Mar 2015 22:46:00 -0000 [thread overview]
Message-ID: <20150323024519.GB8039@vapier> (raw)
In-Reply-To: <1426626170-21401-4-git-send-email-jiri@gaisler.se>
[-- Attachment #1: Type: text/plain, Size: 1900 bytes --]
On 17 Mar 2015 22:02, Jiri Gaisler wrote:
> --- a/sim/erc32/erc32.c
> +++ b/sim/erc32/erc32.c
>
> static void
> -fetch_bytes (asi, mem, data, sz)
> +store_bytes (mem, waddr, data, sz, ws)
as some point we'll want to switch over to sim-core.c and then all these
accessor funcs you have would go away. but we don't need to do that now.
> +#ifdef HOST_LITTLE_ENDIAN
> + waddr ^= 3;
> +#endif
> + mem[waddr] = *data & 0x0ff;
doesn't this assume the target is big endian ? this shows up a few times in
the changes to this file.
> + memcpy(&mem[waddr], data, 2);
space before the (. this shows up a few times in the changes to this file.
> + *data = *((uint32 *) & (romb[addr & ~3]));
broken indentation, and you need to use the union/memcpy logic. this shows up a
few times in the changes to this file.
> + mexc = memory_read(asi, address, ddata, 2, &ws);
you should scan the whole change for new lines that are missing the space before
the (
> sregs.freq = freq ? freq : 15;
> termsave = fcntl(0, F_GETFL, 0);
> INIT_DISASSEMBLE_INFO(dinfo, stdout,(fprintf_ftype)fprintf);
> +#ifdef HOST_LITTLE_ENDIAN
> + dinfo.endian = BFD_ENDIAN_LITTLE;
> +#else
> dinfo.endian = BFD_ENDIAN_BIG;
> +#endif
can't you get the target endian info via the bfd library ?
> +#ifdef HOST_LITTLE_ENDIAN
> + int *ibufp = (int *) buf;
needs a union
> + int ibuf[8192];
> + int i, len;
> +
> + if (length >= 4)
> + for (i = 0; i < length; i += 4) {
> + ibuf[i] = T2H_4(ibufp[i]);
> + }
> + return (sis_memory_write(mem, (char *) ibuf, length));
> +#else
> return (sis_memory_write(mem, buf, length));
> +#endif
the point of using sim-endian is that you wouldn't have any ifdefs. code the
loop and let gcc optimize away the "nothing to do" case.
-mike
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 819 bytes --]
next prev parent reply other threads:[~2015-03-22 22:46 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-17 21:03 [PATCH v4 00/13] Update of the SPARC SIS simulator Jiri Gaisler
2015-03-17 21:03 ` [PATCH v4 02/13] sim/erc32: Removed type mismatch compiler warnings Jiri Gaisler
2015-03-17 22:59 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 11/13] sim/erc32: Updated documentation Jiri Gaisler
2015-03-28 7:17 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 10/13] sim/erc32: Add support for LEON2 processor emulation Jiri Gaisler
2015-03-28 7:21 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 04/13] sim/erc32: Use memory_iread() function for instruction fetching Jiri Gaisler
2015-03-28 7:01 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 03/13] sim/erc32: Switched emulated memory to host endian order Jiri Gaisler
2015-03-22 22:46 ` Mike Frysinger [this message]
2015-03-23 9:01 ` Jiri Gaisler
2015-03-28 7:41 ` Mike Frysinger
2015-03-28 8:21 ` Jiri Gaisler
2015-03-24 9:39 ` Jiri Gaisler
2015-03-27 10:26 ` Jiri Gaisler
2015-03-17 21:03 ` [PATCH v4 05/13] sim/erc32: Fix a few compiler warnings Jiri Gaisler
2015-03-28 7:06 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 09/13] sim/erc32: Add support for LEON3 processor emulation Jiri Gaisler
2015-03-17 21:03 ` [PATCH v4 07/13] sim/erc32: Access memory subsystem through struct memsys Jiri Gaisler
2015-03-28 7:15 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 06/13] sim/erc32: Use gdb callback for UART I/O when linked with gdb Jiri Gaisler
2015-03-28 7:13 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 01/13] sim/erc32: Added -v command line switch for verbose output Jiri Gaisler
2015-03-17 22:56 ` Mike Frysinger
2015-03-17 21:03 ` [PATCH v4 12/13] sim/erc32: Add data watchpoint support Jiri Gaisler
2015-03-28 7:16 ` Mike Frysinger
2015-03-17 21:04 ` [PATCH v4 13/13] Add watchpoint support to gdb simulator interface Jiri Gaisler
2015-03-28 7:19 ` Mike Frysinger
2015-03-30 20:51 ` Jiri Gaisler
2015-03-17 21:04 ` [PATCH v4 08/13] sim/erc32: Move local extern declarations into sis.h Jiri Gaisler
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150323024519.GB8039@vapier \
--to=vapier@gentoo.org \
--cc=gdb-patches@sourceware.org \
--cc=jiri@gaisler.se \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox