Estimating the location of a network client using a media access control address

Abstract
Apparatus and methods are provided for estimating the location of a network client. In one embodiment, the present invention includes the network client establishing communication with a Local Area Network (LAN), the LAN including a plurality of infrastructure nodes each having a globally unique media access control (MAC) address. The network client then estimates the location of a network client using the MAC address of at least one of the plurality of infrastructure nodes or the MAC address of the network client.
Description


COPYRIGHT NOTICE

[0001] Contained herein is material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction of the patent disclosure by any person as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all rights to the copyright whatsoever.



BACKGROUND

[0002] 1. Field


[0003] The disclosed subject matter relates to the estimation of the physical location of a network client in communication with a Local Area Network (LAN).


[0004] 2. Description of the Related Art


[0005] Currently, if a user of a network client device wishes to use a location specific feature of the network client, they would normally determine the location of the device from an exterior source, and then input that information into the device. Such an exterior source may be, for example, a device that accesses the global positioning system (GPS) or a paper map. This process often involves multiple devices and is frequently considered cumbersome and inconvenient.


[0006] It is possible to integrate a device that may access the global positioning system (GPS) with the network client. However, the addition of this GPS device is often expensive and serves only one purpose, the detection of the network client's location. In addition, GPS is primarily an outdoor positioning system and does not work well indoors, which is where network clients are frequently used. Furthermore, even if GPS is utilized, in order to derive a reliable human-scale indoor positioning, an augmentation technology should be employed. A need, therefore, exists for an improved system or technique for determining the physical location of a network client that is neither inconvenient nor expensive.







BRIEF DESCRIPTION OF THE DRAWINGS

[0007] Embodiments of the present invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:


[0008]
FIG. 1 is a block diagram illustrating an exemplary Local Area Network (LAN) environment in which various embodiments of the present invention may be employed.


[0009]
FIG. 2 is a block diagram illustrating an exemplary network client architecture in which various embodiments of the present invention may be employed.


[0010]
FIG. 3 is a flow diagram illustrating location estimation according to one embodiment of the present invention.


[0011]
FIG. 4 is a flow diagram illustrating location estimation according to a specific embodiment of the present invention.


[0012]
FIG. 5 is a flow diagram illustrating location estimation according to another specific embodiment of the present invention.


[0013]
FIG. 6 is a flow diagram illustrating location estimation according to another specific embodiment of the present invention.







DETAILED DESCRIPTION


Local Area Network Environment

[0014] One example Local Area Network (LAN) in which embodiments of the present invention can be implemented is now described with reference to FIG. 1. FIG. 1 shows the LAN 100 as including three LAN segments 102a-c. Each LAN segment is a switched LAN operating using LAN switches 106a-c respectively. The LAN segments 102 need not be switched LANs, but can use shared bandwidth protocols such as Ethernet. The switched LAN segments can use any LAN protocol, for example switched Ethernet, in which case the LAN switches 106 would be Ethernet switches. The LAN segments 102 are linked by a router 108. In one embodiment, the router 108 links the LAN to an outside network. In this case, the router 108 is also the default router for the LAN 100.


[0015] Each LAN segment 102 can be used by network clients 112a-h to access the LAN 100. Some network clients, such as network clients 112c and 112h can be desktop computers that access the LAN 100 using a wired line connection, such as a drop cable that plugs into a network drop. Network client 112f is a notebook PC, that is a laptop computer, which also accesses the LAN 100 using a wired line connection. Other network clients, such as network clients 112a, 112b, 112d, and 112g, are mobile network clients that access the LAN 100 using a wireless interface. The LAN 100 includes a number of wireless access points, such as access point 104. For example, using a wireless protocol, such as the Supplement to 802.11-1999, Wireless LAN MAC and PHY specifications: Higher speed Physical Layer (PHY) extension in the 2.4 GHz band, IEEE Std. 802.11b-1999 (hereafter “802.11b”), Bluetooth™ Special Interest Group (SIG) v1.0 Specification (hereafter “Bluetooth”), or similar protocol, mobile network client 112a can access the LAN 100 through access point 104. Each LAN segment 102 can also have a server 110a-c coupled to provide various server-related functionalities, such as serving documents, applications, web pages, and other resources. In other embodiments, one server, for example server 110a, can provide all server services to the entire LAN 100 and servers 110b and 110c can be omitted.


[0016] Several components of the LAN 100 provide access and communication between clients, servers, and other networks. These components are sometimes referred to as infrastructure nodes. In FIG. 1, for example, access point 104 and all other access points, LAN switches 106a-c, and router 108 are infrastructure nodes. The LAN 100 can include other infrastructure nodes. Furthermore, the LAN 100 can be used to connect other network peripherals, such as printers, scanners, back-up devices, and other such devices. The LAN 100 is given as only one example. Other LANs need not have multiple segments, switches, or even routers. Furthermore, not all LAN segments 102 need a server 110.



