Senior Fitness - Exercise and Nutrition for Aging Men and Women
FREE Article Feed for your website.
Home Ownership Magazine
Party Planning Information
Article Marketing Resources
Bio-Medical Research Article Database
Informative Articles on Life, Love and Happiness
Tutorials on Business to Writing
Famous Quotes from Famous People
Song Lyric Information
New US Patent Information
Comprehensive List of Content by Category
Online Auctions and Shopping Related Articles
Article Search
Most Recent Articles
 

How to make recruitment agencies work for you
Category:
Business  

Get Your Buzz On
Category:
Health / Fitness  

Mizuno Golf Clubs reviewed
Category:
Sports  

Credit Counseling vs Debt Consolidation Which is right for me
Category:
Finance / Investment  

Leverage Your Time Talent to Help More People Make More Money
Category:
Marketing  

Digital Music Music has a surviving Skill
Category:
Entertainment / Television  

Secured Debt Consolidation Loan United we stand divided we fall
Category:
Finance / Investment  

The Whole Truth About Acne Home Remedies
Category:
Health / Fitness  

The Key Benefits of Hyaluronic Acid
Category:
Health / Fitness  

Do You Have A Vision For Your Online Business
Category:
Business  

Guide to online debt consolidation
Category:
Finance / Investment  

Casino income 101
Category:
Hobbies / Pastimes  

Breast Enhancement Pills Formulat natural increase size firmness...
Category:
Health / Fitness  

Breast Augmentation At A Glance
Category:
Health / Fitness  

Immigration Canada Business Immigration Is Economy Booster
Category:
Business  

How Are Your Choices Forming Patterns and Perspectives In Your L...
Category:
Self Help  

Injured Plaintiff s Win Today With No Win No Pay No Risk Lawsuit...
Category:
Finance / Investment  

Trampoline
Category:
Health / Fitness  

Home Business Obstacles Deal with Them Now
Category:
Business  

Niche Blogs and WHY They Make Such An Excellent Affiliate Market...
Category:
Business  

Why You need a Payment Processing System
Category:
Business  

Give a man six inches and he ll want a
Category:
Health / Fitness  

What does Coca Cola Clothing say to you
Category:
Home And Family  

Debt Management Plans Suggesting Ways to Survive the Quagmire of...
Category:
Finance / Investment  

Mortgage Scams Did You Fall For One
Category:
Finance / Investment  

The Benefits of Electric Adjustable Beds
Category:
Home And Family  

Whirlpool air purifiers
Category:
Business  

Be Smart and Repay Your Credit Cards Quickly
Category:
Business  

Follow Help To Advertising Internet Online
Category:
Marketing  

Web Furniture Retailers Embracing Art Yet Another Reason to Shop...
Category:
Home And Family  

It All Turned Out Okay In the End
Category:
Sports  

How to prevent your nasal allergy
Category:
Health / Fitness  

Work Part Time Or Work One Time It s Your Choice
Category:
Finance / Investment  

Medical Malpractice Law An Overview
Category:
Health / Fitness  

Choose Back Surgery As A Last Resort
Category:
Health / Fitness  

Blueprint for Success Defining Your Goals
Category:
Self Help  

The Wedding Planner
Category:
Home And Family  

Time is a Unique Resource
Category:
Business  

Trucking Safety C Is for the Cautious Driver
Category:
Business  

Simple Ways to Get Slim Drop Cellulite and Increase Breast Size ...
Category:
Health / Fitness  

Today s Personal Care Products Health and Beauty
Category:
Health / Fitness  

Timesheets in Compliance with SOX
Category:
Business  

Buying Equipment for a Home Gym What You Should Know First
Category:
Health / Fitness  

Buy s Property from Lottery for Pension Why
Category:
Finance / Investment  

4 Poker Tips the Pros Won t Tell You
Category:
Hobbies / Pastimes  

Holiday Eating Without Overeating Eat what s Yummy and Flatten Y...
Category:
Self Help  

Should You Confide in Your Friends About Your Panic Attacks
Category:
Health / Fitness  

Must Dos From Work From Home Veterans
Category:
Business  

Women gambling 101
Category:
Hobbies / Pastimes  

Out of the Box Marketing
Category:
Marketing  

Can You Really Use Articles To Build Your List
Category:
Marketing  

Perennials in the Garden
Category:
Home And Family  

Get That Dream Job
Category:
Business  

Are Genital Wart Serious
Category:
Self Help  

Popularity Of The Retro Clothes
Category:
Home And Family  

Why Should You Get A Capped Mortgage
Category:
Marketing  

Ten top tips on making money online with articles
Category:
Business  

What is the best pick from the latest mobile phones available
Category:
Entertainment / Television  

All About Mesothelioma
Category:
Health / Fitness  

Graphic Design Niches Finding A Narrow But Deep Client Base
Category:
Marketing  

Are you an emotial eater
Category:
Health / Fitness  

Choosing the Right Ladder for Your Home
Category:
Home And Family  

Who Are You SELLING To
Category:
Marketing  

The Centre Of Your Landing Page
Category:
Marketing  

Household Mold and Prevention
Category:
Home And Family  

Do I Need A Car In Florida
Category:
Travel  

The New Reciprocal Link
Category:
Marketing  

Dry Skin And Water
Category:
Health / Fitness  

8 Reasons Why You Sholud Email Me One Dollar
Category:
Finance / Investment  

Cheap loans for the borrowers fixated on low cost
Category:
Finance / Investment  

Need To Breast Enhancement Photo
Category:
Health / Fitness  

Getting started with videoblogging
Category:
Marketing  

Safelists And Why I Havent Even bothered Yet
Category:
Marketing  

Student Loan Consolidation Program Are The Benefits Worth Your E...
Category:
Finance / Investment  

Acting Smart With Your Credit Card
Category:
Finance / Investment

Data transmission device used to forward data received at a first device for a second device to the second device Number:7,133,953 from the United States Patent and Trademark Office (PTO) owispatent

