|Publication number||US6842771 B2|
|Application number||US 09/898,169|
|Publication date||Jan 11, 2005|
|Filing date||Jul 3, 2001|
|Priority date||Jul 6, 2000|
|Also published as||US20020004818, WO2002005090A1, WO2002005090A8|
|Publication number||09898169, 898169, US 6842771 B2, US 6842771B2, US-B2-6842771, US6842771 B2, US6842771B2|
|Inventors||Jari Länsiö, Lauri Piikivi|
|Original Assignee||Nokia Mobile Phones Ltd.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (13), Non-Patent Citations (3), Referenced by (6), Classifications (16), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The invention relates to a data transmission method and arrangement in which data are transmitted between a wireless system and another system. The invention particularly relates to systems in which data are transmitted between sets of software in different devices.
In the design and maintenance of telecommunications systems attention has been paid to establishment of connections between different systems and to smooth operation. Separate systems have often been implemented using quite a few different methods and various apparatuses which are incompatible. It has been difficult and time consuming to make different systems compatible, if at all possible.
For this reason several producers of devices and systems have developed a common architecture called CORBA (Common Object Request Broker Architecture), which allows computer systems of different types implemented with different programming languages to communicate with one another without difficulty. CORBA defines a GIOP protocol (General Inter-ORB protocol) which enables communication between devices of different types and programs programmed with different languages. The GIOP protocol is a common protocol of which a version called IIOP (Internet Inter-ORB Protocol) has been developed particularly for the Internet environment. Further information on CORBA can be obtained e.g. from the specification published by the OMG (Object Management Group) which created this architecture: The Common Object Request Broker: Architecture and Specification, Revision 2.0, Chapter 2: CORBA Overview. The specification is also available at the address www.omg.org.
CORBA has been developed for systems which have a fixed connection to one another via an unspecified network. When the protocol was designed, hardly any attention was paid to the possible capacity of the transmission path, but the emphasis was on the creation of a flexible and secure protocol. Since the proportion of wireless communication has increased strongly during the past few years, data systems and different software are also increasingly used in computers and devices from which the only or the main connection to other networks is a wireless network, such as the GSM, GPRS or UMTS. The data transmission capacity of wireless networks is, however, considerably smaller than that of fixed wired networks. For this reason CORBA has not been commonly applied to wireless systems. Transmission of CORBA over a wireless transmission path has proven to be very slow due to the large amount of signalling and data to be transmitted.
In wireless devices software applications have usually defined their own interfaces and connection protocol which have been directly involved in the actual data transmission. This is illustrated in FIG. 1. The figure shows three software applications 100 to 104 which run in a device employing a wireless connection. Each software application has a connection protocol 106 to 110 of its own which it uses to communicate with a transmission layer 112, which transmits data using a wireless connection. In this solution the applications need to communicate with the transmission layer, which makes development of the application difficult.
An object of the invention is to provide a method and an arrangement implementing the method to alleviate the above-mentioned problems. This is achieved with a method of implementing data transmission between at least two sets of software used in one or more devices which are able to establish a connection to a telecommunications system, the method comprising implementing at least a portion of a connection between two different devices with a wireless connection and carrying out at least part of the communication between the sets of software by method calls, each of which includes a service request, the method call being supplied to a service broker of the system, which supplies the service request included in the method call to the server indicated, which responds to the method call according to the service requested by sending the information required by the service to the service broker, which sends the information to the sender of the method call, and the method comprising defining the server that offers the service request during the communication, and at least some of the programs used in the devices and participating in data transmission being implemented with a script-based programming language.
In the method according to the invention the program used in a device employing wireless connections sends method calls to a certain application, which transmits service requests and responses to the requests between the service broker and the software that needs data transmission and renders the data transmission requests and responses to the requests compatible between script-based software and another system.
The invention also relates to an arrangement for implementing data transmission between at least two sets of software used in one or more devices which comprise means for establishing a connection to a data transmission system, where at least a portion of a connection between two different devices is implemented with a wireless connection and at least part of the communication between the devices is carried out by method calls, each of which includes a service request, the system comprising one or more service brokers which supply the service request included in the method call to the server indicated, which is arranged to respond to the method call according to the service needed by sending the information requested by the service to the service broker, which is arranged to send the information to the sender of the method call, the server that offers the service request being defined during the communication and at least some of the programs used in the devices and participating in data transmission being implemented with a script-based programming language.
The arrangement of the invention comprises an application which transmits service requests and responses to the requests between the service broker and the software requiring data transmission and renders the data transmission requests and responses to the requests compatible between script-based software and another system.
The dependent claims disclose the preferred embodiments of the invention.
The invention is based on implementing software in wireless devices which adapt the requests needed by the services used by the sets of software in the wireless devices and responses to the requests between a wireless device and another external system so that various sets of software can use the same protocol and the same messages. The wireless device comprises an application of its own which converts the request generated by the software in the wireless device into a format compatible with another system, and in the other direction a response received from the system is converted into a format understood by the software in the wireless device. The application may convert a protocol used in a fixed network, e.g. a GIOP protocol, into a format that can be transmitted better on a wireless transmission path.
The method and arrangement of the invention provide several advantages. Since the invention enables use of the same protocol in several software applications in wireless devices, the protocol not being dependent on the transmission layer and having a basic structure similar to that in a fixed network, the development of software and implementation of communication will become considerably simpler, without causing too much load on the transmission path or without rendering the connection impractically slow.
The invention will be described in greater detail by means of preferred embodiments with reference to the accompanying drawings, in which
The present invention can be applied in various radio systems where the terminals have different radio path properties. It does not matter which multiple access method the system employs. For example, the CDMA, WCDMA and TDMA can be used as the multiple access method. Furthermore, the system can support both circuit-switched and packet-switched connections.
The structure of a mobile communications system according to an embodiment of the invention used as an example will be described with reference to FIG. 2. This is only one possible alternative, which is obvious to a person skilled in the art. The main parts of the mobile communications system are a core network CN, an overground radio access network BSS and a subscriber terminal MS. The interface between the CN and the BSS is called a Gb interface in this example, and the air interface between the BSS and the MS a UM interface.
The radio access network consists of radio network subsystems RNS. Each radio network subsystem RNS consists of a radio network controller RNC and a base station B comprising one or more transceivers. The interface between the radio network controller and the base station is called a lub interface. The coverage area of the base station, i.e. a cell, is denoted by C in FIG. 1.
The illustration in
The cellular radio network typically comprises the infrastructure of a fixed network, i.e. a network part 300 and subscriber terminals 302 which can be fixed, placed in a vehicle or portable. The network part 300 comprises base stations 304. The base station corresponds to node B in the preceding figure. Several base stations 304 are controlled centrally by a radio network controller 306 which communicates with the base stations. A base station 304 comprises transceivers 308 and a multiplexer unit 312.
The base station 304 also comprises a control unit 310 which controls the function of the transceivers 308 and the multiplexer 312. The multiplexer 312 is used for arranging the traffic and control channels used by several transceivers 308 on one transmission connection 314. The transmission connection 314 constitutes the lub interface.
There is a connection from the transceivers 308 of the base station 304 to an antenna unit 318 which establishes a bi-directional radio connection 316 to the subscriber terminal 302. The structure of the frames to be transmitted on the bi-directional radio connection 316 is system-specific and called an air interface Um.
The radio network controller 306 comprises a group switching field 320 and a control unit 322. The group switching field 320 is used for switching speech and data and for connecting signalling circuits. The radio network subsystem 332 formed by the base station 304 and the radio network controller 306 also includes a transcoder 324. The transcoder 324 is usually located as close to a mobile services switching centre 328 as possible because this saves transmission capacity when speech is transmitted in the format of a cellular radio network between the transcoder 324 and the radio network controller 306.
The transcoder 324 converts the different digital speech encoding formats used between the public switched telephone network and the radio telephone network into a compatible format, e.g. from the format of the fixed network into a format of the cellular radio network, and vice versa. The control unit 322 is responsible for call controlling, mobility management, collection of statistics and signalling.
As is seen in
The connection between the packet transmission network 342 and the group switching field 320 is established by a support node 340 (SGSN =Serving GPRS Support Node). The function of the support node 340 is to transmit packets between the base station system and a gateway node (GGSN=Gateway GPRS Support Node) 344 and keep a record of the location of the subscriber terminal 302 in its area.
The gateway node 344 connects a public packet transmission network 346 and the packet transmission network 342. An Internet protocol or an X.25 protocol can be used at the interface. The gateway node 344 hides the internal structure of the packet transmission network 342 from the public packet transmission network 346 by encapsulating the structure, and thus the public packet transmission network 346 regards the packet transmission network 342 as a sub-network which comprises a subscriber terminal 302 to which the public packet transmission can send packets and receive packets from it.
The packet transmission network 342 is typically a private network which utilizes the Internet protocol and carries signalling and tunnelled user data. The structure of the network 342 may vary according to the operator in respect of its architecture and protocols below the Internet protocol layer.
The public packet transmission network 346 may be e.g. the world-wide Internet network.
Typically time slots not involved in circuit-switched transmission are used for packet transmission at the air interface 316. The capacity is reserved dynamically for packet transmission, i.e. as a data transmission request is received, any free channel can be allocated to packet transmission. The arrangement is flexible, which means that circuit-switched connections have priority over packet transmission connections. If necessary, circuit-switched transmission overrides packet-switched transmission, i.e. the time slot used by packet-switched transmission is allocated to circuit-switched transmission. This can be done because packet-switched transmission withstands such interruptions well: transmission is continued using another allocated time slot. The arrangement can also be implemented so that no absolute priority is given to circuit-switched transmission but both circuit-switched and packet-switched transmission requests are served in their order of arrival. These arrangements are not, however, relevant to the present invention.
In the following, data transmission according to the CORBA architecture will be described at a general level by means of FIG. 4.
The application 506 is preferably implemented by a library application. The library application provides the necessary functions for a script-based application for sending method calls. The functions convert outgoing method calls into a general format understood by the service broker and in the other direction the messages entering the application are converted into script calls.
The function of the application is shown in
As illustrated in
The device may also comprise user interface parts, such as a display, keyboard, earpiece and microphone. These are not shown in the figure. The control unit 814 of the device is typically implemented with a microprocessor and memory elements, including the necessary software. The control unit can be used for performing sets of software that need different services, as described above.
Even though the invention has been described with reference to the examples according to the accompanying drawings, it is clear that the invention is not limited thereto but may be modified in various ways within the inventive concept disclosed in the appended claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5754774||Feb 15, 1996||May 19, 1998||International Business Machine Corp.||Client/server communication system|
|US6032199 *||Jun 26, 1996||Feb 29, 2000||Sun Microsystems, Inc.||Transport independent invocation and servant interfaces that permit both typecode interpreted and compiled marshaling|
|US6134559 *||Apr 27, 1998||Oct 17, 2000||Oracle Corporation||Uniform object model having methods and additional features for integrating objects defined by different foreign object type systems into a single type system|
|US6282581||Mar 27, 1997||Aug 28, 2001||Hewlett-Packard Company||Mechanism for resource allocation and for dispatching incoming calls in a distributed object environment|
|US6330598 *||Jun 23, 1998||Dec 11, 2001||Ameritech Corporation||Global service management system for an advanced intelligent network|
|US6425017 *||Aug 17, 1998||Jul 23, 2002||Microsoft Corporation||Queued method invocations on distributed component applications|
|US6510550 *||May 12, 1999||Jan 21, 2003||Intel Corporation||Method and apparatus for providing intermittent connectivity support in a computer application|
|US20010034771 *||Jan 12, 2001||Oct 25, 2001||Sun Microsystems, Inc.||Network portal system and methods|
|US20040111730 *||Nov 3, 2003||Jun 10, 2004||Apte Ajay Arvind||Process and system for a client object to perform a remote method invocation of a method in a server object|
|USH1964 *||Feb 19, 1998||Jun 5, 2001||Dsc/Celcore, Inc.||Resource management sub-system of a telecommunications switching system|
|EP0767428A1||Sep 11, 1996||Apr 9, 1997||Sun Microsystems Inc.||Method and apparatus for dynamically loading method call exception code|
|EP0822492A2||Jun 30, 1997||Feb 4, 1998||Sun Microsystems, Inc.||Bridge providing communication between different implementations of object request brokers|
|FI104873A||Title not available|
|1||"Supporting CORBA Applications in a Mobile Environment", Haahr et al., MobiCom '99, 5<th >International Conference on Mobile Computing and Networking, 1999, pp. 36-47.|
|2||"The Common Object Request Broker: Architecture and Specification", Revision 2.0, Chapter 2: Corba Overview, 1995, 26 page document.|
|3||"Using WAP as the Enabling Technology for CORBA in Mobile and Wireless Environments", Ruggaber et al., IEEE 7<th >Workshop on Future Trends of Distributed Computing Systems, 1999, pp. 69-74.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7493360 *||Jun 12, 2003||Feb 17, 2009||Fujitsu Limited||Method of and computer program for client character code conversion, method of and computer program for server character code conversion, CORBA client, and CORBA server|
|US8019807 *||Apr 11, 2002||Sep 13, 2011||Wireless Enterprise Solutions Technology Limited||Method and system for communication between computer systems|
|US8117531||Sep 23, 2005||Feb 14, 2012||Google Inc.||Interpreted language translation system and method|
|US9311303||Jan 30, 2012||Apr 12, 2016||Google Inc.||Interpreted language translation system and method|
|US20030074401 *||Apr 11, 2002||Apr 17, 2003||Brian Connell||Method and system for communication between computer systems|
|US20030233484 *||Jun 12, 2003||Dec 18, 2003||Fujitsu Limited||Method of and computer program for client character code conversion, method of and computer program for server character code conversion, cobra client, and cobra server|
|U.S. Classification||709/203, 719/315, 709/217, 719/316|
|International Classification||H04L29/08, H04L29/06|
|Cooperative Classification||H04L67/2823, H04L67/2809, H04L69/08, H04L67/02, H04L67/04, H04L29/06|
|European Classification||H04L29/08N27B, H04L29/08N1, H04L29/06, H04L29/08N3|
|Jul 27, 2001||AS||Assignment|
Owner name: NOKIA MOBILE PHONES LTD., FINLAND
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LANSIO, JARI;PIIKIVI, LAURI;REEL/FRAME:012030/0437;SIGNING DATES FROM 20010608 TO 20010619
|Jul 21, 2008||REMI||Maintenance fee reminder mailed|
|Jan 11, 2009||LAPS||Lapse for failure to pay maintenance fees|
|Mar 3, 2009||FP||Expired due to failure to pay maintenance fee|
Effective date: 20090111