Example Network Client

[0017] An example network client 112, such as network client 112a from FIG. 1, that can use embodiments of the present invention to estimate its location is now described with reference to FIG. 2. The network client 112 illustrated in FIG. 2 is a notebook PC, which is only one possible architecture for the network client 112. The network client could also be a desktop computer, personal digital assistant (PDA), a network peripheral device such as a printer, or any other network device.


[0018] The network client 112 can have a memory controller hub 204 connecting the memory 206(A-C), the display 212, and the processor 202. In some mobile PCs architectures, the memory controller hub 204 is sometimes referred to as the Northbridge because it provides a bridge between the host processor 202 and the rest of the computer system. The processor can be a high-performance notebook central processing unit (CPU) commonly used in mobile PCs. The memory system 206(A-C) can include any storage medium used by mobile PCs. For example, memory 206A can be a static random access memory (SRAM), memory 206B can be a dynamic random access memory (DRAM), and memory 206C can be a read only memory (ROM). The display 212 can be a liquid crystal display (LCD) display or other suitable display technology. The display 212 can be connected to the memory controller hub 204 by a high-speed graphics bus 208 and graphics controller 210, such as an Accelerated Graphics Port (AGP) bus.


[0019] In one embodiment, the input/output (I/O) controller hub 214, also known in some architectures as the Southbridge, is connected to the memory controller hub 204 by a point-to-point connection 205. In other architectures, a shared bus may link them. The I/O controller hub 214 controls the operation of the mass storage 220, such as a hard drive, the CD/DVD drive 216, the Universal Serial Buses (USBs) 222, and the Peripheral Component Interconnect (PCI) bus 224. The PCI bus 224 can be used to connect a communications device 226, such as a modem and/or wireless transceiver, to the mobile PC.


[0020] Furthermore, the PCI bus 224 can be used to connect a network interface card (NIC) 228, such as an Ethernet card or an 802.11 card, to the Mobile PC. The NIC 228, can be used to access a Local Area Network, such as LAN 100 in FIG. 1 using either a wired line connection or a wireless connection. The NIC 228, for example an 802.11 card, has a unique media access control (MAC) address burned on it. If the NIC 228 is an Ethernet card, the MAC address may be called an Ethernet Address, which, like some other MAC address specifications, is a globally unique six-byte number.



Location Estimation

[0021] One embodiment of a process for estimating the location of a network client 112 is now described with reference to FIG. 3. In block 302, the network client 112 establishes a connection with the LAN 100. This connection may be a wired line connection or a wireless connection using an appropriate. LAN protocol. For example, wired line connections can use the Ethernet protocol and wireless connections can use a wireless protocol such as 802.11b. In Block 304, the network client 112 estimates its location using a MAC address. The MAC address can be the MAC address burned on the NIC 228 used by the network client 112, the MAC address of an access point 104 used by or accessible to the network client 112, the MAC address of a router 108 used by the LAN 100, such as a default router, or the MAC address of any other infrastructure node.


[0022] One specific implementation of block 304 is now described with reference to FIG. 4. In this embodiment, the network client 112 is a mobile network client accessing the LAN 100 wirelessly, such as network client 112a accessing the LAN 100 using wireless access point 104 in FIG. 1. The wireless access point 104 has a globally unique MAC address, sometimes referred to as the BSSID for 802.11b LANs, which it uses to provide access to mobile clients.


[0023] In block 402, the network client 112 accesses the MAC address of the wireless access point 104. Generally, the MAC address of the wireless access point 104 will have been communicated to the network client 112 upon the establishment of the connection. Furthermore, wireless access points also broadcast signals containing their MAC addresses. A network client can access their MAC addresses by listening for this signal.


[0024] In block 404, the network client 112 queries a database associating the MAC address of the access point 104 with the physical location of the access point 104. Such a database may be created in a number of ways and may be stored in a number of locations, such as one of the servers 10a-c, another node on the LAN 100, or at a central database outside of the LAN 100 accessible through the router 108. Such a database stores the MAC addresses of all or most of the infrastructure nodes, such as the access points, of the LAN 100. The MAC address of the access point 104 is associated by the database with a location. The location can include the coordinates of the access point 104 (i.e. latitude, longitude, altitude), and communications range of the access point 104.


[0025] In block 406, the network client 112 estimates its location using the location and range of the access point 104. In one embodiment, the network client 112 approximates its location as being somewhere in the area covered by the range of the access point 104. In other embodiments, the network client 112 can use other information to improve on this estimate.