Home    Author Login    Submit Article    Article Search    Add Your Link    Edit Your Link    Contact Us    Advertising    Disclaimer

   

 
Web LinkGrinder.com

Top Breaking News
     Greek, Cypriot Leaders Resume Unification Talks in Nicosia by Nathan Morley
     Indonesia Tobacco Sales Grow, Raising Health Fears
     South Korea Allows Top Defector to Travel Overseas by VOA News

Title: Data transmission device used to forward data received at a first device for a second device to the second device

Abstract: A data transmission device is used to forward data that have been received from a first device, and are intended for a second device, to the second device. The data transmission device described has a whole series of characteristics that allow the data that are to be transmitted to be transmitted very easily very quickly and which confer additional functions on the data transmission device.

Patent Number: 7,133,953 Issued on 11/07/2006 to Barrenscheen


Inventors: Barrenscheen; Jens (Munchen, DE)
Assignee: Infineon Technologies AG (Munich, DE)
Appl. No.: 10/308,396
Filed: December 3, 2002


Foreign Application Priority Data

Dec 03, 2001 [EP] 01128727

Current U.S. Class: 710/305 ; 370/475; 710/100; 710/106; 710/260; 710/268; 710/4; 711/200
Current International Class: G06F 13/14 (20060101); G06F 13/00 (20060101); G06F 13/24 (20060101); G06F 13/42 (20060101); G06F 3/00 (20060101)
Field of Search: 711/200 710/4,100,106,268,260,305 370/475


References Cited [Referenced By]

U.S. Patent Documents
4204250 May 1980 Getson et al.
4878166 October 1989 Johnson et al.
5347559 September 1994 Hawkins et al.
5530902 June 1996 McRoberts et al.
5581782 December 1996 Sarangdhar et al.
5713000 January 1998 Larson
5802392 September 1998 Epstein et al.
5897666 April 1999 Mallick et al.
5948094 September 1999 Solomon et al.
5978865 November 1999 Hansen et al.
6085259 July 2000 Rode et al.
6627477 September 2003 Hakey et al.
6732249 May 2004 Pickreign et al.
6763415 July 2004 Tischler
6772315 August 2004 Perego
6865667 March 2005 Moyer et al.
2001/0032286 October 2001 Pawlowski
Foreign Patent Documents
2 318 487 Apr., 1998 GB
WO 01/48621 Jul., 2001 WO

Other References

Luk, Chi-Keung, et al., "Memory Forwarding: Enabling Aggressive Layout Optimizations by Guaranteeing the Safety of Data Relocation," 1999, IEEE Proceedings of the 26th International Symposium on Computer Architecture, p. 88-99. cited by examiner .
Fratto, Mike, "Network Address Translation: Hiding in Plain Sight," Sep. 15, 1998, Network Computing, p. 110. cited by examiner.

Primary Examiner: Perveen; Rehana
Assistant Examiner: Zaman; Faisal
Attorney, Agent or Firm: Greenberg; Laurence A. Stemer; Werner H. Locher; Ralph E.

Claims



I claim:

1. A data transmission assembly for forwarding data received from a first device, and intended for a second device, to the second device, the first device and the second device being part of a module containing the data transmission assembly, the data transmission assembly comprising: a data transmission device connected to a first internal bus of the module; a further data transmission device connected to a second internal bus of the module; the data to be transmitted from the first device to the second device being transmitted via the first internal bus to said data transmission device, and from said data transmission device to said further data transmission device via a connection connecting said data transmission device and said further data transmission device to one another, and from said further data transmission device via the second internal bus to the second device; said data transmission device transmitting to the second device not only the data to be forwarded to the second device but also information about a place to which the data to be forwarded need to be transmitted within the second device, said data transmission device ascertaining the information about the place to which the data to be forwarded need to be transmitted within the second device from an address used to address said data transmission device when the data to be forwarded was supplied to said data transmission device; and said further data transmission device being able to become a bus master on said second internal bus, said further data transmission device forwarding the data to be forwarded via said second internal bus to the second device at its own behest.

2. The data transmission assembly according to claim 1, wherein the information about the place to which the data to be forwarded need to be transmitted within the second device contains a number of an address range and an address offset specifying a particular address within the address range.

3. The data transmission assembly according to claim 2, wherein the number used for the address range is a number associated with the address range covering the address which was used to address said data transmission device when the data to be forwarded was supplied to said data transmission device.

4. The data transmission assembly according to claim 2, wherein the address offset used is a portion of the address which was used to address said data transmission device when the data to be forwarded was supplied to said data transmission device.

5. The data transmission assembly according to claim 4, wherein the portion functioning as the address offset is an address portion specifying a particular address within the address range covering the address used to address said data transmission device when the data to be forwarded was supplied to said data transmission device.

6. The data transmission assembly of claim 1, wherein said data transmission device includes an address prediction device for predicting an address or a portion of the address to which the data to be forwarded need to be transmitted within the second device.

7. The data transmission assembly according to claim 6, wherein if a prediction made by said address prediction device is correct, said data transmission device transmits to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device.

8. The data transmission assembly according to claim 6, wherein the second device is part of a module containing said data transmission device, said data transmission device is sent not only the data to be forwarded but also information about a place to which the data to be forwarded need to be transmitted within the second device, and if the first device sends said data transmission device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device, said data transmission device ascertains the place using a result of a prediction from said address prediction device.

9. The data transmission assembly of claim 1, wherein said data transmission device checks whether it is possible to assume that the second device is able to ascertain the place to which the data to be forwarded need to be transmitted within the second device when the second device is sent no information or less information about the place in question, and, if this is the case, said data transmission device transmits to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device.

10. The data transmission assembly according to claim 9, wherein said data transmission device contains an address prediction device for predicting an address or a portion of the address to which the data to be forwarded need to be transmitted within the second device.

