The present invention relates generally to data processing systems, and more particularly to processing in different contexts using a processor.
Many current computer systems use virtual memory systems to manage and allocate memory to various processes running within the system, which allow each process running on the system to operate as if it has control of the full range of addresses provided by the system. The operating system (OS) maps the virtual address space for each process to the actual physical address space for the system. Mapping from a physical address to a virtual address is typically maintained through the use of page tables.
Processor performance is improved via a multiple-stage pipeline architecture, in which various pipeline resources, such as caches, buffers, arrays, and the like may be used to more efficiently execute instructions. One such pipeline resource that improves use of virtual memory systems is a translation lookaside buffer (TLB). A TLB is a relatively small section of memory in a processor pipeline which caches part of the system's virtual address to physical address translations. Specifically, a few elements of the translation set are stored in the TLB which the processor can access extremely quickly. Various TLBs may exist in a system. For example, separate TLBs may exist for instructions and data (respectively, an instruction TLB (iTLB) and a data TLB (dTLB)). More so, in certain systems a second level dTLB (STLB) may be present.
If a translation for a particular virtual address is not present in the TLB, a “translation miss” occurs and the address translation is resolved using more general mechanisms. Processing in this manner continues until a context switch occurs. A context switch may occur when a multitasking OS stops running one process (e.g., an application) and begins running another. When a context switch occurs, page tables including a page directory and a page table for the new process are loaded, and the TLB and other pipeline resources must be flushed. By flushed, it is meant that the resources' contents are cleared.
Certain systems may implement a virtual machine (VM) environment in which a virtual machine monitor (VMM) presents to other software the abstraction of one or more virtual machines. Each VM may function as a self-contained platform, running its own “guest operating system” (i.e., an OS hosted by the VMM) and other software, collectively referred to as guest software (or simply a “guest”). The guest software expects to operate as if it were running on a dedicated computer rather than a virtual machine. Accordingly, the guest software expects to control various events and have access to hardware resources, such as processor-resident resources, resources that reside in memory and resources that reside on the underlying hardware platform.
In a virtual machine environment, the VMM generally has ultimate control over these events and hardware resources to provide proper operation of guest software and for protection from and between guest software running on different virtual machines. To achieve this, the VMM typically receives control (i.e., effects a context switch) when guest software accesses a protected resource or when other events (such as interrupts or exceptions) occur.
Context switches in a VM or other environment cause considerable overhead in modern microprocessors. This overhead is exacerbated by large second level TLBs that must be flushed and reloaded on every context switch. Thus this overhead can adversely impact performance, especially in systems with many active contexts. A need thus exists to more efficiently maintain pipeline resources on context switches.
In various embodiments of the present invention, pipeline resources or structures such as TLBs, trace caches (TC), branch prediction unit (BPU) arrays, mini-tags and the like, may support multiple address spaces. As used herein, the term “address space” means a set of addresses in memory corresponding to a given application (e.g., a context).
In various embodiments, address spaces may be controlled by a combination of architectural control registers (e.g., control register 3 which includes a page directory base register (CR3.PDBR), a page-level cache disable bit (PCD), a page-level write through bit (PWT); control register 0, which includes a paging bit (CR0.PG), a protection enable bit (CR0.PE); control register 4, which includes a page size extension bit (CR4.PSE) and a page global enable bit and a physical address extension bit (CR4.PGE and PAE), an extended feature-enable register-long mode addressing (EFER.LMA) and a no execution bit (EFER.NXE)) that determine or affect linear to physical translations.
In various embodiments, address space identifiers (ASIDs) may be used to augment linear addresses in various pipeline resources with a pointer to the context with which they are associated. As used herein, an “address space identifier” may be any number, code, or other notation which identifies one or more address spaces with which it is associated. In one embodiment, ASIDs may be implemented using a two-bit ASID (i.e., four address space contexts) per thread, although the scope of the present invention is not so limited. This allows multiple application contexts to share pipeline structures, reducing context switch overhead. For example, when a context switch occurs, the current ASID value may be changed, rather than flushing the pipeline structures. Similarly, in certain embodiments, a thread identifier (thread ID) may be provided to identify a given processor thread for a corresponding address space.
Various architectural events may cause a selective flush of the TLBs in accordance with embodiments of the present invention. These events include, for example, a move to CR3 (MOV to CR3) instruction; changing CR0 page mode bits: CR0.PE and CR0.PG and EFER.LMA; changing CR4 page mode bits; VM Entry/Exit; and a 32-bit context switch (if paging mode bits in CR0 or CR4 are changed). In certain embodiments, of these events, only a MOV to CR3 operation or a VMEntry/VMExit event may change/increment the ASID.
Many pipeline structures are linearly tagged or indexed. In various embodiments, ASIDs may augment the linear address in these pipeline resources with a pointer to the corresponding address space. In such embodiments, the microprocessor may maintain a global current ASID register that is updated when a new address space is created or when changing to a different, previously seen address space. TLB insertions may be extended with the current ASID value, and TLB lookups match only if the ASID tag matches the current ASID value. When a context switch (e.g., a MOV to CR3, or VM entry/exit) triggers an address space change, the microprocessor may switch to a different ASID value that represents the new address space, instead of flushing the TLBs and other pipeline structures. In certain embodiments, either not flushing any entries or selectively flushing some or all entries corresponding to a specific address space may provide a substantial performance gain for environments with multiple contexts.
Referring now to
In various embodiments, a TLB in accordance with an embodiment may include physical addresses (tag addresses) and associated valid, thread ID and ASID bits, along with corresponding linear and physical addresses. TLB entries include an ASID field in their tag that indicates the address space to which they correspond. That ASID field contains the value of the current ASID when that TLB entry was loaded. Since an ASID field is in the tag of TLB entries, a TLB entry is hit only if the current ASID value matches the ASID field in that TLB entry.
On an address space change (i.e., context switch), microcode may save information about the current address space/ASID (CR3, CR0 and CR4 paging bits, LMA) into a scratchpad and may compare the new address space to the stored address space information of each ASID. If no stored address space/ASID matches the new address space, then the address space has not been seen before. Thus microcode either allocates a new ASID for this address space, or chooses an existing ASID to replace with, for example, a least recently used (LRU) policy. In the latter case, microcode may flush TLB entries for the LRU ASID.
Referring now to
In the embodiment of
In one embodiment, criteria (control transfer criteria and/or fault criteria) may be defined using data stored in one or more designated fields in a virtual machine control structure (VMCS) (not shown specifically in
In one embodiment, if the transfer criteria determine that a current event must be handled by VMX monitor 50, control is transferred to VMX monitor 50. VMX monitor 50 may then handle the event and transfer control back to guest software. The transfer of control from a VMM or a VMX monitor to guest software is referred to herein as a VM entry, and the transfer of control from the guest software to the VMM or a VMX monitor the VMX monitor is referred to herein as a VM exit.
As shown in
Still referring to
A VMX monitor that controls execution of first guest software 30 and second guest software 40 may also have an ASID value associated therewith. For example, as shown in the embodiment of
As shown in
In various embodiments, VMX architectural enhancements may allow a VMX monitor to avoid flushing TLBs or other similar processor resources on context switches and VMX transitions by using ASIDs. In various embodiments, neither explicit ASID management in software nor hardware is needed to detect cross-address space pollution.
In various embodiments, upon events such as those shown in
In certain embodiments, pages within system memory 20 or other cached pages are thus protected by VMX monitor 50 across all address spaces so that any attempted storage to such pages may cause a VMX exit from guest software initiating such a store. On such an event, VMX monitor 50 may cause the address(es) corresponding to such stores to be invalidated in all TLBs and other processor resources.
In various embodiments, a processor may handle certain events, instructions and VMX transitions differently. Such different implementations of different instructions and events may be done in processor microcode. For example, on a MOV to CR3 instruction in a guest, a VM exit or a VM entry, a processor may look for an existing ASID that matches the new address space. Such a determination may be made by comparing an ASID of the new address space to a list of ASIDs maintained by the processor. If a match exists, the processor makes that ASID the current ASID without flushing any TLB entries. Otherwise, all TLB entries corresponding to, in one embodiment, the LRU ASID are flushed and the ASID value of the LRU'ed ASID is made the current ASID. The TLB entries from the previous address space may be maintained if that ASID was not flushed.
In contrast, an instruction that invalidates a TLB entry for a specified page (e.g., an INVLPG instruction) may be handled differently. For example, in one embodiment, a linear address space may be invalidated in all TLBs upon such an instruction. Still different operations may occur on other instructions. For example, in one embodiment a MOV to CR4 instruction that detects no change in the CR4 value may invalidate all TLB entries in each ASID.
Referring now to
The address space switch may correspond to a VM exit or a VM entry, or may be caused by a MOV to CR3 instruction, or another such event. Next, it may be determined whether the second address space exists in an ASID list (diamond 120). Such a list may be maintained by a processor to identify different active address spaces, locations in linear address spaces corresponding thereto, and optionally other information. For example, the ASID list may be a scratchpad memory in the processor.
If the second address space is present in the ASID list, control may pass to block 130 where the first address space may be maintained, including any entries within TLBs corresponding to the first address space. Furthermore, the second ASID may be stored in a control register of the processor (e.g., a current ASID register) (or other memory location) to indicate that the second address space (i.e., the address space found in diamond 120) is the currently executing address space within the processor (block 135).
If instead at diamond 120 it is determined that the second address space is not present in the ASID list, next it may be determined whether the ASID list is full (diamond 140). If the list is not full, control may pass to block 145 where the first address space may be maintained, including any entries within TLBs corresponding to the first address space. Furthermore, the second ASID may be stored in a control register of the processor (e.g., a current ASID register, or other memory location) to indicate that the second address space (i.e., an empty address space or the freed address space from block 160, discussed below) is the currently executing address space within the processor (block 150).
If at diamond 140 it is instead determined that the ASID list is full, entries within TLBs corresponding to a LRU entry in the ASID list may be flushed (diamond 160). Then control may pass to block 145 for further processing, as discussed above in which the second ASID may be stored in the LRU entry. Accordingly, TLB entries and other resources associated with the second ASID are enabled.
While shown in the embodiment of
In certain embodiments, depending upon a cause of an address space switch, particular entries within TLBs or other processor resources may be flushed using software. For example, as discussed above, if an attempted store to a protected page causes a VM exit, addresses within TLBs corresponding to the protected space are flushed. That is, in various implementations of a VMX architecture, a VMX monitor protects each paging hierarchy. In a virtualization environment, software may be used to flush a TLB or other resources as dictated by a guest. Then, certain events undertaken by the guest (e.g., a MOV to CR3 instruction) will not flush resources because the virtualization software handles flushing activities as described herein. Thus in the guest, if any store instruction modifies a TLB entry used by a CR3 in a CR3 target value, a VM exit occurs.
With translucent ASIDs in accordance with an embodiment of the present invention, after such a VM exit, the software may flush all TLB entries corresponding to the store instruction that caused the VM exit, even if the TLB entry was not in use by the guest at the time of the VM exit. In such an embodiment, if the software desires to flush an individual entry, the software may perform an INVLPG instruction with a linear address that corresponds to that TLB entry in the appropriate address space. On such a software-invoked INVLPG, the processor may flush any TLB entries corresponding to that linear address, regardless of their ASID. While described as being implemented using an INVLPG instruction, in other embodiments other instructions or operations may flush such entries.
Referring now to
Then, at diamond 220 it may be determined whether a store operation attempted to modify a protected entry, such as a protected TLB entry (e.g., corresponding to a different address space). If not, normal execution of the VMX monitor may continue (block 230). Such execution may take many forms, depending on program instructions. After such execution, control may return to the guest, if desired.
If instead it is determined that a store attempted to modify a protected entry, the VMX monitor may perform the store operation (block 235), as it has access to the protected location that the guest does not. Then, all TLB entries corresponding to the store address may be flushed from all TLBs and other processor resources (block 240). A VM entry may then return control to the guest for continued execution (block 245). Such execution may continue at a next instruction of the guest, for example.
In still other embodiments, it may be desirable to flush all entries within all TLBs. For example, if higher level paging mechanisms have been modified, such flushing may be desired to clear the TLBs or to remove an address space from the TLBs when a VMX monitor will no longer protect it. In one embodiment, if the software desires to flush an entire TLB for an address space, the software may perform a MOV to CR4 instruction with the exact same value already stored there. When the processor sees such a CR4 write, it may flush all TLBs for all ASIDs, since the software does not specify which ASID needs to be flushed. In various embodiments, the software may flush an entire TLB for an address space if a PDE (or higher) entry was changed or if a CR3 is being removed from the CR3 target value and the monitor will no longer protect it.
Referring now to
If instead it is determined that the new value is the same as the previous value, this may be a flag to indicate that a VMX monitor or other entity desires to flush all TLBs. As described above there may be various reasons to flush all TLBs. Accordingly, at block 280, all TLBs may be flushed for all ASIDs. Finally, execution may continue in the same (i.e., original) address space (block 290) (e.g., at a next instruction).
While described in the embodiment of
Referring now to
Memory hub 430 may also be coupled (via a hub link) to an I/O hub 435 that is coupled to an I/O expansion bus 455 and a peripheral bus 450. In various embodiments, I/O expansion bus 455 may be coupled to various I/O devices such as a keyboard and mouse, among other devices. Peripheral bus 450 may be coupled to various components such as peripheral device 470 which may be a memory device such as a flash memory, add-in card, and the like. Although the description makes reference to specific components of system 400, numerous modifications of the illustrated embodiments may be possible.
Embodiments may be implemented in a computer program that may be stored on a storage medium having instructions to program a computer system to perform the embodiments. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic and static RAMs, erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), flash memories, magnetic or optical cards, or any type of media suitable for storing electronic instructions. Other embodiments may be implemented as software modules executed by a programmable control device.
Because software is helping the processor protect and invalidate TLB entries, in various embodiments TLB entries may be maintained on context switches (e.g., MOV to CR3, VM exit, and VM entry). Thus in various embodiments, no snoopy TLB hardware is needed, avoiding snoopy TLB capacity or other limitations.
In other embodiments, translucent ASIDs may be used with any architecture containing page tables which does not explicitly assign IDs to different address spaces, but requires that the processor take a special action to flush TLB entries after modifying page tables, even if that TLB entry is not currently in use by the current address space.
Accordingly, in various embodiments, a processor may support ASIDs and avoid TLB flushes (e.g., on context switches) without either specialized hardware to detect cross-address space pollution or explicit software control and ASID allocation.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.
Number | Name | Date | Kind |
---|---|---|---|
3855456 | Summers et al. | Dec 1974 | A |
4833710 | Hirashima | May 1989 | A |
5123101 | Sindhu | Jun 1992 | A |
5319760 | Mason et al. | Jun 1994 | A |
5892944 | Fukumoto et al. | Apr 1999 | A |
5906001 | Wu et al. | May 1999 | A |
6035380 | Shelton et al. | Mar 2000 | A |
6047354 | Yoshioka et al. | Apr 2000 | A |
6075938 | Bugnion et al. | Jun 2000 | A |
6327646 | Sharma et al. | Dec 2001 | B1 |
6356989 | Hays et al. | Mar 2002 | B1 |
6418521 | Mathews et al. | Jul 2002 | B1 |
6510508 | Zuraski, Jr. et al. | Jan 2003 | B1 |
6604187 | McGrath | Aug 2003 | B1 |
6779085 | Chauvel | Aug 2004 | B2 |
6854046 | Evans et al. | Feb 2005 | B1 |
7409487 | Chen et al. | Aug 2008 | B1 |
7552254 | George et al. | Jun 2009 | B1 |
7552255 | George et al. | Jun 2009 | B1 |
20020082824 | Neiger et al. | Jun 2002 | A1 |
20030217250 | Bennett | Nov 2003 | A1 |
20040117593 | Uhlig et al. | Jun 2004 | A1 |
20040123288 | Bennett et al. | Jun 2004 | A1 |
20040162930 | Forin et al. | Aug 2004 | A1 |
20060190946 | Kissell et al. | Aug 2006 | A1 |
20070006230 | Neiger et al. | Jan 2007 | A1 |
20110238947 | Nishiguchi et al. | Sep 2011 | A1 |
20110271126 | Hill | Nov 2011 | A1 |
20110320789 | Prasky et al. | Dec 2011 | A1 |
20130173882 | Bhowmik et al. | Jul 2013 | A1 |
20140181388 | Mohandru et al. | Jun 2014 | A1 |
20150234687 | Vajapeyam, Sr. | Aug 2015 | A1 |
20160092677 | Patel et al. | Mar 2016 | A1 |
Number | Date | Country |
---|---|---|
1139489 | Jan 1997 | CN |
1489058 | Apr 2004 | CN |
1489059 | Apr 2004 | CN |
10084753 | Apr 2004 | DE |
10357804 | Jul 2004 | DE |
1296333 | Mar 2003 | EP |
S553077 | Jan 1980 | JP |
S6091462 | May 1985 | JP |
S60100245 | Jun 1985 | JP |
H0336648 | Feb 1991 | JP |
H03185539 | Aug 1991 | JP |
H04349548 | Dec 1992 | JP |
H06139149 | May 1994 | JP |
H06318179 | Nov 1994 | JP |
H06332803 | Dec 1994 | JP |
H0784883 | Mar 1995 | JP |
H07105091 | Apr 1995 | JP |
H07134658 | May 1995 | JP |
H07134659 | May 1995 | JP |
H08320830 | Dec 1996 | JP |
H09109380 | Apr 1997 | JP |
H09120374 | May 1997 | JP |
H117411 | Jan 1999 | JP |
2000040029 | Feb 2000 | JP |
200122927 | Apr 2000 | JP |
2004503870 | Feb 2004 | JP |
2005521124 | Jul 2005 | JP |
2011023017 | Feb 2011 | JP |
0141530 | Jun 2001 | WO |
2004061659 | Jul 2004 | WO |
2006019914 | Feb 2006 | WO |
Entry |
---|
Office Action from foreign counterpart Japanese Patent Application No. 2010-179219, dated May 28, 2013, 5 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2010-179219, dated Sep. 18, 2012, 7 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2010-179220, dated Sep. 25, 2012, 6 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2011-106136, dated Nov. 27, 2012, 8 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2011-106137, dated Nov. 27, 2012, 8 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2013-092397, dated Aug. 12, 2014, 6 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2013-092397, dated Mar. 11, 2014, 10 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2013-204470, dated Apr. 30, 2014, 8 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2013-204470, dated Nov. 11, 2014, 4 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2015-020410, dated Feb. 16, 2016, 16 pages. |
Panda R P., et al., “On-Chip vs. Off-Chip Memory: The Data Partitioning Problem in Embedded Processor-Based Systems,” ACM Transactions on Design Automation of Electronic Systems, vol. 5 (3), Jul. 2000, pp. 682-704. |
Pentium (R) Pro Family Developer's Manual, vol. 3: Operating System Writers' Guide, Intel, Dec. 1995, pp. 3-28. |
Requirement for Restriction/Election for U.S. Appl. No. 10/903,704, dated Oct. 19, 2007, 6 pages. |
Response to Final office action from U.S. Appl. No. 12/413,655, dated Oct. 11, 2010, 6 pages. |
Response to Non-final office action from U.S. Appl. No. 12/413,655, dated Jul. 9, 2010, 8 pages. |
Second Office Action from foreign counterpart China Patent Application No. 200580025726A, dated Dec. 12, 2008, 9 pages. |
Second Office Action from foreign counterpart China Patent Application No. CN201010227657.3, dated Jul. 4, 2012, 14 pages. |
Third Office Action from foreign counterpart China Patent Application No. 200580025726.X, dated Apr. 3, 2009, 7 pages. |
Decision to Refuse from foreign counterpart Japanese Patent Application No. 2016-159588, dated Aug. 7, 2018, 5 pages. |
Advisory Action from U.S. Appl. No. 13/020,161, dated May 4, 2012, 3 pages. |
Cox I J., et al., “A Maximum Likelihood Stereo Algorithm,” Computer Vision and Image Understanding, vol. 63, Issue 3, May 1996, pp. 542-567. |
Facom M-180 II Ad Hardware Commentary, 2nd edition, Japan, Fujitsu Ltd., Feb. 1981, pp. 35-37. |
Facom M-190 Hardware Commentary, 2nd edition, Japan, Fujitsu Ltd., Dec. 1977, pp. 26-32. |
Final Office Action from U.S. Appl. No. 10/903,704, dated Jan. 25, 2008, 14 pages. |
Final Office Action from U.S. Appl. No. 12/413,655, dated Aug. 13, 2010, 12 pages. |
Final Office Action from U.S. Appl. No. 13/020,161, dated Feb. 27, 2012, 22 pages. |
Final Office Action from U.S. Appl. No. 13/708,547, dated Nov. 15, 2013, 13 pages. |
Final Office Action from U.S. Appl. No. 13/837,997, dated Feb. 6, 2014, 9 pages. |
Final Office Action from U.S. Appl. No. 13/837,997, dated May 29, 2014, 10 pages. |
Final Office Action from U.S. Appl. No. 13/837,997, dated Oct. 18, 2013, 11 pages. |
First Office Action from foreign counterpart China Patent Application No. 200580025726.X, dated Jun. 6, 2008, 22 pages. |
First Office Action from foreign counterpart China Patent Application No. CN201010227657.3, dated Aug. 29, 2011, 13 pages. |
Intel, “IA-32 Intel architecture software Developers Manual,” vol. 3: System Programming Guide, Intel corporation, 2002, 770 pages. |
International Preliminary Report on Patentability for Application No. PCT/US2005/024997, dated Feb. 8, 2007, 12 pages. |
International Search Report and Written Opinion for Application No. PCT/US2005/024997, dated May 10, 2006, 19 pages. |
Mackenzie K., et al., “FUGU: Implementing Translation and Protection in a Multiuser, Multimodel Multiprocessor,” Technical Memorandum MIT/LCS/TM503, MIT, Oct. 24, 1994, 30 pages. |
Nakamori, “Introduction to Microprocessor Architecture,” Tech I, CQ publishing company, Apr. 1, 2004, vol. 20, pp. 147-153. |
Non-Final Office Action from U.S. Appl. No. 10/903,704, dated May 9, 2007, 19 pages. |
Non-final Office Action from U.S. Appl. No. 12/413,655, dated Apr. 13, 2010, 15 pages. |
Non-Final Office Action from U.S. Appl. No. 12/483,519, dated Jul. 20, 2010, 17 pages. |
Non-Final Office Action from U.S. Appl. No. 13/020,161, dated Sep. 22, 2011, 25 pages. |
Non-Final Office Action from U.S. Appl. No. 13/708,547, dated Jun. 4, 2013, 19 pages. |
Non-Final Office Action from U.S. Appl. No. 13/843,601, dated Oct. 39, 2013, 17 pages. |
Non-Final Office Action from U.S. Appl. No. 14/858,835, dated Nov. 16, 2015, 10 pages. |
Non-Final Office Action from U.S. Appl. No. 15/362,820, dated Aug. 31, 2017, 10 pages. |
Notice of Allowance from U.S. Appl. No. 10/903,704, dated Feb. 27, 2009, 8 pages. |
Notice of Allowance from U.S. Appl. No. 10/903,704, dated Sep. 23, 2008, 12 pages. |
Notice of Allowance from U.S. Appl. No. 12/413,655, dated Nov. 4, 2010, 8 pages. |
Notice of Allowance from U.S. Appl. No. 12/483,519, dated Nov. 12, 2010, 15 pages. |
Notice of Allowance from U.S. Appl. No. 13/020,161, dated May 28, 2013, 28 pages. |
Notice of Allowance from U.S. Appl. No. 13/708,547, dated Mar. 14, 2014, 5 pages. |
Notice of Allowance from U.S. Appl. No. 13/837,997, dated Mar. 18, 2015, 16 pages. |
Notice of Allowance from U.S. Appl. No. 13/837,997, dated Oct. 24, 2014, 18 pages. |
Notice of Allowance from U.S. Appl. No. 13/843,601, dated Apr. 4, 2014, 9 pages. |
Notice of Allowance from U.S. Appl. No. 14/579,040, dated Jun. 3, 2015, 22 pages. |
Notice of Allowance from U.S. Appl. No. 14/579,526, dated Jun. 23, 2015, 22 pages. |
Notice of Allowance from U.S. Appl. No. 14/580,345, dated Jun. 18, 2015, 2 pages. |
Notice of Allowance from U.S. Appl. No. 14/858,835, dated Apr. 12, 2016, 20 pages. |
Notice of Allowance from U.S. Appl. No. 14/858,835, dated Aug. 2, 2016, 11 pages. |
Notice of Allowance from U.S. Appl. No. 15/362,820, dated Feb. 23, 2018, 29 pages. |
Notice of Allowance from U.S. Appl. No. 15/362,820, dated Nov. 30, 2017, 8 pages. |
Notice of Reasons for Rejection from foreign counterpart Japanese Patent Application No. 2016-159588, dated Sep. 5, 2017, 10 pages. |
Notification of Reasons for Refusal from foreign counterpart Japanese Patent Application No. 2007-523610, dated Sep. 7, 2010, 4 pages. |
Office Action from foreign counterpart German Patent Application No. 112005001798.2, dated Aug. 19, 2009, 6 pages. |
Office Action from foreign counterpart German Patent Application No. 112005001798.2, dated Feb. 28, 2008, 5 pages. |
Office Action from foreign counterpart German Patent Application No. 112005001798.2, dated Jun. 30, 2011, 5 pages. |
Office Action from foreign counterpart German Patent Application No. 112005003863.7, dated Mar. 4, 2015, 3 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2007-523610, dated May 11, 2010, 6 pages. |
Office Action from foreign counterpart Japanese Patent Application No. 2010-179219, dated Jan. 29, 2013, 6 pages. |
Number | Date | Country | |
---|---|---|---|
20180357179 A1 | Dec 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15362820 | Nov 2016 | US |
Child | 16005385 | US | |
Parent | 14858835 | Sep 2015 | US |
Child | 15362820 | US | |
Parent | 14580345 | Dec 2014 | US |
Child | 14858835 | US | |
Parent | 13837997 | Mar 2013 | US |
Child | 14580345 | US | |
Parent | 13708547 | Dec 2012 | US |
Child | 13837997 | US | |
Parent | 13020161 | Feb 2011 | US |
Child | 13708547 | US | |
Parent | 12483519 | Jun 2009 | US |
Child | 13020161 | US | |
Parent | 10903704 | Jul 2004 | US |
Child | 12483519 | US |