[0026] Another specific implementation of block 304 is now described with reference to FIG. 5. In this embodiment, the network client 112 can be a mobile network client accessing the LAN 100 wirelessly, such as network client 112a accessing the LAN 100 using wireless access point 104 in FIG. 1, or the network client 112 can be a fixed or mobile network client accessing the LAN 100 using a wired line connection, such as network clients 112c and 112f in FIG. 1.


[0027] In block 502, the network client 112 accesses the MAC address of the router 108. This can be done by asking the router 108 for its MAC address, or noting the MAC address of the router 108 when establishing communication with the LAN 100. The router MAC address is freely accessible on the LAN 100 and there are various ways the network client 112 can access it.


[0028] In block 504, the network client 112 queries a database associating the MAC address of the router 108 with the physical location of the router 108. This database can be the same database described above with reference to FIG. 4, or it can be a similar database. The MAC address of the router 108 is associated by the database with a location. The location can include the coordinates of the router 108 (i.e. latitude, longitude, altitude), and an area of coverage of the router 108. The location can include other information, such as a floor (or several floors) of a building serviced by the router 108.


[0029] In block 506, the network client 112 estimates its location using the location and service area of the router 108. In one embodiment, the network client 112 approximates its location as being somewhere in the service area of the router 108. In other embodiments, the network client 112 can use other information to improve on this estimate.


[0030] Another specific implementation of block 304 is now described with reference to FIG. 6. In this embodiment, the network client 112 can be a mobile network client accessing the LAN 100 wirelessly, such as network client 112a accessing the LAN 100 using wireless access point 104 in FIG. 1, or the network client 112 can be a fixed or mobile network client accessing the LAN 100 using a wired line connection, such as network clients 112c and 112f in FIG. 1.


[0031] In block 602, the network client 112 accesses the MAC address of its NIC, such as NIC 228 in FIG. 2. Since the network client 112 has access to the NIC 228, it can retrieve this MAC address readily.


[0032] In block 604, the network client 112 queries a database associating the MAC address of the NIC 228 with a switch port of a LAN switch, such as LAN switch 106a in FIG. 1. This database is used by the LAN switch 106a to keep track of the various devices using the LAN 100 or LAN segment 102a. In one embodiment, this database is a table of switch port numbers. When a device, such as a network client 112 or a server 110, is connected to the switched LAN 100, the switch port used to connect the device is associated in the table with the MAC address of the device, i.e. the MAC address of the NIC used by the device to interface with the LAN 100.


[0033] In block 606, the network client 112 queries a database associating the switch port returned from the query in block 604, i.e. the switch port used to connect the network device 112 to the LAN switch 106a, with a location of the switch port. This database can be the same database described above with reference to FIG. 4, or it can be a similar database. The switch port number is associated by the database with a location. The location can include the coordinates of network drop connected to the switch port (i.e. latitude, longitude, altitude). The location can include other information, such as a floor of a building on which the network drop is located.


[0034] In block 606, the network client 112 estimates its location using the location of the network drop. In one embodiment, the network client 112 approximates its location as being somewhere in the near vicinity of the network drop, since the drop cable tends to be of short length. In other embodiments, the network client 112 can use other information to improve on this estimate.



General Matters

[0035] In the description above, for the purposes of explanation, numerous specific details have been set forth. However, it is understood that embodiments of the invention may be practiced without these specific details. In other instances, well-known circuits, structures and techniques have not been shown in detail in order not to obscure the understanding of this description.


[0036] Embodiments of the present invention include various processes. The processes may be performed by a unit or units such as hardware components or may be embodied in machine-executable instructions, which may be used to cause one or more processors programmed with the instructions to perform the processes. Alternatively, the processes may be performed by a combination of hardware and software. As used in herein, a unit performing a process can be one or more processors, an ASIC, a controller such as a micro-controller, or any other module capable of carrying out the process.


[0037] Embodiments of the present invention may be provided as a computer program product that may include a machine-readable medium having stored thereon instructions, which may be used to program a computer (or other electronic device) to perform a process according to one or more embodiments of the present invention. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, compact disc read-only memories (CD-ROMs), and magneto-optical disks, read-only memories (ROMs), random access memories (RAMs), erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, flash memory, or other type of media/machine-readable medium suitable for storing instructions. Moreover, embodiments of the present invention may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).


[0038] While the invention has been described in terms of several embodiments, those skilled in the art will recognize that the invention is not limited to the embodiments described, but can be practiced with modification and alteration within the spirit and scope of the appended claims. The description is thus to be regarded as illustrative instead of limiting.