11. The data transmission assembly according to claim 10, wherein at least the first device is part of a module containing said data transmission device, and, if a prediction made by said address prediction device is correct, said data transmission device transmits to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device.

12. The data transmission assembly according to claim 10, wherein the second device is part of a module containing said data transmission device, and, if the first device sends said data transmission device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device, said data transmission device ascertaining the place using a result of a prediction from said address prediction device.

13. The data transmission assembly of claim 1, wherein, if the first device sends said data transmission device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device, said data transmission device ascertains the place using the information which is available in said data transmission device.

14. The data transmission assembly according to claim 13, wherein said data transmission device contains an address prediction device for predicting an address or a portion of the address to which the data to be forwarded need to be transmitted within the second device.

15. The data transmission assembly according to claim 14, wherein at least the first device is part of a module containing said data transmission device, and, if a prediction made by said address prediction device is correct, said data transmission device transmit; to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device.

16. The data transmission assembly according to claim 14, wherein the second device is part of a module containing said data transmission device, and, if the first device sends said data transmission device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device, said data transmission device ascertains the place using a result of a prediction from said address prediction device.

17. The data transmission assembly of claim 1, wherein said data transmission device produces an interrupt request signal when prompted by one of the first device and the second device.

18. The data transmission assembly according to claim 17, wherein said data transmission device can be prompted to produce the interrupt request signal by the data supplied to said data transmission device from one of the first device and the second device.

19. The data transmission assembly according to claim 18, wherein said data transmission device does not forward the data which prompted said data transmission device to produce the interrupt request signal.

20. The data transmission assembly according to claim 17, wherein said data transmission device can be prompted to produce various interrupt request signals prompting execution of different interrupt service routines.

21. A data transmission assembly for forwarding data received from a first device, and intended for a second device, to the second device, the first device being part of a module containing the data transmission assembly, the data transmission assembly comprising: a data transmission device transmitting to the second device not only the data to be forwarded to the second device but also information about a place to which the data to be forwarded need to be transmitted within the second device, the information about the place to which the data to be forwarded need to be transmitted within the second device containing a number of an address range and an address offset specifying a particular address within the address range.

22. The data transmission assembly according to claim 21, wherein before forwarding the data to the second device, said data transmission device transmits information about the address range to the second device.

23. The data transmission assembly according to claim 22, wherein the information about the address range associated with the number of the address range contains an address from which it is possible to ascertain a position of the address range which is to be allocated.

24. The data transmission assembly according to claim 23, wherein the address is a start address of the address range which is to be allocated.

25. The data transmission assembly according to claim 22, wherein said data transmission device transmits information about the address range which is to be allocated to the number of the address range to the second device only if an association needs to be changed.

26. The data transmission assembly according to claim 22, wherein for every number of the address range, said data transmission device transmits information about the address range that is to be allocated to the number of the address range to the second device.

27. The data transmission assembly of claim 21, wherein the second device is part of a module containing said data transmission assembly, said data transmission device is able to become a bus master on a bus connecting said data transmission device and the second device to one another, and said data transmission device forwards the data to be forwarded via said bus to the second device at its own behest.

28. The data transmission assembly according to claim 27, wherein the first device forms part of a further module.

29. The data transmission assembly according to claim 27, wherein said data transmission device is an interface for the module containing said data transmission device, and said interface is used by the module to transmit the data to another module, said interface can be used by the another module to transmit further data to the module containing said data transmission device.

30. The data transmission assembly according to claim 28, wherein the module containing said data transmission device is a program-controlled unit.

31. The data transmission assembly according to claim 28, wherein the further module is a program-controlled unit.

32. The data transmission assembly according to claim 28, wherein said data transmission device is one of two data transmission devices, and the module and the further module each contains one of said data transmission devices, the data to be transmitted from the first device to the second device are transmitted using said data transmission device in the further module containing the first device and using said data transmission device in the module.

33. The data transmission assembly according to claim 32, wherein said data transmission device in the module and said data transmission device in the further module are identical in at least one of operation and design.

34. The data transmission assembly according to claim 32, wherein said data transmission device in the module and said data transmission device in the further module are identical modules.

35. The data transmission assembly according to claim 27, wherein said data transmission device, the first device and the second device are all part of the module.

36. The data transmission assembly according to claim 35, further comprising a further data transmission device forming part of the module, said data transmission device is connected to a first internal bus of the module, and said further data transmission device is connected to a second internal bus of the module, and the data to be transmitted from the first device to the second device are transmitted via the first internal bus to said data transmission device, and from said data transmission device to said further data transmission device via a connection connecting said data transmission device and said further data transmission device to one another, and from said further data transmission device via the second internal bus to the second device.

37. The data transmission assembly according to claim 35, further comprising a further data transmission device disposed on the module, said data transmission device is connected to a first internal bus of the module, and said further data transmission device is connected to a second internal bus of the module, and the data to be transmitted from the second device to the first device are transmitted via the second internal bus to said further data transmission device, from there to said data transmission device via a connection connecting said further data transmission device and said data transmission device to one another, and from said data transmission device via the first internal bus to the first device.

38. The data transmission assembly according to claim 36, wherein said data transmission device and said further data transmission device are data transmission devices of at least one of identical design and operation.

39. The data transmission assembly according to claim 37, wherein said data transmission device and said further data transmission device are data transmission devices of at least one of identical design and operation.

40. The data transmission assembly according to claim 35, wherein the module is a program-controlled unit.
Description



BACKGROUND OF THE INVENTION

Field of the Invention

The present invention relates to a data transmission device used to forward data that have been received from a first device, and are intended for a second device, to the second device.

Such a data transmission device is, by way of example, a serial or parallel interface in a program-controlled unit, such as a microprocessor, microcontroller or signal processor.

Such an interface can output data supplied to it by one of the other components of the program-controlled unit to another module and/or can receive data that are output by another module and are intended for the program-controlled unit, and can prompt forwarding of the data within the program-controlled unit.

