Revision | a86c90e6ba808e997f87f0287d9f01ba8d3e904e (tree) |
---|---|
Time | 2015-06-16 04:31:00 |
Author | Simon Marchi <simon.marchi@eric...> |
Commiter | Simon Marchi |
Clarify doc about memory read/write and non-8-bits addressable memory unit sizes
New in v3:
New in v2:
This patch modifies the manual to clarify the MI, RSP and Python APIs in
regard to reading/writing memory on architectures with addressable
memory unit that are not 8 bits.
Care is taken to use the word "addressable memory unit" or "memory unit"
when referring to one piece of the smallest addressable size on the
current architecture and the word "byte" when referring to an 8-bits
data piece.
For MI, -data-{read,write}-memory are not modified, since they are
deprecated.
gdb/doc/ChangeLog:
* gdb.texinfo (GDB/MI Data Manipulation): Clarify usage of
bytes and memory units for -data-{read,write}-memory-bytes.
(Packets): Same for m, M and X packets.
* python.texi (Inferiors In Python): Same for read_memory and
write_memory.
@@ -1,3 +1,11 @@ | ||
1 | +2015-06-15 Simon Marchi <simon.marchi@ericsson.com> | |
2 | + | |
3 | + * gdb.texinfo (GDB/MI Data Manipulation): Clarify usage of | |
4 | + bytes and memory units for -data-{read,write}-memory-bytes. | |
5 | + (Packets): Same for m, M and X packets. | |
6 | + * python.texi (Inferiors In Python): Same for read_memory and | |
7 | + write_memory. | |
8 | + | |
1 | 9 | 2015-06-10 Jon Turney <jon.turney@dronecode.org.uk> |
2 | 10 | |
3 | 11 | * gdb.texinfo (Separate Debug Files): Document that PE is also |
@@ -9009,6 +9009,18 @@ If the @code{x} command has a repeat count, the address and contents saved | ||
9009 | 9009 | are from the last memory unit printed; this is not the same as the last |
9010 | 9010 | address printed if several units were printed on the last line of output. |
9011 | 9011 | |
9012 | +@anchor{addressable memory unit} | |
9013 | +@cindex addressable memory unit | |
9014 | +Most targets have an addressable memory unit size of 8 bits. This means | |
9015 | +that to each memory address are associated 8 bits of data. Some | |
9016 | +targets, however, have other addressable memory unit sizes. | |
9017 | +Within @value{GDBN} and this document, the term | |
9018 | +@dfn{addressable memory unit} (or @dfn{memory unit} for short) is used | |
9019 | +when explicitly referring to a chunk of data of that size. The word | |
9020 | +@dfn{byte} is used to refer to a chunk of data of 8 bits, regardless of | |
9021 | +the addressable memory unit size of the target. For most systems, | |
9022 | +addressable memory unit is a synonym of byte. | |
9023 | + | |
9012 | 9024 | @cindex remote memory comparison |
9013 | 9025 | @cindex target memory comparison |
9014 | 9026 | @cindex verify remote memory image |
@@ -29579,6 +29591,9 @@ can be used to instantiate this class for a varobj: | ||
29579 | 29591 | This section describes the @sc{gdb/mi} commands that manipulate data: |
29580 | 29592 | examine memory and registers, evaluate expressions, etc. |
29581 | 29593 | |
29594 | +For details about what an addressable memory unit is, | |
29595 | +@pxref{addressable memory unit}. | |
29596 | + | |
29582 | 29597 | @c REMOVED FROM THE INTERFACE. |
29583 | 29598 | @c @subheading -data-assign |
29584 | 29599 | @c Change the value of a program variable. Plenty of side effects. |
@@ -30103,7 +30118,7 @@ next-page="0x000013c0",prev-page="0x00001380",memory=[ | ||
30103 | 30118 | @subsubheading Synopsis |
30104 | 30119 | |
30105 | 30120 | @smallexample |
30106 | - -data-read-memory-bytes [ -o @var{byte-offset} ] | |
30121 | + -data-read-memory-bytes [ -o @var{offset} ] | |
30107 | 30122 | @var{address} @var{count} |
30108 | 30123 | @end smallexample |
30109 | 30124 |
@@ -30112,18 +30127,19 @@ where: | ||
30112 | 30127 | |
30113 | 30128 | @table @samp |
30114 | 30129 | @item @var{address} |
30115 | -An expression specifying the address of the first memory word to be | |
30116 | -read. Complex expressions containing embedded white space should be | |
30130 | +An expression specifying the address of the first addressable memory unit | |
30131 | +to be read. Complex expressions containing embedded white space should be | |
30117 | 30132 | quoted using the C convention. |
30118 | 30133 | |
30119 | 30134 | @item @var{count} |
30120 | -The number of bytes to read. This should be an integer literal. | |
30135 | +The number of addressable memory units to read. This should be an integer | |
30136 | +literal. | |
30121 | 30137 | |
30122 | -@item @var{byte-offset} | |
30123 | -The offsets in bytes relative to @var{address} at which to start | |
30124 | -reading. This should be an integer literal. This option is provided | |
30125 | -so that a frontend is not required to first evaluate address and then | |
30126 | -perform address arithmetics itself. | |
30138 | +@item @var{offset} | |
30139 | +The offset relative to @var{address} at which to start reading. This | |
30140 | +should be an integer literal. This option is provided so that a frontend | |
30141 | +is not required to first evaluate address and then perform address | |
30142 | +arithmetics itself. | |
30127 | 30143 | |
30128 | 30144 | @end table |
30129 | 30145 |
@@ -30134,10 +30150,10 @@ Attributes}. Second, @value{GDBN} will attempt to read the remaining | ||
30134 | 30150 | regions. For each one, if reading full region results in an errors, |
30135 | 30151 | @value{GDBN} will try to read a subset of the region. |
30136 | 30152 | |
30137 | -In general, every single byte in the region may be readable or not, | |
30138 | -and the only way to read every readable byte is to try a read at | |
30153 | +In general, every single memory unit in the region may be readable or not, | |
30154 | +and the only way to read every readable unit is to try a read at | |
30139 | 30155 | every address, which is not practical. Therefore, @value{GDBN} will |
30140 | -attempt to read all accessible bytes at either beginning or the end | |
30156 | +attempt to read all accessible memory units at either beginning or the end | |
30141 | 30157 | of the region, using a binary division scheme. This heuristic works |
30142 | 30158 | well for reading accross a memory map boundary. Note that if a region |
30143 | 30159 | has a readable range that is neither at the beginning or the end, |
@@ -30197,17 +30213,19 @@ where: | ||
30197 | 30213 | |
30198 | 30214 | @table @samp |
30199 | 30215 | @item @var{address} |
30200 | -An expression specifying the address of the first memory word to be | |
30201 | -written. Complex expressions containing embedded white space should be | |
30202 | -quoted using the C convention. | |
30216 | +An expression specifying the address of the first addressable memory unit | |
30217 | +to be written. Complex expressions containing embedded white space should | |
30218 | +be quoted using the C convention. | |
30203 | 30219 | |
30204 | 30220 | @item @var{contents} |
30205 | -The hex-encoded bytes to write. | |
30221 | +The hex-encoded data to write. It is an error if @var{contents} does | |
30222 | +not represent an integral number of addressable memory units. | |
30206 | 30223 | |
30207 | 30224 | @item @var{count} |
30208 | -Optional argument indicating the number of bytes to be written. If @var{count} | |
30209 | -is greater than @var{contents}' length, @value{GDBN} will repeatedly | |
30210 | -write @var{contents} until it fills @var{count} bytes. | |
30225 | +Optional argument indicating the number of addressable memory units to be | |
30226 | +written. If @var{count} is greater than @var{contents}' length, | |
30227 | +@value{GDBN} will repeatedly write @var{contents} until it fills | |
30228 | +@var{count} memory units. | |
30211 | 30229 | |
30212 | 30230 | @end table |
30213 | 30231 |
@@ -34842,8 +34860,9 @@ probes the target state as if a new connection was opened | ||
34842 | 34860 | |
34843 | 34861 | @item m @var{addr},@var{length} |
34844 | 34862 | @cindex @samp{m} packet |
34845 | -Read @var{length} bytes of memory starting at address @var{addr}. | |
34846 | -Note that @var{addr} may not be aligned to any particular boundary. | |
34863 | +Read @var{length} addressable memory units starting at address @var{addr} | |
34864 | +(@pxref{addressable memory unit}). Note that @var{addr} may not be aligned to | |
34865 | +any particular boundary. | |
34847 | 34866 | |
34848 | 34867 | The stub need not use any particular size or alignment when gathering |
34849 | 34868 | data from memory for the response; even if @var{addr} is word-aligned |
@@ -34857,8 +34876,8 @@ suitable for accessing memory-mapped I/O devices. | ||
34857 | 34876 | Reply: |
34858 | 34877 | @table @samp |
34859 | 34878 | @item @var{XX@dots{}} |
34860 | -Memory contents; each byte is transmitted as a two-digit hexadecimal | |
34861 | -number. The reply may contain fewer bytes than requested if the | |
34879 | +Memory contents; each byte is transmitted as a two-digit hexadecimal number. | |
34880 | +The reply may contain fewer addressable memory units than requested if the | |
34862 | 34881 | server was able to read only part of the region of memory. |
34863 | 34882 | @item E @var{NN} |
34864 | 34883 | @var{NN} is errno |
@@ -34866,9 +34885,9 @@ server was able to read only part of the region of memory. | ||
34866 | 34885 | |
34867 | 34886 | @item M @var{addr},@var{length}:@var{XX@dots{}} |
34868 | 34887 | @cindex @samp{M} packet |
34869 | -Write @var{length} bytes of memory starting at address @var{addr}. | |
34870 | -The data is given by @var{XX@dots{}}; each byte is transmitted as a two-digit | |
34871 | -hexadecimal number. | |
34888 | +Write @var{length} addressable memory units starting at address @var{addr} | |
34889 | +(@pxref{addressable memory unit}). The data is given by @var{XX@dots{}}; each | |
34890 | +byte is transmitted as a two-digit hexadecimal number. | |
34872 | 34891 | |
34873 | 34892 | Reply: |
34874 | 34893 | @table @samp |
@@ -35182,7 +35201,8 @@ for success (@pxref{Stop Reply Packets}) | ||
35182 | 35201 | @anchor{X packet} |
35183 | 35202 | @cindex @samp{X} packet |
35184 | 35203 | Write data to memory, where the data is transmitted in binary. |
35185 | -Memory is specified by its address @var{addr} and number of bytes @var{length}; | |
35204 | +Memory is specified by its address @var{addr} and number of addressable memory | |
35205 | +units @var{length} (@pxref{addressable memory unit}); | |
35186 | 35206 | @samp{@var{XX}@dots{}} is binary data (@pxref{Binary Data}). |
35187 | 35207 | |
35188 | 35208 | Reply: |
@@ -2749,7 +2749,7 @@ return an empty tuple. | ||
2749 | 2749 | |
2750 | 2750 | @findex Inferior.read_memory |
2751 | 2751 | @defun Inferior.read_memory (address, length) |
2752 | -Read @var{length} bytes of memory from the inferior, starting at | |
2752 | +Read @var{length} addressable memory units from the inferior, starting at | |
2753 | 2753 | @var{address}. Returns a buffer object, which behaves much like an array |
2754 | 2754 | or a string. It can be modified and given to the |
2755 | 2755 | @code{Inferior.write_memory} function. In @code{Python} 3, the return |
@@ -2762,7 +2762,8 @@ Write the contents of @var{buffer} to the inferior, starting at | ||
2762 | 2762 | @var{address}. The @var{buffer} parameter must be a Python object |
2763 | 2763 | which supports the buffer protocol, i.e., a string, an array or the |
2764 | 2764 | object returned from @code{Inferior.read_memory}. If given, @var{length} |
2765 | -determines the number of bytes from @var{buffer} to be written. | |
2765 | +determines the number of addressable memory units from @var{buffer} to be | |
2766 | +written. | |
2766 | 2767 | @end defun |
2767 | 2768 | |
2768 | 2769 | @findex gdb.search_memory |