Claims
  • 1. A method comprising: establishing communication with a Local Area Network (LAN), the LAN including a plurality of infrastructure nodes each having a globally unique media access control (MAC) address; and estimating the location of a network client using a MAC address of at least one of the network client and the plurality of infrastructure nodes.
  • 2. The method of claim 1, wherein the network client comprises a mobile network client, and estimating the location of the network client uses the MAC address of a wireless access point.
  • 3. The method of claim 2, wherein estimating the location of the network client comprises the mobile network client querying a database for a record associated with the MAC address of the wireless access point containing a location and a communication range of the wireless access point.
  • 4. The method of claim 2, wherein the mobile network client comprises one of a laptop computer, a notebook PC, and a personal digital assistant (PDA).
  • 5. The method of claim 1, wherein establishing communication with the LAN comprises establishing a wired line connection with the LAN.
  • 6. The method of claim 5, wherein estimating the location of the network client uses the MAC address of a router.
  • 7. The method of claim 6, wherein the router comprises a default router.
  • 8. The method of claim 6, wherein estimating the location of the network client comprises querying a database for a record associated with the MAC address of the router containing a location and a range of an area served by the router.
  • 9. The method of claim 5, wherein estimating the location of the network client comprises querying a LAN switch to identify a port associated with the (MAC) address of the network client, and querying a database for a record associated with the identified port containing a location of a network drop connected to the port.
  • 10. The method of claim 5, wherein the network client comprises one of a laptop computer, a notebook PC, a personal digital assistant (PDA), a desktop computer, and a network peripheral device.
  • 11. The method of claim 1, wherein estimating the location of the network client is performed by the network client.
  • 12. The method of claim 1, wherein the LAN comprises an Ethernet.
  • 13. A network client comprising: a network interface card (NIC) having a globally unique media access control (MAC) address to communicatively couple the network client to a Local Area Network (LAN), the LAN including a plurality of infrastructure nodes each having a globally unique media access control (MAC) address; and a unit to estimate a location of the network client using the MAC address of at least one of the NIC and the plurality of infrastructure nodes.
  • 14. The network client of claim 13, further comprising a wireless transceiver coupled to the NIC to communicate with the LAN, wherein the unit estimates the location of the network client using the MAC address of a wireless access point.
  • 15. The network client of claim 14, wherein the unit estimates the location of the network client by querying a database for a record associated with the MAC address of the wireless access point containing a location and a communication range of the wireless access point.
  • 16. The network client of claim 14, wherein the network client comprises one of a laptop computer, a notebook PC, and a personal digital assistant (PDA).
  • 17. The network client of claim 13, wherein the NIC couples to the LAN using a wired line connection.
  • 18. The network client of claim 17, wherein the unit estimates the location of the network client uses the MAC address of a router.
  • 19. The network client of claim 18, wherein the router comprises a default router.
  • 20. The network client of claim 18, wherein the unit estimates the location of the network client by querying a database for a record associated with the MAC address of the router containing a location and a range of an area served by the router.
  • 21. The network client of claim 17, wherein the unit estimates the location of the network client by querying a LAN switch to identify a port associated with the (MAC) address of the network client, and querying a database for a record associated with the identified port containing a location a network drop connected to the port.
  • 22. The network client of claim 17, wherein the network client comprises one of a laptop computer, a notebook PC, a personal digital assistant (PDA), a desktop computer, and a network peripheral device.
  • 23. The network client of claim 13, wherein the NIC comprises an Ethernet card and the LAN comprises an Ethernet.
  • 24. A machine-readable medium having stored thereon data representing instructions that, when executed by a processor of a network client, cause the processor to perform operations comprising: establishing communication with a Local Area Network (LAN), the LAN including a plurality of infrastructure nodes each having a globally unique media access control (MAC) address; and estimating the location of a network client using the MAC address of at least one of the network client and the plurality of infrastructure nodes.
  • 25. The machine-readable medium of claim 24, wherein the network client comprises a mobile network client, and estimating the location of the network client uses the MAC address of a wireless access point.
  • 26. The machine-readable medium of claim 25, wherein estimating the location of the network client comprises the mobile network client querying a database for a record associated with the MAC address of the wireless access point containing a location and a communication range of the wireless access point.
  • 27. The machine-readable medium of claim 24, wherein establishing communication with the LAN comprises establishing a wired line connection with the LAN.
  • 28. The machine-readable medium of claim 27, wherein estimating the location of the network client uses the MAC address of a router.
  • 29. The machine-readable medium of claim 28, wherein estimating the location of the network client comprises querying a database for a record associated with the MAC address of the router containing a location and a range of an area served by the router.
  • 30. The machine-readable medium of claim 29, wherein estimating the location of the network client comprises querying a LAN switch to identify a port associated with the (MAC) address of the network client, and querying a database for a record associated with the identified port containing a location of a network drop connected to the port.