The other module can likewise be a program-controlled unit or can be any other module, such as a memory module.

A configuration in which two program-controlled units can interchange data with one another via interfaces is known in the art. Such a configuration contains a first microcontroller and a second microcontroller.

The first microcontroller contains a CPU, peripheral units, a memory and an interface, with the components being connected to one another by an internal bus.

The second microcontroller contains a CPU, peripheral units, a memory and an interface, with the components being connected to one another by an internal bus.

The interface in the first microcontroller and the interface in the second microcontroller are connected to one another by a connection that contains one or more lines.

If the interfaces are parallel interfaces, addresses, data and control signals can be transmitted between the interfaces simultaneously and therefore very quickly. On the other hand, a very large number of pins need to be provided for the interfaces, however, as a result of which the program-controlled units become very large.

If the interfaces are serial interfaces, they require fewer pins. On the other hand, the addresses, data and control signals need to be transmitted serially, however, as a result of which a great deal of time is required for data transmission.

In both cases, i.e. both with serial interfaces and with parallel interfaces, the transmission of data involves severe loading of the CPUs in the program-controlled units. The CPU in the program-controlled unit outputting data needs to access the interface repeatedly in order to supply the interface with the addresses, data and control signals which it needs to output. The CPU in the program-controlled unit receiving data needs to access the interface repeatedly in order to fetch the addresses, data and control signals received from the interface and to forward the data to their destination within the program-controlled unit.

SUMMARY OF THE INVENTION

It is accordingly an object of the invention to provide a data transmission device that overcomes the above-mentioned disadvantages of the prior art devices of this general type, in which it is possible to transmit data that are to be transmitted between various modules quickly with little complexity.

With the foregoing and other objects in view there is provided, in accordance with the invention, a data transmission assembly for forwarding data received from a first device, and intended for a second device, to the second device. The first device is part of a module containing the data transmission assembly. The data transmission assembly contains a data transmission device transmitting to the second device not only the data to be forwarded to the second device but also information about a place to which the data to be forwarded need to be transmitted within the second device. The data transmission device ascertains the information about the place to which the data to be forwarded need to be transmitted within the second device from an address used to address the data transmission device when the data to be forwarded were supplied to the data transmission device.

The data transmission device makes it possible to transmit data that are to be transmitted between a first device and a second device quickly and with little complexity.

In accordance with an added feature of the invention, the information about the place to which the data to be forwarded need to be transmitted within the second device contains a number of an address range and an address offset specifying a particular address within the address range. The number used for the address range is a number associated with the address range covering the address which was used to address the data transmission device when the data to be forwarded were supplied to the data transmission device. The address offset used is a portion of the address that was used to address the data transmission device when the data to be forwarded were supplied to the data transmission device. The portion functioning as the address offset is an address portion specifying a particular address within the address range covering the address used to address the data transmission device when the data to be forwarded were supplied to the data transmission device.

In accordance with an additional feature of the invention, before forwarding the data to the second device, the data transmission device transmits information about the address range to the second device. The information about the address range associated with the number of the address range contains an address from which it is possible to ascertain a position of the address range that is to be allocated.

In accordance with a further feature of the invention, the address is a start address of the address range that is to be allocated.

In accordance with another feature of the invention, the data transmission device transmits information about the address range that is to be allocated to the number of the address range to the second device only if an association needs to be changed. For every number of the address range, the data transmission device transmits information about the address range that is to be allocated to the number of the address range to the second device.

With the foregoing and other objects in view there is provided, in accordance with the invention, a data transmission assembly for forwarding data received from a first device, and intended for a second device, to the second device. The data transmission assembly contains a data transmission device having an address prediction device for predicting an address or a portion of the address to which the data to be forwarded need to be transmitted within the second device. The first device is part of a module containing the data transmission device, and the data transmission device transmits to the second device not only the data to be forwarded to the second device but also information about a place to which the data to be forwarded need to be transmitted within the second device, and if a prediction made by the address prediction device is correct, the data transmission device transmits to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device.

In accordance with an added feature of the invention, the second device is part of a module containing the data transmission device. The data transmission device is sent not only the data to be forwarded but also information about a place to which the data to be forwarded need to be transmitted within the second device, and if the first device sends the data transmission device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device, the data transmission device ascertains the place using a result of a prediction from the address prediction device.

In accordance with an additional feature of the invention, the data transmission device transmits to the second device not only the data to be forwarded to the second device but also information about a place to which the data to be forwarded need to be transmitted within the second device. The data transmission device checks whether it is possible to assume that the second device is able to ascertain the place to which the data to be forwarded need to be transmitted within the second device when the second device is sent no information or less information about the place in question, and, if this is the case, the data transmission device transmitting to the second device no information or less information about the place to which the data to be forwarded need to be transmitted within the second device. The data transmission device contains an address prediction device for predicting an address or a portion of the address to which the data to be forwarded need to be transmitted within the second device.

In accordance with another feature of the invention, the data transmission device produces an interrupt request signal when prompted by the first device or the second device. The data transmission device can be prompted to produce the interrupt request signal by the data supplied to the data transmission device from the first device or the second device. The data transmission device does not forward the data that prompted the data transmission device to produce the interrupt request signal. The data transmission device can be prompted to produce various interrupt request signals prompting execution of different interrupt service routines.

Other features which are considered as characteristic for the invention are set forth in the appended claims.

Although the invention is illustrated and described herein as embodied in a data transmission device, it is nevertheless not intended to be limited to the details shown, since various modifications and structural changes may be made therein without departing from the spirit of the invention and within the scope and range of equivalents of the claims.

The construction and method of operation of the invention, however, together with additional objects and advantages thereof will be best understood from the following description of specific embodiments when read in connection with the accompanying drawings.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram of a configuration having two modules each having a data transmission device that can be used to transmit data between the modules;

