1. Field
The present application relates generally to communication networks, and more particularly to computer-implemented techniques for layering virtual networks.
2. Background
The use of multiple physical network connections using multiple physical network interfaces as peripherals in a single computer is well known in the art. An advantage of such a system is that a computer user can be concurrently connected to multiple separate and discreet networks. This is particularly valuable in handling very large networks or in situations where high security is needed for each individual network but a computer user has clearance for access to more than one network at the same time.
The advent of virtual network connections has made it possible for private networks to “piggy back” on other often public networks and for the communications to be facilitated completely in software, thereby reducing costs and enabling rapid upgrade of network capability and deployment. The virtual network is accomplished by simulating with software the capabilities and function normally delivered by physical network devices.
Such virtual networks currently supply one virtual network connection at a time. In this context, it would be desirable to deliver the capabilities of a system using multiple physical network interfaces but doing so virtually as a software process.
The following presents a simplified summary of one or more embodiments in order to provide a basic understanding of such embodiments. This summary is not an extensive overview of all contemplated embodiments, and is intended to neither identify key or critical elements of all embodiments nor delineate the scope of any or all embodiments. Its sole purpose is to present some concepts of one or more embodiments in a simplified form as a prelude to the more detailed description that is presented later.
In accordance with one or more embodiments and corresponding disclosure thereof, various aspects are described in connection with methods for facilitating the establishment of multiple concurrent virtual networks. The method may be performed by a virtual network controller (VNC) or the like. For example, the method may involve establishing communication links with a plurality of virtual network interfaces (VNIs) operatively coupled to a plurality of virtual networks. The method may involve establishing a single port communication link with an operating system. The method may involve allowing the virtual networks to be transported on top of a physical network. The method may involve facilitating communication between the operating system and the virtual networks via the single port communication link.
In accordance with one or more embodiments and corresponding disclosure thereof, there is provided a system of multiple concurrent virtual networks. The system may include a plurality of virtual networks operatively coupled to a plurality of VNIs. The system may include a VNC in operative communication with the VNIs. The system may include an operating system operatively coupled with the VNC via a single port connection. The VNC may be configured to: allow the virtual networks to be transported on top of a physical network; and facilitate communication between the operating system and the virtual networks concurrently via the single port connection.
To the accomplishment of the foregoing and related ends, the one or more embodiments comprise the features hereinafter fully described and particularly pointed out in the claims. The following description and the annexed drawings set forth in detail certain illustrative aspects of the one or more embodiments. These aspects are indicative, however, of but a few of the various ways in which the principles of various embodiments may be employed and the described embodiments are intended to include all such aspects and their equivalents.
Various embodiments are now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of one or more embodiments. It may be evident, however, that such embodiment(s) can be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate describing one or more embodiments. The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any embodiment described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments. The techniques described herein may be used for various communication networks, wired or wireless. The terms “network” and “system” are often used interchangeably.
With reference to
With reference to
With reference to
The embodiment of
In view of exemplary systems shown and described herein, methodologies that may be implemented in accordance with the disclosed subject matter, will be better appreciated with reference to various flow charts. While, for purposes of simplicity of explanation, methodologies are shown and described as a series of acts/blocks, it is to be understood and appreciated that the claimed subject matter is not limited by the number or order of blocks, as some blocks may occur in different orders and/or at substantially the same time with other blocks from what is depicted and described herein. Moreover, not all illustrated blocks may be required to implement methodologies described herein. It is to be appreciated that functionality associated with blocks may be implemented by software, hardware, a combination thereof or any other suitable means (e.g., device, system, process, or component). Additionally, it should be further appreciated that methodologies disclosed throughout this specification are capable of being stored on an article of manufacture to facilitate transporting and transferring such methodologies to various devices. Those skilled in the art will understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram.
In accordance with one or more aspects of the subject of this disclosure, there are provided methods for establishing and using multiple concurrent virtual networks. With reference to
With reference to
With continued reference to
In accordance with one or more aspects of the embodiments described herein, there are provided devices and apparatuses for establishing and using multiple concurrent virtual networks, as described above with reference to
For example, the apparatus 600 of
In related aspects, the apparatus 600 may optionally include a processor component 610 having at least one processor. The processor 610, in such case, may be in operative communication with the virtual components 602-608 via a bus 612 or similar communication coupling. The processor 610 may effect initiation and scheduling of the processes or functions performed by virtual components 602-608.
In further related aspects, the apparatus 600 may include a radio transceiver component 614. A stand alone receiver and/or stand alone transmitter may be used in lieu of or in conjunction with the transceiver 614. The apparatus 600 may optionally include a component for storing information, such as, for example, a memory device/component 616. The computer readable medium or the memory component 616 may be operatively coupled to the virtual components of the apparatus 600 via a bus 612 or the like. The memory component 616 may be adapted to store computer readable instructions and data for effecting the processes and behavior of the virtual components 602-608, or the processor 610, or the methods disclosed herein. The memory component 616 may retain instructions for executing functions associated with the virtual components 602-608. While shown as being external to the processor 610, the transceiver 614, and the memory 616, it is to be understood that one or more of the virtual components 602-608 can exist within the processor 610, the transceiver 614, and/or the memory 616.
Those of skill in the art would understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Those of skill would further appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the disclosure herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The various illustrative logical blocks, modules, and circuits described in connection with the disclosure herein may be implemented or performed with a general-purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm described in connection with the disclosure herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.
In one or more exemplary designs, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a general purpose or special purpose computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code means in the form of instructions or data structures and that can be accessed by a general-purpose or special-purpose computer, or a general-purpose or special-purpose processor. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or non-transitory wireless technologies, then the coaxial cable, fiber optic cable, twisted pair, DSL, or the non-transitory wireless technologies are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
The previous description of the disclosure is provided to enable any person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the spirit or scope of the disclosure. Thus, the disclosure is not intended to be limited to the examples and designs described herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
This application claims the benefit of U.S. Provisional Application No. 61/309,875, entitled “System of Multiple Concurrent Virtual Networks,” filed Mar. 3, 2010, which is hereby expressly incorporated in its entirety by reference herein.
Number | Date | Country | |
---|---|---|---|
61309875 | Mar 2010 | US |