OpenCores
URL https://opencores.org/ocsvn/rs232_syscon/rs232_syscon/trunk

Subversion Repositories rs232_syscon

[/] [rs232_syscon/] [tags/] [V001/] [rs232_syscon.doc] - Diff between revs 3 and 4

Only display areas with differences | Details | Blame | View Log

Rev 3 Rev 4
аЯрЁБс>ўџ  ]hўџџџ\{џџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџьЅСq ПI<bjbjt+t+   0ІAAи7mџџџџџџ]8Plt–2h2222ž  &Ф
аЯрЁБс>ўџ  ]hўџџџ\{џџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџьЅСq ПI<bjbjt+t+   0ІAAи7mџџџџџџ]8Plt–2h2222ž  &Ф
d(4[2]2]2]2]2]2]2$ў3єђ5†2\š ž \\2x22hxxx\ŽR22[2\[2x‚xњІћ00т"O22р<  ›K$СъŽ+2$
Rs232_syscon
User’s Guide
version 1.00






											 Writen By John Clayton
Scottsdale, AZ
2001.8.13




Purpose:
This document describes some of the design features of “rs232_syscon.v” (a softcore written in Verilog.)  It is intended to facilitate new users in understanding what is available in the core, and how to use it.  Also, the Verilog code itself is replete with comments, so that additional insights into the operation of this core can be gained by reviewing the code.

Release Log
V1.00		Aug. 13, 2001

1.Introduction

The name “rs232_syscon” comes from rs232 (serial communication standard) and an abbreviated contraction of “system controller.”  The core actually uses LVTTL levels for the serial connection, and the user is responsible for providing level shifting translators to achieve rs232 standard voltage levels.

The rs232_syscon project  was conceived on May 30, 2001.  It’s purpose was to develop a “serial-port-to-bus-interface” core suitable for debugging some other ps2_mouse and ps2_keyboard interface cores which were under development at the time…  Those other cores were quickly completed, but the actual development of rs232_syscon was more complicated than originally thought, and it ended up taking longer to complete.  Luckily, as its development progressed, rs232_syscon became simpler instead of more complicated.

After many hours of debugging and coding, the rs232_syscon core is now functional, and it has been successfully used to test out memory blocks and register blocks as part of a “system on a chip” (SOC) design effort.

This document describes the following:

The connection diagram of rs232_syscon.
The command syntax of rs232_syscon.
The serial interface BAUD rate generators.

In reality, rs232_syscon is a simple core to use – once it is connected to the data and address buses and the BAUD rate is adjusted, it can be used immediately.  It does not contain any architecture specific blocks, so it easily ports to different FPGA and even ASIC platforms.
2. rs232_syscon connections

2.1 Block diagram

A top-level block diagram of rs232_syscon being used in  a system is shown in figure2.1 below.

Since the address bus is not bidirectional, it is an output from the host processor, and also an output from rs232_syscon.  In order to select which device gets to drive the address bus, a multiplexer is implemented inside of rs232_syscon.  This introduces some additional delay in the address bus, which is considered an acceptable tradeoff in exchange for the enhanced debugging capability of rs232_syscon.  Besides, when debugging is completed, the mux can be removed (or “hard wired” by a parameter at compile time, which will also result in the eventual removal of the mux because of optimization in the synthesis and routing tools…)

 EMBED Word.Picture.8  
figure 2.1


The data bus is implemented as a tri-state bus, so that it can be bi-directional without requiring the use of multiplexers.  The designers of rs232_syscon were aware that the Wishbone standard seems to encourage a split data bus (dat_i for input data and dat_o for output data) but found that the Wishbone standard also allows for tri-state connections (See Wishbone spec. page 66).  The tri-state data bus was chosen in order to reduce the number of internal interconnects needed to implement the bus.  If a tri-state bus is unacceptable for your application, the rs232_syscon block can be easily modified to add “dat_i” and “dat_o” ports in place of the existing “dat_io” port, and the tri-state buffering can be removed.  This is not difficult for a Verilog programmer to accomplish, and it does not require any major functional modifications to the rs232_syscon block.  The same handshaking structure that is used for address bus multiplexing (“master_br_o” and “master_bg_i”) could also be used to control the data bus multiplexers.

The handshaking scheme in rs232_syscon allows the rs232_syscon to request access to the bus from the normal bus master.  This is accomplished through the “master_br_o” and “master_bg_i” pins.  Once the bus request (br) is detected at the normal bus master, it should finish the current operation, and then assert and keep asserting “master_bg” to rs232_syscon.  As long as the bus grant (bg) line is asserted into rs232_syscon, then rs232_syscon will know that it has control of the bus.  Also, when rs232_syscon finishes generating its bus cycles, it does not check or wait for the bus grant line to be deasserted.  Therefore, those who wish to test peripherals, memory or registers without another master on the bus, can simply tie “master_bg_i” high, or just connect it to the rs232_syscon’s “master_br_o” and forget about that handshaking interface.

The bus cycles generated by rs232_syscon are one clock long.  The clock which is used with rs232_syscon can vary up to the maximum speed allowed by the architecture in which it is being used.  In a Xilinx SpartanII device (XC2S200) it synthesized with a maximum clock speed of around 45 MHz, although most of the testing was done at around 25 MHz.  The length of each bus cycle is extended until the “ack_i” signal is received by rs232_syscon.  If the watchdog timer expires before “ack_i” is received, then a bus error message is generated for the user.  Similarly, if the “err_i” signal is received, then a bus error message is generated for the user.

 
2.2 Parameter listing

Parameter NameRangeFunctionADR_DIGITS_PP1..?Width of address bus in nibbles   (4 => 16bits, 8 => 32 bits)DAT_DIGITS_PP1..?Width of data bus in nibblesQTY_DIGITS_PP1..?Width of qty counter in nibblesCMD_BUFFER_SIZE_PP16/32/64Characters in command buffer (drives logic size significantly)CMD_PTR_BITS_PP4/5/6Width of pointer to command buff.WATCHDOG_TIMER_VALUE_PP1..?Number of clocks before timer expiresWATCHDOG_TIMER_BITS_PP1..?Number of bits in watchdog timerRD_FIELDS_PP1..?Number of columns shown for readRD_FIELD_COUNT_BITS_PP1..?Number of bits in rd_field_countRD_DIGIT_COUNT_BITS_PP1..?Number of bits in rd_digit_count

The defaults for these parameters are given in the Verilog code.  The settings are related to each other, as explained in the code also.  For instance, if the watchdog_timer is set to expire after 32000 clocks, then there must be 15 bits in the watchdog timer, so that parameter must be set accordingly.

2.3 Pinout description (port listing)

NameSizeFunctionclk_i1Clock inputreset_i1Resets rs232_syscon unitmaster_bg_i1Grants bus to rs232_sysconack_i1Wishbone bus cycle acknowledgeerr_i1Wishbone bus cycle errorrs232_rxd_i1rs232 serial port data inputdat_ioparameterdata bus (tri-state)rst_o1Wishbone reset outputmaster_br_o1Requests bus for rs232_sysconstb_o1Wishbone strobe outputcyc_o1Wishbone cycle output (wired to stb_o in this version)adr_oparameteraddress buswe_o1Wishbone write enable outputrs232_txd_o1rs232 serial port data output

3.0 Command syntax

The commands for rs232_syscon are very simple.  There are three of them – read, write and initialize (reset).  The spacing of the characters in the command does not matter – spaces and tabs are considered “whitespace.”  The enter key terminates the command, and begins the process of parsing and executing the command.  All numbers are given in hexadecimal.  Hexadecimal numbers are printed using capitalized letters, but case does not matter when entering commands.

The command syntax is as follows, where “aaaa” refers to address, “dddd” refers to data, and “qq” refers to quantity.

Write command:          w aaaa dddd qq
Read command:            r aaaa qq
Initialize command:   i

The command character (w,r,i) is the only required part of the command.  If the data field is left out, then the previous value is assumed.  If the address field is left out, then the previous value is assumed.  Default values for address and data are both zero.  An exception to this rule is the quantity field (qq), which does NOT assume the previous value.  Instead, if quantity is not specified, it assumes the value “1,” which is generally what the user intends for a command that does not specify quantity.

When entering quantity explicitly, the value zero is allowed.  In that case, the command will do nothing.  No bus cycles will be generated.  For quantity values greater than one, the address field is automatically incremented during the subsequent iterations of the command loop.  However, the data remains the same.

Extra fields can be entered after the “i” command, but they will not have any effect.


3.1 Numerical Field length

Using too few characters for a given numerical field will not produce an error – for instance, if the address/data buses are 16-bits wide, and you wish to enter the value 0005 into address 0017, it is sufficient to say:

w 17 5 [enter]

The leading zeros are assumed by the command parser.  Similarly, if too many digits are used, only the appropriate number of digits (the right hand ones) are used.  For instance, consider the command:

w 5434540017 66677560005 [enter]

This would have the same effect as the first example, because only the four digits on the right side are used (0017 and 0005 respectively).

backspace is allowed, and the cursor will move inside the rs232 terminal to indicate that a character has been “deleted” from the command line, even if the character itself still shows up on the terminal screen.

The maximum number of characters that can be entered on the command line is determined by the size of the command buffer (a parameter setting.)  When that length is reached, if the [enter] key has not yet been pressed, a ‘?’ message will be returned, indicating a parsing error.

3.1 Parsing errors

The different responses which can be generated from rs232_syscon are listed here:

ResponseMeaningOKThe command was parsed and executed without error?Line length exceededA?Address field parsing errorD?Data field parsing errorQ?Quantity field parsing error!“err_i” or else watchdog timeout before “ack_i”B!Watchdog timeout before bus grant
The watchdog timer is used twice during the execution of a command.  The first time it is used to determine if there was a timeout for obtaining the bus, and the second time it is used to determine if the bus cycle timed out, with no “ack_i” response.  Therefore, a slow master together with a slow peripheral could conceivably use almost twice the time period of the watchdog timer, in order to complete the execution of the command.


3.2 Initial power up

The initial power up of rs232_syscon produces the following stream of characters which are sent to the terminal:

0123456789ABCDEF
-> [cursor]

This initial stream of characters can be used to verify that your terminal is set to the correct BAUD rate.

Also, no activity is generated to reset the peripherals on the bus upon initial power up.  Therefore, in order to reset the peripherals on the bus, an explicit “i” command must be issued.  Resetting the rs232_syscon unit will return all quantities to zero, but it will not generate the “rst_o” signal which is generated by the “i” command.


3.3 Actual session logfile

Here is the text from part of a debugging session using the rs232_syscon module (none of the bus error responses are shown here):


0123456789ABCDEF
-> w 1 55 1
OK
-> w 1 5a
OK
-> w 4 4c
OK
-> w 2 140
OK
-> w 3 100
OK
-> w 4 5c
OK
-> w 4 6c
OK
-> w 2 150
OK
-> w 3 f8
OK
-> w 3 f0
OK
-> w 3 f8
OK
-> w 3 f7
OK
-> w 3 48
OK
-> r 3
0003 : 0048 OK
-> r 0 8
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
OK
-> r 0 10
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
0008 : 0000 005A 0150 0048 006C 0000 0000 0000
OK
-> r 0 20
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
0008 : 0000 005A 0150 0048 006C 0000 0000 0000
0010 : FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF
0018 : FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF
OK
-> w 3 58
OK
-> w 3 68
OK
-> r 0 10
0000 : 0000 0068 0068 0068 0068 0068 0068 0068
0008 : 0000 0068 0068 0068 0068 0068 0068 0068
OK
-> w 3 58 1
OK
-> w 4 68 1
OK
-> r 0 10
0000 : 0000 0068 0068 0058 0068 0068 0068 0068
0008 : 0000 0068 0068 0058 0068 0068 0068 0068
OK
-> w 4 6c 1
OK
-> w 4 7c 1
OK
-> w 1 f4 1
OK
-> r 0 8
0000 : 0000 00F4 0068 0058 007C 0068 0068 0068
OK


4.0 BAUD rate generators

The BAUD rate used in rs232_syscon is determined by a in internal signal called “serial_clk_16x.”  This signal is not actually implemented on a clock net.  Instead, it is a clock enable.  Using a clock enable for this slow signal is perfectly acceptable in most cases, and it has the advantage that it does not use an additional dedicated clock resource on the target FPGA.

As indicated by the name, the signal occurs at 16 times the desired BAUD clock rate.  For 115,200 BAUD it is a high pulse which occurs for one single “clk_i” clock period, at a rate of 16*115200 = 1.8432 MHz.

This clock enable pulse is derived from a higher frequency clock on your board, by a small DDS (Direct Digital Synthesizer.)  It sounds more complicated than it is.  This DDS does not produce a sine-wave output, it merely produces a single pulse at the desired rate.  You can use different modules from “serial.v” in order to do this.  The “clock_gen_select” allows you to use a lookup table of DDS phase increment values (which are directly related to the output frequency) so that the BAUD rate can be changed easily between common values.

On the other hand, you could choose to use the “clk_gen” module from serial.v in order to generate a single, fixed BAUD clock.

You will almost certainly need to re-calculate the DDS “frequency” inputs for use with your board, since you will undoubtedly be using some clock other than the 49.152 MHz which I chose to use.

However, the nature of the DDS circuit is such that you can most likely find a way to make it work without having to change your system clock frequency.  Almost anything can be made to work.  Some frequency error is tolerable in the BAUD clocks, and by making the DDS bigger then more and more resolution is obtained until it works for your frequency...  Detailed instructions are given in “serial.v” on how to recalculate new values for use in your application.  Or you can simply get a different clock!
rs232_syscon             

                        rs232_syscon



                           rs232_syscon  






(.ABmnvw…ŽЎу    %
d(4[2]2]2]2]2]2]2$ў3єђ5†2\š ž \\2x22hxxx\ŽR22[2\[2x‚xњІћ00т"O22р<  ›K$СъŽ+2$
Rs232_syscon
User’s Guide
version 1.00






											 Writen By John Clayton
Scottsdale, AZ
2001.8.13




Purpose:
This document describes some of the design features of “rs232_syscon.v” (a softcore written in Verilog.)  It is intended to facilitate new users in understanding what is available in the core, and how to use it.  Also, the Verilog code itself is replete with comments, so that additional insights into the operation of this core can be gained by reviewing the code.

Release Log
V1.00		Aug. 13, 2001

1.Introduction

The name “rs232_syscon” comes from rs232 (serial communication standard) and an abbreviated contraction of “system controller.”  The core actually uses LVTTL levels for the serial connection, and the user is responsible for providing level shifting translators to achieve rs232 standard voltage levels.

The rs232_syscon project  was conceived on May 30, 2001.  It’s purpose was to develop a “serial-port-to-bus-interface” core suitable for debugging some other ps2_mouse and ps2_keyboard interface cores which were under development at the time…  Those other cores were quickly completed, but the actual development of rs232_syscon was more complicated than originally thought, and it ended up taking longer to complete.  Luckily, as its development progressed, rs232_syscon became simpler instead of more complicated.

After many hours of debugging and coding, the rs232_syscon core is now functional, and it has been successfully used to test out memory blocks and register blocks as part of a “system on a chip” (SOC) design effort.

This document describes the following:

The connection diagram of rs232_syscon.
The command syntax of rs232_syscon.
The serial interface BAUD rate generators.

In reality, rs232_syscon is a simple core to use – once it is connected to the data and address buses and the BAUD rate is adjusted, it can be used immediately.  It does not contain any architecture specific blocks, so it easily ports to different FPGA and even ASIC platforms.
2. rs232_syscon connections

2.1 Block diagram

A top-level block diagram of rs232_syscon being used in  a system is shown in figure2.1 below.

Since the address bus is not bidirectional, it is an output from the host processor, and also an output from rs232_syscon.  In order to select which device gets to drive the address bus, a multiplexer is implemented inside of rs232_syscon.  This introduces some additional delay in the address bus, which is considered an acceptable tradeoff in exchange for the enhanced debugging capability of rs232_syscon.  Besides, when debugging is completed, the mux can be removed (or “hard wired” by a parameter at compile time, which will also result in the eventual removal of the mux because of optimization in the synthesis and routing tools…)

 EMBED Word.Picture.8  
figure 2.1


The data bus is implemented as a tri-state bus, so that it can be bi-directional without requiring the use of multiplexers.  The designers of rs232_syscon were aware that the Wishbone standard seems to encourage a split data bus (dat_i for input data and dat_o for output data) but found that the Wishbone standard also allows for tri-state connections (See Wishbone spec. page 66).  The tri-state data bus was chosen in order to reduce the number of internal interconnects needed to implement the bus.  If a tri-state bus is unacceptable for your application, the rs232_syscon block can be easily modified to add “dat_i” and “dat_o” ports in place of the existing “dat_io” port, and the tri-state buffering can be removed.  This is not difficult for a Verilog programmer to accomplish, and it does not require any major functional modifications to the rs232_syscon block.  The same handshaking structure that is used for address bus multiplexing (“master_br_o” and “master_bg_i”) could also be used to control the data bus multiplexers.

The handshaking scheme in rs232_syscon allows the rs232_syscon to request access to the bus from the normal bus master.  This is accomplished through the “master_br_o” and “master_bg_i” pins.  Once the bus request (br) is detected at the normal bus master, it should finish the current operation, and then assert and keep asserting “master_bg” to rs232_syscon.  As long as the bus grant (bg) line is asserted into rs232_syscon, then rs232_syscon will know that it has control of the bus.  Also, when rs232_syscon finishes generating its bus cycles, it does not check or wait for the bus grant line to be deasserted.  Therefore, those who wish to test peripherals, memory or registers without another master on the bus, can simply tie “master_bg_i” high, or just connect it to the rs232_syscon’s “master_br_o” and forget about that handshaking interface.

The bus cycles generated by rs232_syscon are one clock long.  The clock which is used with rs232_syscon can vary up to the maximum speed allowed by the architecture in which it is being used.  In a Xilinx SpartanII device (XC2S200) it synthesized with a maximum clock speed of around 45 MHz, although most of the testing was done at around 25 MHz.  The length of each bus cycle is extended until the “ack_i” signal is received by rs232_syscon.  If the watchdog timer expires before “ack_i” is received, then a bus error message is generated for the user.  Similarly, if the “err_i” signal is received, then a bus error message is generated for the user.

 
2.2 Parameter listing

Parameter NameRangeFunctionADR_DIGITS_PP1..?Width of address bus in nibbles   (4 => 16bits, 8 => 32 bits)DAT_DIGITS_PP1..?Width of data bus in nibblesQTY_DIGITS_PP1..?Width of qty counter in nibblesCMD_BUFFER_SIZE_PP16/32/64Characters in command buffer (drives logic size significantly)CMD_PTR_BITS_PP4/5/6Width of pointer to command buff.WATCHDOG_TIMER_VALUE_PP1..?Number of clocks before timer expiresWATCHDOG_TIMER_BITS_PP1..?Number of bits in watchdog timerRD_FIELDS_PP1..?Number of columns shown for readRD_FIELD_COUNT_BITS_PP1..?Number of bits in rd_field_countRD_DIGIT_COUNT_BITS_PP1..?Number of bits in rd_digit_count

The defaults for these parameters are given in the Verilog code.  The settings are related to each other, as explained in the code also.  For instance, if the watchdog_timer is set to expire after 32000 clocks, then there must be 15 bits in the watchdog timer, so that parameter must be set accordingly.

2.3 Pinout description (port listing)

NameSizeFunctionclk_i1Clock inputreset_i1Resets rs232_syscon unitmaster_bg_i1Grants bus to rs232_sysconack_i1Wishbone bus cycle acknowledgeerr_i1Wishbone bus cycle errorrs232_rxd_i1rs232 serial port data inputdat_ioparameterdata bus (tri-state)rst_o1Wishbone reset outputmaster_br_o1Requests bus for rs232_sysconstb_o1Wishbone strobe outputcyc_o1Wishbone cycle output (wired to stb_o in this version)adr_oparameteraddress buswe_o1Wishbone write enable outputrs232_txd_o1rs232 serial port data output

3.0 Command syntax

The commands for rs232_syscon are very simple.  There are three of them – read, write and initialize (reset).  The spacing of the characters in the command does not matter – spaces and tabs are considered “whitespace.”  The enter key terminates the command, and begins the process of parsing and executing the command.  All numbers are given in hexadecimal.  Hexadecimal numbers are printed using capitalized letters, but case does not matter when entering commands.

The command syntax is as follows, where “aaaa” refers to address, “dddd” refers to data, and “qq” refers to quantity.

Write command:          w aaaa dddd qq
Read command:            r aaaa qq
Initialize command:   i

The command character (w,r,i) is the only required part of the command.  If the data field is left out, then the previous value is assumed.  If the address field is left out, then the previous value is assumed.  Default values for address and data are both zero.  An exception to this rule is the quantity field (qq), which does NOT assume the previous value.  Instead, if quantity is not specified, it assumes the value “1,” which is generally what the user intends for a command that does not specify quantity.

When entering quantity explicitly, the value zero is allowed.  In that case, the command will do nothing.  No bus cycles will be generated.  For quantity values greater than one, the address field is automatically incremented during the subsequent iterations of the command loop.  However, the data remains the same.

Extra fields can be entered after the “i” command, but they will not have any effect.


3.1 Numerical Field length

Using too few characters for a given numerical field will not produce an error – for instance, if the address/data buses are 16-bits wide, and you wish to enter the value 0005 into address 0017, it is sufficient to say:

w 17 5 [enter]

The leading zeros are assumed by the command parser.  Similarly, if too many digits are used, only the appropriate number of digits (the right hand ones) are used.  For instance, consider the command:

w 5434540017 66677560005 [enter]

This would have the same effect as the first example, because only the four digits on the right side are used (0017 and 0005 respectively).

backspace is allowed, and the cursor will move inside the rs232 terminal to indicate that a character has been “deleted” from the command line, even if the character itself still shows up on the terminal screen.

The maximum number of characters that can be entered on the command line is determined by the size of the command buffer (a parameter setting.)  When that length is reached, if the [enter] key has not yet been pressed, a ‘?’ message will be returned, indicating a parsing error.

3.1 Parsing errors

The different responses which can be generated from rs232_syscon are listed here:

ResponseMeaningOKThe command was parsed and executed without error?Line length exceededA?Address field parsing errorD?Data field parsing errorQ?Quantity field parsing error!“err_i” or else watchdog timeout before “ack_i”B!Watchdog timeout before bus grant
The watchdog timer is used twice during the execution of a command.  The first time it is used to determine if there was a timeout for obtaining the bus, and the second time it is used to determine if the bus cycle timed out, with no “ack_i” response.  Therefore, a slow master together with a slow peripheral could conceivably use almost twice the time period of the watchdog timer, in order to complete the execution of the command.


3.2 Initial power up

The initial power up of rs232_syscon produces the following stream of characters which are sent to the terminal:

0123456789ABCDEF
-> [cursor]

This initial stream of characters can be used to verify that your terminal is set to the correct BAUD rate.

Also, no activity is generated to reset the peripherals on the bus upon initial power up.  Therefore, in order to reset the peripherals on the bus, an explicit “i” command must be issued.  Resetting the rs232_syscon unit will return all quantities to zero, but it will not generate the “rst_o” signal which is generated by the “i” command.


3.3 Actual session logfile

Here is the text from part of a debugging session using the rs232_syscon module (none of the bus error responses are shown here):


0123456789ABCDEF
-> w 1 55 1
OK
-> w 1 5a
OK
-> w 4 4c
OK
-> w 2 140
OK
-> w 3 100
OK
-> w 4 5c
OK
-> w 4 6c
OK
-> w 2 150
OK
-> w 3 f8
OK
-> w 3 f0
OK
-> w 3 f8
OK
-> w 3 f7
OK
-> w 3 48
OK
-> r 3
0003 : 0048 OK
-> r 0 8
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
OK
-> r 0 10
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
0008 : 0000 005A 0150 0048 006C 0000 0000 0000
OK
-> r 0 20
0000 : 0000 005A 0150 0048 006C 0000 0000 0000
0008 : 0000 005A 0150 0048 006C 0000 0000 0000
0010 : FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF
0018 : FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF
OK
-> w 3 58
OK
-> w 3 68
OK
-> r 0 10
0000 : 0000 0068 0068 0068 0068 0068 0068 0068
0008 : 0000 0068 0068 0068 0068 0068 0068 0068
OK
-> w 3 58 1
OK
-> w 4 68 1
OK
-> r 0 10
0000 : 0000 0068 0068 0058 0068 0068 0068 0068
0008 : 0000 0068 0068 0058 0068 0068 0068 0068
OK
-> w 4 6c 1
OK
-> w 4 7c 1
OK
-> w 1 f4 1
OK
-> r 0 8
0000 : 0000 00F4 0068 0058 007C 0068 0068 0068
OK


4.0 BAUD rate generators

The BAUD rate used in rs232_syscon is determined by a in internal signal called “serial_clk_16x.”  This signal is not actually implemented on a clock net.  Instead, it is a clock enable.  Using a clock enable for this slow signal is perfectly acceptable in most cases, and it has the advantage that it does not use an additional dedicated clock resource on the target FPGA.

As indicated by the name, the signal occurs at 16 times the desired BAUD clock rate.  For 115,200 BAUD it is a high pulse which occurs for one single “clk_i” clock period, at a rate of 16*115200 = 1.8432 MHz.

This clock enable pulse is derived from a higher frequency clock on your board, by a small DDS (Direct Digital Synthesizer.)  It sounds more complicated than it is.  This DDS does not produce a sine-wave output, it merely produces a single pulse at the desired rate.  You can use different modules from “serial.v” in order to do this.  The “clock_gen_select” allows you to use a lookup table of DDS phase increment values (which are directly related to the output frequency) so that the BAUD rate can be changed easily between common values.

On the other hand, you could choose to use the “clk_gen” module from serial.v in order to generate a single, fixed BAUD clock.

You will almost certainly need to re-calculate the DDS “frequency” inputs for use with your board, since you will undoubtedly be using some clock other than the 49.152 MHz which I chose to use.

However, the nature of the DDS circuit is such that you can most likely find a way to make it work without having to change your system clock frequency.  Almost anything can be made to work.  Some frequency error is tolerable in the BAUD clocks, and by making the DDS bigger then more and more resolution is obtained until it works for your frequency...  Detailed instructions are given in “serial.v” on how to recalculate new values for use in your application.  Or you can simply get a different clock!
rs232_syscon             

                        rs232_syscon



                           rs232_syscon  






(.ABmnvw…ŽЎу    %
&
&
норјљћ
'\fюяєържЬРЬРОВжВжВжЬРЈž’žВ†Ј†Ј|vqvqbжj5CJKHOJQJUOJQJOJQJo(5CJKHOJQJ5CJ KHOJQJo(5CJKHOJQJo(5CJKHOJQJ5CJ KHOJQJ5CJKHOJQJo(o(5CJ KHOJQJo(5CJ KHOJQJ5CJKHOJQJ5CJ,KHOJQJ5CJHKHOJQJ5CJHKHOJQJo("()*+,-.Q`jklmnwхцђ  љххххххххххххаахШЦШШШШШ$H$7$8$$H$4$7$8$$d$%d$&d$'d$$H$7$8$$d$%d$&d$'d$H$7$8$()*+,-.Q`jklmnwхцђ HIM    N     &
норјљћ
'\fюяєържЬРЬРОВжВжВжЬРЈž’žВ†Ј†Ј|vqvqbжj5CJKHOJQJUOJQJOJQJo(5CJKHOJQJ5CJ KHOJQJo(5CJKHOJQJo(5CJKHOJQJ5CJ KHOJQJ5CJKHOJQJo(o(5CJ KHOJQJo(5CJ KHOJQJ5CJKHOJQJ5CJ,KHOJQJ5CJHKHOJQJ5CJHKHOJQJo("()*+,-.Q`jklmnwхцђ  љххххххххххххаахШЦШШШШШ$H$7$8$$H$4$7$8$$d$%d$&d$'d$$H$7$8$$d$%d$&d$'d$H$7$8$()*+,-.Q`jklmnwхцђ HIM    N     &
'
'
N
N
O
O
w
w
›
›
Ц
Ц
Ч
Ч
оњћ
mnэю
оњћ
mnэю
%ќљіѓ№эъчфсолиевЯЩСЙЖГА­ЊЅ ›–‘Ž‹ˆ…‚WѕџџXѕџџYѕџџdѕџџ€ѕџџѕџџјџџјџџ`јџџaјџџsјџџtјџџјџџЇљџџЈљџџгљџџ  
%ќљіѓ№эъчфсолиевЯЩСЙЖГА­ЊЅ ›–‘Ž‹ˆ…‚WѕџџXѕџџYѕџџdѕџџ€ѕџџѕџџјџџјџџ`јџџaјџџsјџџtјџџјџџЇљџџЈљџџгљџџ  
їљџџ   
їљџџ   


њџџ         њџџGњџџHњџџ ћџџ!ћџџ%§џџ&§џџUўџџVўџџeўџџgўџџ|ўџџˆўџџ‰ўџџїџџџ3    HIM    N     &
њџџ         њџџGњџџHњџџ ћџџ!ћџџ%§џџ&§џџUўџџVўџџeўџџgўџџ|ўџџˆўџџ‰ўџџїџџџ3    HIM    N     &
'
'
N
N
O
O
w
w
›
›
Ц
Ц
Ч
Ч
оњћ
mnэю
оњћ
mnэю
їїїїїїїэээтттїїїкїииииикк$H$7$8$$
їїїїїїїэээтттїїїкїииииикк$H$7$8$$
&FH$7$8$       $„аH$7$8$$H$7$8$    
&FH$7$8$       $„аH$7$8$$H$7$8$    
D•–ЦЧњћVWгдEFƒ„СТѕ/M`“%Ў%**j*{*7-L- /К/P0
D•–ЦЧњћVWгдEFƒ„СТѕ/M`“%Ў%**j*{*7-L- /К/P0
4434и;ф;ђ;ѓ;ў;эовЦМВЈВЈВЈВЈВЈВЈВЈВЈВЈВЈВМВМžМВМžМžМВМžМžМ–МВМ‰‚
5>*CJTo(
5>*CJHo(
4434и;ф;ђ;ѓ;ў;эовЦМВЈВЈВЈВЈВЈВЈВЈВЈВЈВЈВМВМžМВМžМžМВМžМžМ–МВМ‰‚
5>*CJTo(
5>*CJHo(
5>*CJHOJQJhnH       5CJKHOJQJ5CJKHOJQJ5CJ KHOJQJ5CJKHOJQJ5CJKHOJQJo(5CJKHOJQJo(j5CJKHOJQJU#jE'"?
5>*CJHOJQJhnH       5CJKHOJQJ5CJKHOJQJ5CJ KHOJQJ5CJKHOJQJ5CJKHOJQJo(5CJKHOJQJo(j5CJKHOJQJU#jE'"?
CJKHPJUVmHnH3%&|}$%4:CDRW•–ЄЉЦЧељљљљљљљёёљљщщщЮHщщщЮФщщщЮащ$$–lжж
CJKHPJUVmHnH3%&|}$%4:CDRW•–ЄЉЦЧељљљљљљљёёљљщщщЮHщщщЮФщщщЮащ$$–lжж
ђўN:!H$7$8$$„аH$7$8$H$7$8$%&|}$%4:CDRW•–ЄЉЦЧекњћVWgmЈ­гдќљіѓ№эъчтнидЯЪХСМЗВЎЉЄŸ›–‘Œˆƒ~yupkfb›щџџ    
ђўN:!H$7$8$$„аH$7$8$H$7$8$%&|}$%4:CDRW•–ЄЉЦЧекњћVWgmЈ­гдќљіѓ№эъчтнидЯЪХСМЗВЎЉЄŸ›–‘Œˆƒ~yupkfb›щџџ    
Сщџџ   
Сщџџ   
Цщџџ   
Цщџџ   
ощџџпщџџ   
ощџџпщџџ   
ъџџ   
ъџџ   
ъџџ   
ъџџ   
ъџџъџџ   
ъџџъџџ   
Wъџџ   
Wъџџ   
`ъџџ   
`ъџџ   
sъџџtъџџ   
sъџџtъџџ   
”ъџџ   
”ъџџ   
™ъџџ   
™ъџџ   
ЇъџџЈъџџ   
ЇъџџЈъџџ   
Хъџџ   
Хъџџ   
Ъъџџ   
Ъъџџ   
иъџџйъџџ   
иъџџйъџџ   
ыџџ   
ыџџ   
ыџџ   
ыџџ   
*ыџџ+ыџџ   
*ыџџ+ыџџ   
4ыџџ   
4ыџџ   
:ыџџ   
:ыџџ   
IыџџJыџџ`ыџџbыџџcыџџёэџџђэџџHёџџIёџџ$екњћVWgmЈ­гды№$EF]bїїмpїїїмфїїїмїїїмјїїїмаїїїмјїї$$–lжж
IыџџJыџџ`ыџџbыџџcыџџёэџџђэџџHёџџIёџџ$екњћVWgmЈ­гды№$EF]bїїмpїїїмфїїїмїїїмјїїїмаїїїмјїї$$–lжж
ђўN:!H$7$8$$ды№$EF]bƒ„› СТУФєѕ!&/068DEMOhiuwњѕ№ьчтнйдЯЪЦСМЗГА­ЊЇЄЁœ—’Ž‰„{vqlhc^        
ђўN:!H$7$8$$ды№$EF]bƒ„› СТУФєѕ!&/068DEMOhiuwњѕ№ьчтнйдЯЪЦСМЗГА­ЊЇЄЁœ—’Ž‰„{vqlhc^        
љцџџ   
љцџџ   
чџџчџџ   
чџџчџџ   
чџџ   
чџџ   
!чџџ   
!чџџ   
)чџџ*чџџ   
)чџџ*чџџ   
6чџџ   
6чџџ   
8чџџ   
8чџџ   
>чџџ?чџџ   
>чџџ?чџџ   
Hчџџ   
Hчџџ   
Mчџџ   
Mчџџ   
RчџџSчџџyчџџzчџџЊшџџЋшџџЌшџџ­шџџ       
RчџџSчџџyчџџzчџџЊшџџЋшџџЌшџџ­шџџ       
Юшџџ   
Юшџџ   
гшџџ   
гшџџ   
ъшџџышџџ   
ъшџџышџџ   
щџџ   
щџџ   
щџџ   
щџџ   
(щџџ)щџџ   
(щџџ)щџџ   
Jщџџ   
Jщџџ   
Oщџџ   
Oщџџ   
\щџџ]щџџ   
\щџџ]щџџ   
~щџџ   
~щџџ   
ƒщџџ   
ƒщџџ   
šщџџ$bƒ„› СТУФєѕ!&/068DEMїмјїїїмжжжжжжїїїЛTїїїЛї$$–lжж
šщџџ$bƒ„› СТУФєѕ!&/068DEMїмјїїїмжжжжжжїїїЛTїїїЛї$$–lжж
”џЪх H$7$8$$$–lжж
”џЪх H$7$8$$$–lжж
ђўN:!H$7$8$$MOhiuw’“™›КЛСУмнщы        /068їїмЈїїїм їїїмˆїїїмАїїїмœїїїм|її$$–lжж
ђўN:!H$7$8$$MOhiuw’“™›КЛСУмнщы        /068їїмЈїїїм їїїмˆїїїмАїїїмœїїїм|її$$–lжж
”џЪх H$7$8$$w’“™›КЛСУмнщы    /068NO[]{|‚„›œЂЄлмњіёьчуойдаЫЦСНИГЎЊЅ ›—’ˆ„zuqlgb^“хџџ     
”џЪх H$7$8$$w’“™›КЛСУмнщы    /068NO[]{|‚„›œЂЄлмњіёьчуойдаЫЦСНИГЎЊЅ ›—’ˆ„zuqlgb^“хџџ     
Ъхџџ   
Ъхџџ   
Ьхџџ   
Ьхџџ   
вхџџгхџџ   
вхџџгхџџ   
ъхџџ   
ъхџџ   
ьхџџ   
ьхџџ   
ђхџџѓхџџ   
ђхџџѓхџџ   
цџџ   
цџџ   
цџџ   
цџџ   
цџџ цџџ   
цџџ цџџ   
6цџџ   
6цџџ   
8цџџ   
8цџџ   
>цџџ?цџџ   
>цџџ?цџџ   
Tцџџ   
Tцџџ   
^цџџ   
^цџџ   
eцџџfцџџ   
eцџџfцџџ   
ƒцџџ   
ƒцџџ   
…цџџ   
…цџџ   
‘цџџ’цџџ   
‘цџџ’цџџ   
Ћцџџ   
Ћцџџ   
­цџџ   
­цџџ   
ГцџџДцџџ   
ГцџџДцџџ   
гцџџ   
гцџџ   
ецџџ   
ецџџ   
лцџџмцџџ   
лцџџмцџџ   
їцџџ"8NO[]{|‚„›œЂЄлмтьјљў*,JїмДїїїм€їїїмїїїмtїїїм”їїїмДїїї$$–lжж
їцџџ"8NO[]{|‚„›œЂЄлмтьјљў*,JїмДїїїм€їїїмїїїмtїїїм”їїїмДїїї$$–lжж
”џЪх H$7$8$$мтьјљў*,JKLM`a4!5!Ћ!Ќ!Ы!ф!њ!ћ!ќ#§#:%;%‘%’%“%Ў%Џ%‹&Œ&›&œ&e'f'‡'ˆ'(њѕ№ьчтнйдЯЪЦУРНКЗДБЎЋЈЅЂŸœ™–“Š‡„~{xurolцмџџчмџџнџџ        нџџвнџџгнџџтнџџунџџПоџџРоџџлоџџмоџџноџџ3пџџ4пџџqрџџrрџџsтџџtтџџŠтџџЃтџџТтџџУтџџ9уџџ:уџџ
хџџхџџ!хџџ"хџџ#хџџ$хџџ 
”џЪх H$7$8$$мтьјљў*,JKLM`a4!5!Ћ!Ќ!Ы!ф!њ!ћ!ќ#§#:%;%‘%’%“%Ў%Џ%‹&Œ&›&œ&e'f'‡'ˆ'(њѕ№ьчтнйдЯЪЦУРНКЗДБЎЋЈЅЂŸœ™–“Š‡„~{xurolцмџџчмџџнџџ        нџџвнџџгнџџтнџџунџџПоџџРоџџлоџџмоџџноџџ3пџџ4пџџqрџџrрџџsтџџtтџџŠтџџЃтџџТтџџУтџџ9уџџ:уџџ
хџџхџџ!хџџ"хџџ#хџџ$хџџ 
Bхџџ   
Bхџџ   
Dхџџ   
Dхџџ   
PхџџQхџџ   
PхџџQхџџ   
nхџџ   
nхџџ   
pхџџ   
pхџџ   
uхџџvхџџ   
uхџџvхџџ   
‚хџџ   
‚хџџ   
Œхџџ   
Œхџџ   
’хџџ*JKLM`a4!5!Ћ!Ќ!Ы!ф!њ!ћ!ќ#§#:%;%‘%’%“%Ў%Џ%‹&Œ&›&фооооооооооооооооооооооооH$7$8$$$–lжж
’хџџ*JKLM`a4!5!Ћ!Ќ!Ы!ф!њ!ћ!ќ#§#:%;%‘%’%“%Ў%Џ%‹&Œ&›&фооооооооооооооооооооооооH$7$8$$$–lжж
”џЪх ›&œ&e'f'‡'ˆ'((щ(ъ(****i*j*s*{*|**Б*В*Д*Щ*Ъ*љљљљљљљљљљљљљљљёёзиЮёз`Юёз€        $H$7$8$$$$–lжж”џф H$7$8$$H$7$8$((щ(ъ(****i*j*s*{*|**Б*В*Д*Щ*Ъ*Э*щ*ъ*э*++
”џЪх ›&œ&e'f'‡'ˆ'((щ(ъ(****i*j*s*{*|**Б*В*Д*Щ*Ъ*љљљљљљљљљљљљљљљёёзиЮёз`Юёз€        $H$7$8$$$$–lжж”џф H$7$8$$H$7$8$((щ(ъ(****i*j*s*{*|**Б*В*Д*Щ*Ъ*Э*щ*ъ*э*++
+'+(+*+Z+[+^+€++‚+5-6-7-L-ќљіѓ№эъчфпкжбЬШУОКЕАЌЇЂž™”‹†‚}xtqnkhe7зџџ8зџџ9зџџьиџџэиџџюиџџ     
+'+(+*+Z+[+^+€++‚+5-6-7-L-ќљіѓ№эъчфпкжбЬШУОКЕАЌЇЂž™”‹†‚}xtqnkhe7зџџ8зџџ9зџџьиџџэиџџюиџџ     
йџџ   
йџџ   
йџџйџџ   
йџџйџџ   
Dйџџ   
Dйџџ   
FйџџGйџџ   
FйџџGйџџ   
dйџџ   
dйџџ   
gйџџhйџџ   
gйџџhйџџ   
йџџ   
йџџ   
„йџџ…йџџ   
„йџџ…йџџ   
Ёйџџ   
Ёйџџ   
ЄйџџЅйџџ   
ЄйџџЅйџџ   
Кйџџ   
Кйџџ   
МйџџНйџџ   
МйџџНйџџ   
яйџџ   
яйџџ   
ђйџџѓйџџ   
ђйџџѓйџџ   
ћйџџ   
ћйџџ   
кџџкџџWкџџXкџџkкџџmкџџ„лџџ…лџџYмџџZмџџ&Ъ*Э*щ*ъ*э*++
кџџкџџWкџџXкџџkкџџmкџџ„лџџ…лџџYмџџZмџџ&Ъ*Э*щ*ъ*э*++
+'+(+*+Z+[+^+€++‚+5-6-7-L-M-О-П-а-іюдtіюд„іюдЬію䘳юдЮЮЮЮЮЮЮЮЮH$7$8$$$–lжж”џф H$7$8$$ $H$7$8$$L-M-О-П-а-м-н-I.J.ž/Ÿ/ /Л/М/>0?0P0a0Г0Ў2
+'+(+*+Z+[+^+€++‚+5-6-7-L-M-О-П-а-іюдtіюд„іюдЬію䘳юдЮЮЮЮЮЮЮЮЮH$7$8$$$–lжж”џф H$7$8$$ $H$7$8$$L-M-О-П-а-м-н-I.J.ž/Ÿ/ /Л/М/>0?0P0a0Г0Ў2
4443444Њ5Ћ5|6}6›8œ899о9п9и;й;л;ф;ѓ;<<<<C<D<E<F<G<H<I<ќљіѓ№эъчфсолййййжййййгбЮбгбй


TаџџЮдџџЯдџџадџџ$жџџ%жџџ‘жџџ’жџџžжџџЏжџџАжџџ!зџџ"зџџ2а-м-н-I.J.ž/Ÿ/ /Л/М/>0?0P0a0m0p0z0}0‡0Š0•0˜0Ѓ0І0А0Г0Н0Р0Ы0љљљљљљљљљљљљїїїїїїїїїїїїїїїїH$7$8$Ы0Ю0и0л0х0ш0ђ0ѕ0џ01111%1.1]1`1j1™1Ш1Ы1е1232b2‘2”2ž2Ё2Ћ2§§§§§§§§§§§§§§§§§§§§§§§§§§§§§Ћ2Ў2И2ч233%3(34373A3p3Ÿ3Ђ3Ў3Б3Н3Р3Ь3Я3и34
4443444Њ5Ћ5|6}6›8œ899о9п9и;й;л;ф;ѓ;<<<<C<D<E<F<G<H<I<ќљіѓ№эъчфсолййййжййййгбЮбгбй


TаџџЮдџџЯдџџадџџ$жџџ%жџџ‘жџџ’жџџžжџџЏжџџАжџџ!зџџ"зџџ2а-м-н-I.J.ž/Ÿ/ /Л/М/>0?0P0a0m0p0z0}0‡0Š0•0˜0Ѓ0І0А0Г0Н0Р0Ы0љљљљљљљљљљљљїїїїїїїїїїїїїїїїH$7$8$Ы0Ю0и0л0х0ш0ђ0ѕ0џ01111%1.1]1`1j1™1Ш1Ы1е1232b2‘2”2ž2Ё2Ћ2§§§§§§§§§§§§§§§§§§§§§§§§§§§§§Ћ2Ў2И2ч233%3(34373A3p3Ÿ3Ђ3Ў3Б3Н3Р3Ь3Я3и34
4443444Њ5Ћ5§§§§§§§§§§§§§§§§§§§§§§їїїїїїH$7$8$Ћ5|6}6›8œ899о9п9и;ђ;ѓ;<<<<C<D<E<F<G<H<I<љљљљљљљљљієёєьєёєєєєєљ&d$$H$7$8$ў;<<<<'<3<4<7<@<C<H<I<њѓэцњцпйпЯ5CJKHOJQJ
4443444Њ5Ћ5§§§§§§§§§§§§§§§§§§§§§§їїїїїїH$7$8$Ћ5|6}6›8œ899о9п9и;ђ;ѓ;<<<<C<D<E<F<G<H<I<љљљљљљљљљієёєьєёєєєєєљ&d$$H$7$8$ў;<<<<'<3<4<7<@<C<H<I<њѓэцњцпйпЯ5CJKHOJQJ
5>*CJH
5>*CJHo(
5>*CJTo(
5>*CJH
5>*CJHo(
5>*CJTo(
5>*CJ8
5>*CJ8o(
5>*CJ8
5>*CJ8o(
5>*CJT.
5>*CJT.
00&P P/R Аƒ. АШA!А"А# $ %АpDd{Dot№BВ
00&P P/R Аƒ. АШA!А"А# $ %АpDd{Dot№BВ
№
№
S№A?Пџ№€2№к^dtiСXОп
S№A?Пџ№€2№к^dtiСXОп
FЫљ(4џЖDу`!№Ў^dtiСXОп
FЫљ(4џЖDу`!№Ў^dtiСXОп
FЫљ(4 ^    ђиТ7c#|ўxœЕVQh[UўЯ9џЙЗIƒыF‰sKKW73f7m•‰Ук†U6aЮбLХ'MkKг[ю-Д        ‚+QДDиУі Џ
FЫљ(4 ^    ђиТ7c#|ўxœЕVQh[UўЯ9џЙЗIƒыF‰sKKW73f7m•‰Ук†U6aЮбLХ'MkKг[ю-Д        ‚+QДDиУі Џ
>)Ў+ЎC™‚И!Ј{*ŠuOт:ъЮЭmnвtЩЭц
‡ѓчЫ9џљОџœѓх2ˆc&@мъiЅі€Б	кa•дп_Аь“їР3#iлrЌW&;дwIx3W3Tс7ф‰PŒЂ›МLщK§+=<™s&3YЕ„З@_Œяen&Ю(7г'Ћn‚wи[Žd3NЧбЬTЧ •‡фЬŸSW†џšzдЧJ™˜ЮZcчцTЌV#Y*›Щ5Ї	5Š\]\шблё<†GрГЊsQїЫОоухv Јoз9ЂxўYјлЧKE­|1эг˜к‹žАТZt€Ёђ§У–39з1a[щŒуXvњЁ:a+Ф!JQмд+Bfmѕ§ХQЎњV­^a†O}6“ЕьмAи
Is;эy}j[РuЗЈv7€ZїЂљ#  =ŒPд-ЙКзъсUЩJН’СЁЖ“NУ48ЭЃ8fЈ&аЁВ…ѕy~UlуЬѓ'аУF^\4"8j\ў–j+53ХмаЬT*щЅЅў …NSџЁ€ЪџЎ№r}†НKpHЩe–’Я	OЗЗzu§џ„LŠ”œъхпCп$l˜јП
ѓ_ЯxіуЬКГч­_kн—ЈV+„}L§fЌн‚шcё]РJ	š,EН‡
‰ЫЂ "xŽњzЋWэжЪ
n­ЙvkЗѓ˜8А.wyхЬŠ[{ѕŠдsksPКЕї{ksє~сѓьЬ№Н	иŽіЈ.эR[ЕcеыV•Лї4§`Rћˆк7ОнkЊБ{6C_У`ЛwiVŸЅоУŽbžАyќ€њ;ЙЛъьЋЛ+YАГŸ’!˜Š„М@Г€Јo”БђЭ‹ОyE4т“ГbšŸc†jГЂšOІЩ'чDž-J>Й@џ:sbд8йАЯ}o’г=Я§ГU6ПчœУbОЧk{Юот(зs6ƒђ…ЁЯsЧ}АібЛr}S9c_˜GрЌМѓпрus~–Е™g‹Ѓ\цQЭ\aІyb``№Љdњˆy 
нєЙ
ŸГ7шПчv;
gи!бЮЖеQ§ХQўъ+ьnT4'€џэЋ†
>)Ў+ЎC™‚И!Ј{*ŠuOт:ъЮЭmnвtЩЭц
‡ѓчЫ9џљОџœѓх2ˆc&@мъiЅі€Б	кa•дп_Аь“їР3#iлrЌW&;дwIx3W3Tс7ф‰PŒЂ›МLщK§+=<™s&3YЕ„З@_Œяen&Ю(7г'Ћn‚wи[Žd3NЧбЬTЧ •‡фЬŸSW†џšzдЧJ™˜ЮZcчцTЌV#Y*›Щ5Ї	5Š\]\шблё<†GрГЊsQїЫОоухv Јoз9ЂxўYјлЧKE­|1эг˜к‹žАТZt€Ёђ§У–39з1a[щŒуXvњЁ:a+Ф!JQмд+Bfmѕ§ХQЎњV­^a†O}6“ЕьмAи
Is;эy}j[РuЗЈv7€ZїЂљ#  =ŒPд-ЙКзъсUЩJН’СЁЖ“NУ48ЭЃ8fЈ&аЁВ…ѕy~UlуЬѓ'аУF^\4"8j\ў–j+53ХмаЬT*щЅЅў …NSџЁ€ЪџЎ№r}†НKpHЩe–’Я	OЗЗzu§џ„LŠ”œъхпCп$l˜јП
ѓ_ЯxіуЬКГч­_kн—ЈV+„}L§fЌн‚шcё]РJ	š,EН‡
‰ЫЂ "xŽњzЋWэжЪ
n­ЙvkЗѓ˜8А.wyхЬŠ[{ѕŠдsksPКЕї{ksє~сѓьЬ№Н	иŽіЈ.эR[ЕcеыV•Лї4§`Rћˆк7ОнkЊБ{6C_У`ЛwiVŸЅоУŽbžАyќ€њ;ЙЛъьЋЛ+YАГŸ’!˜Š„М@Г€Јo”БђЭ‹ОyE4т“ГbšŸc†jГЂšOІЩ'чDž-J>Й@џ:sbд8йАЯ}o’г=Я§ГU6ПчœУbОЧk{Юот(зs6ƒђ…ЁЯsЧ}АібЛr}S9c_˜GрЌМѓпрus~–Е™g‹Ѓ\цQЭ\aІyb``№Љdњˆy 
нєЙ
ŸГ7шПчv;
gи!бЮЖеQ§ХQўъ+ьnT4'€џэЋ†

 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSўџџџUVWXYZ[ўџџџ§џџџ^j`abcdefgўџџџўџџџ…„lmnopqrўџџџtuvwxyzўџџџ§џџџ}~€Root Entryџџџџџџџџ
 РFлЬI$С№Ѓ4›K$Сi@Data

 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSўџџџUVWXYZ[ўџџџ§џџџ^j`abcdefgўџџџўџџџ…„lmnopqrўџџџtuvwxyzўџџџ§џџџ}~€Root Entryџџџџџџџџ
 РFлЬI$С№Ѓ4›K$Сi@Data
џџџџџџџџџџџџTWordDocumentџџџџџџџџ0ІObjectPoolџџџџ`ј›K$С№Ѓ4›K$С_1059202885џџџџџџџџ        РF`ј›K$С›K$С1Tableџџџџџџџџџџџџ_CompObjџџџџhObjInfoџџџџџџџџџџџџ
џџџџџџџџџџџџTWordDocumentџџџџџџџџ0ІObjectPoolџџџџ`ј›K$С№Ѓ4›K$С_1059202885џџџџџџџџ        РF`ј›K$С›K$С1Tableџџџџџџџџџџџџ_CompObjџџџџhObjInfoџџџџџџџџџџџџ
[N@ёџNNormal$1$a$$CJKHPJ_HaJmH       nHsH tH<A@ђџЁ<Default Paragraph Font -5@FOUiџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџ -5@FOUXџџi џџџџ џџiiih№8№@ёџџџ€€€ї№Z№№ј№(        №
[N@ёџNNormal$1$a$$CJKHPJ_HaJmH       nHsH tH<A@ђџЁ<Default Paragraph Font -5@FOUiџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџ -5@FOUXџџi џџџџ џџiiih№8№@ёџџџ€€€ї№Z№№ј№(        №
№№H
№№H
№
№
#№€Š№№!
№№H
#№€Š№№!
№№H
№
№
#№€Š№№)
№№H
#№€Š№№)
№№H
№
№
#№€Š№№(
№№H
#№€Š№№(
№№H
№
№
#№€Š№№'
№№ZB
#№€Š№№'
№№ZB
№€
№€
s№*DПЫŸoабџ№№&№NB
s№*DПЫŸoабџ№№&№NB
№

№

S№DПбџ№
S№DПбџ№
№$№HB
№$№HB
№@
№@
C№DПџ№
№ №TB
C№DПџ№
№ №TB
№
№
c№$DПабџ№№&№H
c№$DПабџ№№&№H
№
№
#№€Š№№
№№ZB
#№€Š№№
№№ZB
№@
№@
s№*DПЫœ1абџ№№№NB
s№*DПЫœ1абџ№№№NB
№
№
S№DПбџ№№№ZB
S№DПбџ№№№ZB
№€
№€
s№*DПЫŸoабџ№    №№TB
s№*DПЫŸoабџ№    №№TB
№@
№@
c№$DПЫœ1бџ№№      №TB
c№$DПЫœ1бџ№№      №TB
№
№
c№$DПабџ№№№NЂ
c№$DПабџ№№№NЂ
№
№
3№€Пџ№№
№№NЂ
3№€Пџ№№
№№NЂ
№
№
3№€Пџ№№
№№NЂ
3№€Пџ№№
№№NЂ
№
№
3№€Пџ№№
№№B
3№€Пџ№№
№№B
№S№ПЫџ       ?№
№S№ПЫџ       ?№

i{gkt{
З‹gt›З    ‹     gtЫЇЫЗ   tЋ

i{gkt{
З‹gt›З    ‹     gtЫЇЫЗ   tЋ
gлзtћg›з
tы—ыgtKw;з
gлзtћg›з
tы—ыgtKw;з
tЗ       KЗ t—K—t
ыЇы—tkgkЗ   tЋ
tЗ       KЗ t—K—t
ыЇы—tkgkЗ   tЋ
З     Ћ
З     Ћ
gt
gt
GыGtыGыgtЋЗ
GыGtыGыgtЋЗ
^t‹wз
^t‹wз
t
t

$02=?EGPQQRgj

$02=?EGPQQRgj

"$02=?EGPQQRgj:џ@€ј†iА@G‡ŸTimes New Roman5€Symbol3&‡ŸArial;†‹[SOSimSun 1ˆЄhŠjX&jX&	!-!),.:;?]}ЈЗЧЩ    & 6"0000  00
00000џџџ     џџџџџџ=џ@џ\џ]џ^џрџ([{З  0

"$02=?EGPQQRgj:џ@€ј†iА@G‡ŸTimes New Roman5€Symbol3&‡ŸArial;†‹[SOSimSun 1ˆЄhŠjX&jX&	!-!),.:;?]}ЈЗЧЩ    & 6"0000  00
00000џџџ     џџџџџџ=џ@џ\џ]џ^џрџ([{З  0
000000џџ;џ[џсџхџѕI#Дœ‚€eџџssyMotorola PCўџџџўџџџ
000000џџ;џ[џсџхџѕI#Дœ‚€eџџssyMotorola PCўџџџўџџџ
ўџџџ
ўџџџўџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџўџ
ўџџџ
ўџџџўџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџўџ
џџџџ РFMicrosoft Word Picture
џџџџ РFMicrosoft Word Picture
MSWordDocWord.Picture.8є9Вqўџр…ŸђљOhЋ‘+'Гй0œ˜ Ьиф№ќ        $0
MSWordDocWord.Picture.8є9Вqўџр…ŸђљOhЋ‘+'Гй0œ˜ Ьиф№ќ        $0
LXd
p|„Œ”ф!nnARM Architecture SpecificationrosnARssysysyNormal.dottObjectPool
LXd
p|„Œ”ф!nnARM Architecture SpecificationrosnARssysysyNormal.dottObjectPool
џџџџ›K$С›K$СWordDocumentџџџџџџџџџџџџkSummaryInformation(     џџџџsDocumentSummaryInformation8џџџџџџџџџџџџ|ьЅСq       RПibjbjt+t+   2AAVџџџџџџ]ММММ88888D8жђ\\\\\›$Ш
єМFСџС›ММ\\Ѓ\›››ФМю\\›*ММММ››››Њ^›\P"‡$С88Хж›
“Host” processor

rs232_syscon

peripherals

memory

registers

DATA

ADDRESS

DATA



iєjCJUmHnH#$12>?FGQRWX`afghiњїѕїѕїѕѕѕѕѕѕѕѕѕѕѕѕњ$$„ќџ 
џџџџ›K$С›K$СWordDocumentџџџџџџџџџџџџkSummaryInformation(     џџџџsDocumentSummaryInformation8џџџџџџџџџџџџ|ьЅСq       RПibjbjt+t+   2AAVџџџџџџ]ММММ88888D8жђ\\\\\›$Ш
єМFСџС›ММ\\Ѓ\›››ФМю\\›*ММММ››››Њ^›\P"‡$С88Хж›
“Host” processor

rs232_syscon

peripherals

memory

registers

DATA

ADDRESS

DATA



iєjCJUmHnH#$12>?FGQRWX`afghiњїѕїѕїѕѕѕѕѕѕѕѕѕѕѕѕњ$$„ќџ 

#$12>?FGQRWX`abefghўўўўўўўўўўўўўўўўўўўўўўў%0182PАЫN АРN!Аѕ"А[#I#$3%ААSАрЉўџр…ŸђљOhЋ‘+'Гй0h˜ЄАМШдш ќ

#$12>?FGQRWX`abefghўўўўўўўўўўўўўўўўўўўўўўў%0182PАЫN АРN!Аѕ"А[#I#$3%ААSАрЉўџр…ŸђљOhЋ‘+'Гй0h˜ЄАМШдш ќ
$0
<HPX`фssssysysyNormal.dotMotorola PC2toMicrosoft Word 8.0@Œ†G@dбШ$С@ТЁ{$С	‚ƒўџџџўџџџ†ўџџџˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ЁЂўџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџўџеЭеœ.“—+,љЎDеЭеœ.“—+,љЎ4№hp„Œ”œЄЌДМ
Фбф	Motorola-1Title˜ 6>
$0
<HPX`фssssysysyNormal.dotMotorola PC2toMicrosoft Word 8.0@Œ†G@dбШ$С@ТЁ{$С	‚ƒўџџџўџџџ†ўџџџˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ЁЂўџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџџўџеЭеœ.“—+,љЎDеЭеœ.“—+,љЎ4№hp„Œ”œЄЌДМ
Фбф	Motorola-1Title˜ 6>
_PID_GUIDфAN{4B0122E4-900B-11D5-A35B-00B0D0428383}1Tableџџџџ‡x6SummaryInformation(џџџџЬDocumentSummaryInformation8џџџџџџџџџџџџьCompObjџџџџџџџџџџџџjMotorola PC18oMicrosoft Word 8.0S@T"Ч@Р3ЯУР@xE$С@вŠK$С.ўџеЭеœ.“—+,љЎDеЭеœ.“—+,љЎThp„Œ”œЄЌДМ
Фёф     MotorolahbŒ81!nnARM Architecture SpecificationTitle˜ 6>
_PID_GUIDфAN{4B0122E4-900B-11D5-A35B-00B0D0428383}1Tableџџџџ‡x6SummaryInformation(џџџџЬDocumentSummaryInformation8џџџџџџџџџџџџьCompObjџџџџџџџџџџџџjMotorola PC18oMicrosoft Word 8.0S@T"Ч@Р3ЯУР@xE$С@вŠK$С.ўџеЭеœ.“—+,љЎDеЭеœ.“—+,љЎThp„Œ”œЄЌДМ
Фёф     MotorolahbŒ81!nnARM Architecture SpecificationTitle˜ 6>
_PID_GUIDфAN{E3AC8D01-877B-11D5-A35A-00B0D0428383}ўџ
_PID_GUIDфAN{E3AC8D01-877B-11D5-A35A-00B0D0428383}ўџ
џџџџ РFMicrosoft Word Document
џџџџ РFMicrosoft Word Document
MSWordDocWord.Document.8є9Вq
MSWordDocWord.Document.8є9Вq
[J@ёџJNormal$1$a$ CJKH_HaJmH   nHsH tHV@V       Heading 1$$7$8$@&H$a$5CJKHOJQJ\aJ P@P	Heading 2$7$8$@&H$5CJKHOJQJ\^JP@P	Heading 3$7$8$@&H$5CJ KHOJQJ\^JP@P	Heading 4$7$8$@&H$5CJKHOJQJ\^JV@V	Heading 5$$7$8$@&H$a$5CJKHOJQJ\^JR@R	Heading 6$$7$8$@&H$a$5KHOJQJ\^JX@X	Heading 7$$7$8$@&H$a$5B*CJKHOJQJphџZ@Z	Heading 8$„а7$8$@&H$`„а5B*CJKHOJQJphџ<A@ђџЁ<Default Paragraph FontN@ђNHeader'$
Ц9r &dG$PЦџa$CJaJ< @<Footer$
Ц9r G$a$CJaJLB@L	Body Text$7$8$H$a$5CJKHOJQJ\NP@"NBody Text 27$8$H$5CJKHOJQJ\^JF"@FCaption7$8$H$5CJ KHOJQJ\^JdC@BdBody Text Indent„h7$8$H$`„h5CJKHOJQJ\^JaJ <L@<Date„dVDФ	^„d5CJ KHOJQJVQ@bVBody Text 3$7$8$H$a$5B*CJKHOJQJphџfR@rfBody Text Indent 2„а7$8$H$`„а5B*CJKHOJQJphџ^S@‚^Body Text Indent 3„а7$8$H$`„а5CJKHOJQJI8џџџџџџџџџџџџџџI8ІџџџџACloў;I<;?R	еbM8J›&Ъ*а-Ы0Ћ2Ћ5I<<>@BDEGIJLNOPQ%дwм(L-I<=ACFHKMю
[J@ёџJNormal$1$a$ CJKH_HaJmH   nHsH tHV@V       Heading 1$$7$8$@&H$a$5CJKHOJQJ\aJ P@P	Heading 2$7$8$@&H$5CJKHOJQJ\^JP@P	Heading 3$7$8$@&H$5CJ KHOJQJ\^JP@P	Heading 4$7$8$@&H$5CJKHOJQJ\^JV@V	Heading 5$$7$8$@&H$a$5CJKHOJQJ\^JR@R	Heading 6$$7$8$@&H$a$5KHOJQJ\^JX@X	Heading 7$$7$8$@&H$a$5B*CJKHOJQJphџZ@Z	Heading 8$„а7$8$@&H$`„а5B*CJKHOJQJphџ<A@ђџЁ<Default Paragraph FontN@ђNHeader'$
Ц9r &dG$PЦџa$CJaJ< @<Footer$
Ц9r G$a$CJaJLB@L	Body Text$7$8$H$a$5CJKHOJQJ\NP@"NBody Text 27$8$H$5CJKHOJQJ\^JF"@FCaption7$8$H$5CJ KHOJQJ\^JdC@BdBody Text Indent„h7$8$H$`„h5CJKHOJQJ\^JaJ <L@<Date„dVDФ	^„d5CJ KHOJQJVQ@bVBody Text 3$7$8$H$a$5B*CJKHOJQJphџfR@rfBody Text Indent 2„а7$8$H$`„а5B*CJKHOJQJphџ^S@‚^Body Text Indent 3„а7$8$H$`„а5CJKHOJQJI8џџџџџџџџџџџџџџI8ІџџџџACloў;I<;?R	еbM8J›&Ъ*а-Ы0Ћ2Ћ5I<<>@BDEGIJLNOPQ%дwм(L-I<=ACFHKMю
I8:”џ•€№t№ №,b№$Лб†ƒц
‘ќ
I8:”џ•€№t№ №,b№$Лб†ƒц
‘ќ
tъ…ƒ†џўџџџџ@ёџџџ€€€ї№’ №№0№(     №
tъ…ƒ†џўџџџџ@ёџџџ€€€ї№’ №№0№(     №
№№B
№№B
№S№ПЫџ       ?№№H№№0№(        №
№S№ПЫџ       ?№№H№№0№(        №
№I8џџ_1052893757_1052893776_1052893903_1052893907_1052893949_1052893966_1052894399_1052894432_1052894475_1052894823_1058166206_1059201963J8@@@@@@@@@ @
№I8џџ_1052893757_1052893776_1052893903_1052893907_1052893949_1052893966_1052894399_1052894432_1052894475_1052894823_1058166206_1059201963J8@@@@@@@@@ @
@@J8,<,>,>,
@@J8,<,>,>,
0000…0з7и7ф7888848@8D8E8E8G8J8,<,>,>,
0000…0з7и7ф7888848@8D8E8E8G8J8,<,>,>,
0000…0з7и7ф7888848@8D8E8E8G8J8џџMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docfs3ЖІзџџџџџџџџџљ`
ЄаеџџџџџџџџџeЛjЅFџџџџџџџџџ=Рвџџџџџџџџџ—М0Ъџџџџџџџџџ1 џЋEb"Јj.šџџџџџџџџџбA2BSЖрџџџџџџџџџR||2†и/џџџџџџџџџе<к4ЖІзџџџџџџџџџЈh/6h*‚џџџџџџџџџCзE
0000…0з7и7ф7888848@8D8E8E8G8J8џџMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docMotorola PC-C:\TEMP\AutoRecovery save of rs232_syscon.asdMotorola PC,D:\JOHN\xilinx\rs232_syscon\rs232_syscon.docfs3ЖІзџџџџџџџџџљ`
ЄаеџџџџџџџџџeЛjЅFџџџџџџџџџ=Рвџџџџџџџџџ—М0Ъџџџџџџџџџ1 џЋEb"Јj.šџџџџџџџџџбA2BSЖрџџџџџџџџџR||2†и/џџџџџџџџџе<к4ЖІзџџџџџџџџџЈh/6h*‚џџџџџџџџџCзE
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.