FIG. 2 is a block diagram showing a configuration and connection of the data transmission devices in the configuration shown in FIG. 1;

FIG. 3 is a timing diagram showing signals transmitted between the data transmission devices;

FIG. 4 is a block diagram showing a configuration having three modules each having a data transmission device that can be used to transmit data between the modules;

FIG. 5 illustrates a structure of a message that is transmitted between two data transmission devices;

FIG. 6 illustrates a structure of a base address transmission message;

FIG. 7 illustrates a structure of a write access message;

FIG. 8 illustrates a structure of a read access message;

FIG. 9 illustrates a structure of a special write access message;

FIG. 10 illustrates a structure of a special read access message;

FIG. 11 illustrates a structure of a response message;

FIG. 12 illustrates a structure of a command message; and

FIG. 13 is a block diagram of a configuration of a module that contains two of the data transmission devices described in order to transmit data which are to be transferred within the module in question.

DESCRIPTION OF THE PREFERRED EMBODIMENTS

Referring now to the figures of the drawing in detail and first, particularly, to FIG. 1 thereof, there is shown a configuration in which two program-controlled units can interchange data with one another via interfaces provided in them.

The configuration shown in FIG. 1 contains a first microcontroller .mu.Cx and a second microcontroller .mu.Cy.

The first microcontroller .mu.Cx contains a CPU CPUx, peripheral units PERx0 to PERx4, a memory MEMx and an interface IFx, with the components being connected to one another by an internal bus BUSx.

The second microcontroller .mu.Cy contains a CPU CPUy, peripheral units PERy0 to PERy4, a memory MEMy and an interface IFy, with the components being connected to one another by an internal bus BUSy.

The interface IFx in the first microcontroller .mu.Cx and the interface IFy in the second microcontroller .mu.Cy are connected to one another by a connection V that contains one or more lines.

If the interfaces IFx and IFy are parallel interfaces, addresses, data and control signals can be transmitted between the interfaces simultaneously and therefore very quickly. On the other hand, a very large number of pins need to be provided for the interfaces IFx and IFy, however, as a result of which the program-controlled units .mu.Cx and .mu.Cy become very large.

If the interfaces IFx and IFy are serial interfaces, they require very many fewer pins. On the other hand, the addresses, data and control signals need to be transmitted serially, however, as a result of which a great deal of time is required for data transmission.

In both cases, i.e. both with serial interfaces and with parallel interfaces, the transmission of data involves severe loading of the CPUs in the program-controlled units. The CPU in the program-controlled unit outputting data needs to access the interface repeatedly in order to supply the interface with the addresses, data and control signals which it needs to output. The CPU in the program-controlled unit receiving data needs to access the interface repeatedly in order to fetch the addresses, data and control signals received from said interface and to forward the data to their destination within the program-controlled unit.

Turning now to the invention and an example under consideration, the data transmission device described is an interface in a module which can be used to transmit data to another module and which can be used to receive data output by another module.

The module of which the data transmission device described is part is a microcontroller in the example under consideration. However, the module could also be another program-controlled unit, such as a microprocessor or a signal processor, or any other module, such as a memory chip.

The configuration used to describe the operation of the data transmission device presented here is the configuration which is shown in FIG. 1, i.e. a configuration containing the two microcontrollers, but the interfaces IFx and IFy in these microcontrollers are each formed by a data transmission device described in more detail below.

Before the particulars of the configuration and manner of operation of the interfaces IFx and IFy are described in more detail, the operation of the interfaces IFx and IFy will first be described in a general form.

When one of the components in the microcontroller .mu.Cx needs to transmit data to one of the components in the microcontroller .mu.Cy, it transmits the data via the internal bus BUSx to the interface IFx, which converts the data received into a particular format and transmits them to the interface IFy via the connection V. The interface IFy receives the data, ascertains their destination within the microcontroller .mu.Cy and finally transmits the data to their destination via the bus BUSy.

A similar situation applies when one of the components in the microcontroller .mu.Cy needs to transmit data to one of the components in the microcontroller .mu.Cx. In this case, the component in question in the microcontroller .mu.Cy transmits the data to be transmitted via the internal bus BUSy to the interface IFy, which converts the data received into a particular format and transmits them to the interface IFx via the connection V. The interface IFx receives the data, ascertains their destination within the microcontroller .mu.Cx and finally transmits the data to their destination via the bus BUSx.

While the interface IFy is transmitting the data received via the connection V to their destination within the microcontroller .mu.Cy via the bus BUSy, it is the bus master on the bus BUSy; while the interface IFx is transmitting the data received via the connection V to their destination within the microcontroller .mu.Cx via the bus BUSx, it is the bus master on the bus BUSx.

The fact that the interfaces IFx and IFy can become bus masters on the buses BUSx and BUSy is one of the special features of the interfaces described IFx and IFy. This characteristic allows data to be transmitted from the interface to their destination within the microcontroller that contains the interface by the interface itself, i.e. without the assistance of the CPU. The fact that data transmission requires no CPU results in that the interfaces described can also be used to transmit data to modules that have no CPU.

In addition, the interface under consideration in the present case has a whole series of other special features or characteristics.

In the rest of the explanations, for the sake of simplicity, it is always assumed that data are transmitted from the microcontroller .mu.Cx to the microcontroller .mu.Cy; the statements made in this regard apply accordingly to the opposite data transmission direction, however. It is also assumed that the CPU CPUx is the component in the microcontroller .mu.Cx that needs to transmit data to the microcontroller .mu.Cy. The transmission of data to the microcontroller .mu.Cy can also be prompted by any other component in the microcontroller .mu.Cx, however; for this, the statements below apply accordingly.

One of the aforementioned other characteristics of the interface presented here, to be more precise a special feature of the interface presented here which is referred to below as the second characteristic, is that the component in the microcontroller which wants to transmit data to the other microcontroller--that is to say the CPU CPUx in the microcontroller .mu.Cx in the example under consideration--supplies the interface IFx only with the data which are to be transmitted, and particularly not with the address which represents the destination for the data within the microcontroller .mu.Cy. The address can be ascertained by the interface IFx itself, specifically from the address which the CPUx uses to address it when transmitting to it the data which are to be forwarded.

The address which the CPU CPUx uses to address the interface IFx when transmitting to it the data which are to be forwarded is referred to below as the address used for interface addressing; the address representing the destination for the data to be forwarded within the microcontroller .mu.Cy is referred to below as the data target address.

The addresses that can be used for interface addressing, to be more precise the address range covering the addresses, is divided into a plurality of (4 in the example under consideration) subranges. The subranges are referred to below as pipes. The pipe covering the address used for interface addressing can be used by the interface IFx to ascertain a first portion of the data target address. The data target address portion, referred to below as the base address, represents the m most significant bits of the data target address in the example under consideration. m is a variable in the example under consideration and is stipulated by the CPU CPUx. The respective base address to be used is ascertained using an association that is known to the interface IFx and which provides each pipe with a particular associated base address.

In the example under consideration, which pipe has which associated base address is stipulated by the CPU CPUx and is communicated to the interface IFx by the latter. The association can be altered, preferably even dynamically, i.e. can be altered while the microcontroller .mu.Cx is operating. Therefore, the CPU CPUx can allocate a different base address to any pipe at any time.

To avoid misunderstandings, it will be pointed out that the address range associated with a pipe and the base address associated with the pipe in question can be stipulated entirely independently of one another.

The base address to be used can be ascertained by the interface IFx extremely easily. The interface IFx merely needs to ascertain which pipe contains the address used for interface addressing, and then to use the association that is known to it to ascertain the base address associated with this pipe.

The remaining portion of the data target address, which is referred to below as the address offset, to be more precise the portion of the data target address which contains the n less significant bits of the data target address, can be ascertained from the position of the address used for interface addressing within the pipe which covers it. In the example under consideration, n is variable and is stipulated by the CPU CPUx. A simple, but not the only, way of ascertaining the address offset is to ascertain it by subtracting a reference address situated within the pipe in question from the address used for interface addressing. The reference address chosen can be, by way of example, the start address of the pipe that covers the address used for interface addressing.

To obtain the full data target address, it is merely necessary to assemble (line up) the base address and the address offset in the correct order. This provides a very simple way for the interface IFx to ascertain the data target address itself. There is therefore no need for the CPU CPUx to transmit the address to the interface IFx in a separate bus cycle. Therefore, the CPUx is loaded to a lesser degree when transmitting data to the microcontroller .mu.Cy than is the case to date.

The data target address ascertained by the interface IFx can be transmitted to the microcontroller .mu.Cx by the interface IFx together with the data which are to be forwarded to the microcontroller .mu.Cy, with the transmission being able to be effected in any manner, that is to say either serially or in parallel, or as described below.

A third characteristic of the interface presented here is that the interface IFx does not transmit the full data target address to the microcontroller .mu.Cy with the data which are to be forwarded to the microcontroller .mu.Cy, but rather only a pipe number and the address offset, the pipe number being the number of the pipe which covers the address used for interface addressing.

The microcontroller .mu.Cy receiving the address information, to be more precise the interface IFy in the microcontroller, can ascertain the full data target address from the pipe number and the address offset. To do this, the interface IFy merely needs to ascertain which base address is associated with the pipe number, and then to assemble the base address and the address offset to form the address.

Which base address is associated with which pipe number is known to the microcontroller .mu.Cy because it has been notified of this by the microcontroller .mu.Cx using a base address transmission message, which will be described in more detail later; every time the CPU CPUx performs a configuration or reconfiguration which allocates a new base address to a pipe, the interface IFx automatically sends the aforementioned base address transmission message to the interface IFy, and the interface IFy takes receipt of the base address transmission message as an opportunity to allocate the base address contained in the base address transmission message to the pipe number contained in the base address transmission message, so that the interface IFy can always easily and reliably ascertain which base address it needs to use for data target address generation.

A fourth characteristic of the interface presented here is that the interface IFx can, under certain circumstances, also dispense with transmitting the address offset to the microcontroller .mu.Cy.

This is so because both the interface IFx and the interface IFy contain an address prediction unit which respectively attempts to predict the next data target address, or at least the portion thereof which is formed by the address offset, and because, if the address offset is predicted correctly, the interface IFy can use the address offset predicted by the address prediction unit to generate the data target address. The rules used for the address prediction are of no importance. However, what is important is that the predictions in the interfaces IFx and IFy respectively produce the same results.

In the example under consideration, it is assumed that the address prediction units predict "only" the address offset. However, the statements below apply in a corresponding manner to the situation in which the address prediction units predict the complete data target address.

If the interface IFx now establishes that the data target address, to be more precise the address offset which needs to be used to generate it, matches the address offset predicted by the address prediction unit in the interface IFx, the address offset does not need to be transmitted to the interface IFy; it is sufficient if the interface IFy receives a signal indicating that the address prediction unit has predicted the address offset correctly. In this case, the interface IFy can use the address offset predicted by its address prediction unit for the purpose of data target address generation and is not instructed by the interface IFx to transmit the address offset which is to be used.

A fifth characteristic of the interface presented here is that it has an interrupt generation device and that it can be commanded from outside the program-controlled unit containing it, to be more precise by another module or by the interface in the other module, to produce a particular interrupt request. This allows the microcontroller .mu.Cx to prompt the interface IFy in the microcontroller .mu.Cy to produce an interrupt request signal (to prompt the microcontroller .mu.Cy to execute an interrupt service routine). Preferably, the interrupt generation device can output various interrupt request signals, i.e. interrupt request signals which prompt execution of various interrupt service routines, with it being possible for the microcontroller .mu.Cx (the interface IFx of the microcontroller) to prescribe which interrupt request signal the interface containing the interrupt generation device--i.e. the interface IFy in the example under consideration--needs to output.

A sixth characteristic of the interface presented here is that the addresses which can be used to address the interface via the internal bus in the module containing it are chosen such that they fully or partially match the addresses which are used to address other components in the program-controlled unit in question via the internal bus. By way of example, it would be conceivable for the addresses that can be used to address the interface IFx via the internal bus BUSx to contain the addresses that can be used to address the memory MEMx via the internal bus BUSx. This makes it possible for data written to the memory MEMx to be automatically written to the memory MEMy too with a certain short time delay, and/or for data that are read from the memory MEMx to be automatically read from the memory MEMy too. The effect that can be achieved by this is that the content of the memory MEMy is a copy of the content of the memory MEMx. This is found to be advantageous when configuring systems with error redundancy and failsafe systems, for example.

A seventh characteristic of the interface presented here is that the interface can access only unprotected components in the microcontroller containing it. In the example under consideration, the components in the microcontroller which need to be protected against access by the interface when required have an associated protection bit or the like whose content governs whether or not the respective component is accessed by the interface. In addition or as an alternative to preventing the component in question from accessing a component protected by a protection bit, provision can be made for the component in question to output an interrupt request signal when it is accessed. The component executing the interrupt service routine, that is to say in the CPU, can then decide how such access is to be handled and/or what further measures need to be taken. The protection bits are set and reset by the CPU in the microcontroller containing the components that are to be protected. This makes it possible to prevent unauthorized access thereto from outside the microcontroller.

The interface presented here has all of the characteristics. However, it ought to be clear and requires no further explanation that the interface described would also be found to be advantageous if it had only some of the characteristics, that is to say only a single one or a particular plurality of the characteristics. The characteristics can be used either individually or else in any combination.

The configuration and manner of operation of the interfaces IFx and IFy will be described in more detail below.

The interfaces IFx and IFy are of identical construction. The basic configuration of the interfaces IFx and IFy and of the connection V connecting them to one another is shown in FIG. 2.

Accordingly, the interface IFx contains a bus interface BIFx, a transmission unit TUx, a reception unit RUx, a port control device PCTRLx, and a control device CTRLx controlling the components.

The interface IFx is connected by the bus interface BIFx to the internal bus BUSx in the microcontroller .mu.Cx and by a port control device PCTRLx to the connection V connecting the interface IFx and the interface IFy to one another.

The interface IFy contains a bus interface BIFy, a transmission unit TUy, a reception unit RUy, a port control device PCTRLy, and a control device CTRLy controlling the components.

The interface IFy is connected by the bus interface BIFy to the internal bus BUSy in the microcontroller .mu.Cy and by the port control device PCTRLy to the connection V connecting the interface IFx and the interface IFy to one another.

The transmission unit TUx outputs signals and data TCLK, TVALID and TDATA to the port control device PCTRLx and is supplied with a signal TREADY by the port control device PCTRLx. The reception unit RUx outputs a signal RREADY to the port control device PCTRLx and is supplied with signals and data RCLK, RVALID and RDATA by the port control device PCTRLx.

The transmission unit TUy outputs signals and data TCLK, TVALID and TDATA to the port control device PCTRLy and is supplied with a signal TREADY by the port control device PCTRLy. The reception unit RUy outputs a signal RREADY to the port control device PCTRLy and is supplied with signals and data RCLK, RVALID and RDATA by the port control device PCTRLy.

The connection V connecting the interface IFx and the interface IFy to one another contains a total of 8 lines, with 4 lines being used to connect the transmission unit TUx to the reception unit RUy, and 4 lines being used to connect the transmission unit TUy to the reception unit RUx.

The 4 lines used to connect the transmission unit TUx to the reception unit RUy are denoted in FIG. 2 by the reference symbols CLK_xy, READY_yx, VALID_xy and DATA_xy. The 4 lines used to connect the transmission unit TUy to the reception unit RUx are denoted in FIG. 2 by the reference symbols CLK_yx, READY_xy, VALID_yx and DATA_yx. The last two letters of the line labels, i.e. xy or yx, each indicate the source and the target of the signals and data transmitted via them; xy means that the line in question is used to transmit signals and data from .mu.Cx to .mu.Cy, and yx means that the line in question is used to transmit signals and data from .mu.Cy to .mu.Cx.

Among the Lines:

a) the line CLK_xy connects that connection of the transmission unit TUx which outputs the signal TCLK to that connection of the reception unit RUy which receives the signal RCLK;

b) the line READY_yx connects that connection of the reception unit RUy which outputs the signal RREADY to that connection of the reception unit TUx which receives the signal TREADY;

c) the line VALID_xy connects that connection of the transmission unit TUx which outputs the signal TVALID to that connection of the reception unit RUy which receives the signal RVALID;

d) the line DATA_xy connects that connection of the transmission unit TUx which outputs the data TDATA to that connection of the reception unit RUy which receives the data RDATA;

e) the line CLK_yX connects that connection of the transmission unit TUy which outputs the signal TCLK to that connection of the reception unit RUx which receives the signal RCLK;

f) the line READY_xy connects that connection of the reception unit RUx which outputs the signal RREADY to that connection of the reception unit TUy which receives the signal TREADY;

g) the line VALID_yx connects that connection of the transmission unit TUy which outputs the signal TVALID to that connection of the reception unit RUx which receives the signal RVALID; and

h) the line DATA_yx connects that connection of the transmission unit TUy which outputs the data TDATA to that connection of the reception unit RUx which receives the data RDATA.

The signals TCLK output by the transmission units TUx and TUy are clock signals for synchronizing the reception units RUy and RUx connected to the respective transmission units. Transmitting these signals also allows data to be transferred between the modules that are clocked internally using clock signals that have various frequencies and/or various phases.

The signals RREADY output by the reception units RUx and RUy are signals that signal that the reception units in question are ready to receive data.

The signals TVALID output by the transmission units TUx and TUy are signals that signal that the transmission unit in question is currently outputting data TDATA to the reception unit receiving the signal TVALID.

In addition, RREADY and TVALID can also be used as handshake signals used to coordinate and monitor transmission of the data TDATA.

The data TDATA output by the transmission units TUx and TUy contain the data that are actually to be output by the respective interfaces IFx and IFy.

FIG. 3 shows the timing of the signals TCLK, TREADY, TVALID and TDATA for the data transmission to proceed correctly.

In the example under consideration, the clock signal TCLK is output all the time, that is to say even when no data are being transmitted. However, provision could also be made for the clock signal TCLK to be output only in particular phases, for example only during the transmission of data and a particular time thereafter.

At the start of the time window shown in FIG. 3, the signals TREADY and TVALID are at the low level and no data TDATA are output.

The signal TREADY which is at the low level signals that the reception unit RU to which data need to be transmitted is not ready to receive data; the signal TVALID which is at the low level signals that currently no data TDATA are being output.

As soon as the reception unit RU is ready to receive data, the signal TREADY changes from the low level to the high level. In the example under consideration, this is the case at a time denoted by t1.

The transmission unit TU recognizes from this that it can now start to output data TDATA, provided that it has data to transmit. In the example under consideration, the transmission unit TU starts to output data TDATA at a time t2 that comes after the time t1; at the same time, the signal TVALID changes from the low level to the high level.

From the level change of TVALID occurring at the time t2, the reception unit RU recognizes that data are now being transmitted to it and reads in the data in time with the clock signal TCLK.

At a time t3 that comes a certain time after the time t2, the signal TREADY changes from the high level to the low level. As a result, the transmission unit TU receives confirmation from the reception unit RU that it is receiving the data transmitted to it.

After the time t3, the transmission unit TU can continue to transmit data TDATA for an arbitrary period. In the example under consideration, the transmission device TU continues to transmit data TDATA up to a time t4 that comes after the time t3. At the end of the transmission of TDATA, i.e. likewise at the time t4, TVALID also changes from the high level to the low level again.

The level change in TVALID signals to the reception device RU that no further data TDATA are being transmitted.

At a time t5 that comes a certain time after the time t4, TREADY changes from the low level to the high level again, which signals that the reception unit is ready to receive data again.

The signal TREADY, to be more precise a deviation in the timing of the signal TREADY from a prescribed timing (for example that shown in FIG. 3), can be used by the reception device RU to signal to the transmission device the occurrence of errors as well.

In the Example Under Consideration,

a) if the signal TREADY does not fall to the low level between the times t2 and t4, i.e. during the transmission of data TDATA, that is to say it is still at the high level at the time t4, the data which are output by the transmission unit TU have not been received or have not been accepted by the reception unit RU, and

b) if the time between the falling edge of TVALID and the rising edge of TREADY, that is to say the period between t4 and t5, is too long, a parity error has occurred during the data transmission (the reception unit RU reacts to detected parity errors by delayed output of TREADY).

It ought to be clear and requires no more detailed explanation that the timing of the signal TREADY can also signal further or other errors. In this case, the errors can also be signaled by further or other characteristics of the timing of TREADY. Invaluable characteristics of the timing of TREADY can also be, by way of example, that the time between t2 and t3 is longer or shorter than in the undisturbed normal case or that TREADY changes its level at short intervals of time (for example in time with TCLK).

In the example shown in FIG. 2, "only" two modules are connected to one another. Using the interfaces described, it is a very simple matter for more than two modules to be connected to one another as well.

If a plurality of modules need to be connected to one another, to be more precise if, by way of example, the interface needs to be able to transmit data selectively to one of n modules or needs to be able to receive data from one of n modules, it is merely necessary to provide a connection V containing additional lines, and a port control device PCTRL which can set that line of the connection V to which the input and output connections of the transmission unit TU and of the reception unit RU are connected.

FIG. 4 shows an example in which three modules, to be more precise three microcontrollers .mu.Cx, .mu.Cy and .mu.Cz, are connected to one another by their interfaces IFx, IFy and IFz.

As can be seen from FIG. 4, particular lines of the connection V are used in duplicate. By way of example, data that need to be transmitted from .mu.Cx to .mu.Cy are transmitted via the same line (DATA_x) as data that need to be transmitted from .mu.Cx to .mu.Cz. On the other hand, particular signals need to be transmitted to the various modules via various lines. This is the case with the signal TVALID, for example: TVALID which is to be output from .mu.Cx to .mu.Cy is transmitted via a different line (VALID_xy) than TVALID which is to be output from .mu.Cx to .mu.Cz (VALID_xz).

The transmission unit TU and the reception unit RU remain unchanged, however. Therefore, they have as many input and output connections as is the case for the configuration shown in FIG. 2, where only two modul


Free Web Sudoku Puzzles.
Solve with your browser.
4   9         2  
    1 3 7     8  
7     2   4      
                6
    2 6 4 3 8    
3                
      9   5     4
  2     1 6 3    
  7         9   1
What is it?



Add Your Site · Terms Of Service · Privacy Policy


DISCLAIMER
Linkgrinder is a free service that searches the Internet and indexes all files found so that you may search quickly and easily for shared files. These files are created and made available individually by users whose identity we are not aware of and who we have no control over. In essence we function like a search engine tool; these files ARE NOT STORED OR SERVED BY OUR NETWORK. We are not responsible for any materials obtained by using our service. We do not monitor any of the contents of these files. These files may contain viruses, illegal materials, materials inappropriate for minors, offensive files and the like. BY USING OUR SERVICE, YOU ASSUME FULL RESPONSIBILITY FOR DOWNLOADING THESE MATERIALS AND WILL INDEMNIFY US FOR ANY DAMAGES THAT MAY BE INCURRED.

For More Specific Information VIEW OUR TERMS OF SERVICE.

Thank you and Enjoy!