In a conventional processing system having a processor with multiple cores, one core is designated as the default core for implementing the boot process for the processing system and for remaining in an active state to handle various tasks while the other cores of the processor are in a reduced-power state. This default core assignment is static and permanent across boot processes and state changes. The core permanently designated as this default core thus is subjected to an unequal share of the computing workload of the processor. As a result, the operating life of the default core is reduced relative to the other cores, and once the default core is no longer operational within minimum specifications, the entire processor typically is scrapped or discarded.
The present disclosure may be better understood, and its numerous features and advantages made apparent to those skilled in the art by referencing the accompanying drawings. The use of the same reference symbols in different drawings indicates similar or identical items.
Typically, an operating system (OS) of a computing device logically enumerates the cores of a multi-core processor according to pin number, with the core at a first pin position or number being numbered C(0) (or “C0”) by the operating system as a default core for handling processes assigned for execution by the processor. This assignment is maintained as long as the operating system remains active, which often is for weeks or even months between re-starts or boot-ups. Further, when computing demand is reduced, one or more of the cores of the multi-core processor are placed into a reduced power state, while the default core C(0) is maintained in an active state (or a more active state) so that at least one core is available to accept processes for execution. Thus, even when idle, the OS generally tends to favor assigning execution of processes to the default core C(0). However, between the assignment of boot tasks, low-level kernel tasks, and user space program processes to the default core C(0), the default core C(0) wears out sooner than the other cores, especially when the other cores of the processor are frequently set to an idle state or a power-down state. As such, without evenly spreading the workload to all of the cores of the processor, the operating life of the processor is reduced because the default core C(0) wears out. Once one core fails or wears out, the processor (and perhaps the device implementing the processor) is rendered non-operational since the processor typically is not designed to operate without all cores of the processor remaining viable for accepting process tasks from the OS.
Therefore, according to some embodiments, during a bootstrap process a computing device implementing a processor with multiple processor cores is configured to non-permanently select one core of the plurality of cores as the default core for process execution so that the computing device and OS do not default to always assigning the same core as the default core. The other cores are assigned based on this selection. The assignment of the default core C(0) is performed according to one of a plurality of techniques as further described. As this selection of one core as the default core is temporary, the computing device is able to dynamically re-assign a different core as the default core C(0) at some point after the boot process. As a result, the responsibility for operating as the default core C(0) is more evenly spread among the cores of the processor. This more evenly spreads the wear on the cores and thus extends the operational life of the processor.
At a first time (“TIME 1”), a core assignment component 104 operative in the device 100 has assigned or designated a first core (“CORE 1”) 111 in the upper-left as the default core C(0) to the OS 103—where core indices are numbered starting from zero. A second core (“CORE 2”) 112 has been assigned to be a second core C(1). A third core (“CORE 3”) 113 has been assigned to be a third core C(2). A fourth core (“CORE 4”) 114 has been assigned to be a fourth core C(3). At a second time (“TIME 2”) previous or subsequent to the first time, the cores 111-114 have been assigned differently by one or more components of the computing device 100 such as the core assignment component 104 according to some embodiments. The same physical cores have remained in their same physical places in the processor 110. However, the core assignments have changed. At the second time, the cores 111-114 are designated as C(3), C(2), C(1), and C(0), respectively.
According to some embodiments, the fourth core 114 has been selected at random and designated as the default core C(0), and the remaining cores are designated according to pin order in the processor 110 as encountered during the boot process. Other embodiments assign core designations by other methods. For example, according to other embodiments, the third core 113 and the fourth core 114 have been selected at random and designated as the second core C(1) and the default core C(0), respectively, and the remaining cores are designated according to pin order in the processor 110 as encountered during the boot process. In yet other embodiments, the second, third, and fourth cores 112-114 have been selected at random and designated as the third core C(2), the second core C(1), and the default core C(0), respectively, and the remaining core is designated according to pin order in the processor 110 as encountered during the boot process. Further examples of embodiments and further illustrative details are provided herein in relation to other figures.
Irrespective of whether the computing device 100 is operating at the first time or the second time, the OS 103 sends process instructions to cores 111-114 according to core indices. For example, process instructions passed from the OS 103 to the processor 110 is done according to an index (e.g., 1 in hexadecimal notation corresponding to either the second core 112 or the third core 113) and a hardware identifier (e.g., HID=LNXCPU:00 corresponding to the processor 110). Thus, when a reference to a process of the OS 103 needs to be passed from the system memory 102 to the processor 110 so that process instructions can be executed, the mechanism involves the core index. The core index allows the device 100 to deliver processor instructions to the proper core without the OS 103 passing a specific pin number of the processor 110 in relation to the motherboard 101. Consequently, the OS 103 can be written, compiled, and operated across a variety of types of processors without a need to change the operating system for every hardware change across various devices. Various embodiments are now described as examples of how to assign processor core indices for use by an OS such as OS 103.
The processor 210 includes a plurality of cores including a first core 211, a second core 212, a third core 213, and a fourth core 214. These cores include, for example, central processing unit (CPU) cores, graphics processing unit (GPU) cores, or combinations thereof. According to some embodiments, the cores 211-214 include their own respective memory structures, such as an L1 cache and L2 cache which are not depicted in
According to some embodiments, the boot memory 202 is implemented as a ROM that stores boot code for execution during a boot process that is initiated upon a motherboard power-on reset. The boot memory 202 includes a start-up service such as an advanced configuration and power interface (ACPI) framework 203 and a basic input output system (BIOS) 204. The ACPI framework 203 provides hardware registers to the components powered by the motherboard 201 to enable power management and device operation without directly calling each component natively such as by a hardware address. The ACPI framework 203 serves as an interface layer between the BIOS 204 and an OS 232 for the device 200.
At a power-on reset or other boot initialization event, power is supplied to the motherboard 201. When the motherboard 201 first receives power, the boot memory 202 is activated and completes its setup, initialization, and self-tests including a power-on self-test (POST). The BIOS 204 then uses information obtained during firmware initialization to create or update tables of the ACPI framework 203 with various platform and device configurations including power interface data. During the boot process, the processor 210 generates core information 205, which provides data about the cores 211-214 to the OS 232. In particular, the core information 205 includes a designation of one of the cores 211-214 as the default core C(0), and with the default core C(0) so designated, enumeration of the other cores as C(1) to C(N−1) accordingly.
During the boot process, the BIOS 204 identifies all available storage devices for potential boot devices that may have an OS for the device 200. The BIOS 204 uses a boot order specified in a persistent storage available to the motherboard 201. On some motherboards, the persistent storage is a separate chip. In many instances, the BIOS persistent storage is integrated with a real-time clock (RTC) or with an integrated circuit (IC) on the motherboard 201 that is responsible for a hard drive controller, an I/O controller, and integrated components. In some embodiments, the BIOS persistent storage is provided with its own power source in the form of a battery which allows the BIOS persistent storage to maintain the boot order, the core assignments 207, and so forth even if the motherboard 201 of the device 200 loses primary power.
The BIOS 204 looks for an OS to load in the first sector of each storage device in a boot order sequence. In
The copied MBR 231 includes a boot loader for the OS 232. The boot loader includes executable code that loads the OS 232 into the system memory 230 and starts the OS 232. At this point, the BIOS 204 activates the boot loader and stops controlling the motherboard 201 and the device 200. The boot loader loads and executes the various components of the OS 232 in the system memory 230. During its initialization, the OS 232 starts and initializes a kernel 233 to allow the kernel 233 to provide tasks in the form of processor instructions to the processor cores 211-214. The kernel 233 manages execution of processes on the cores 211-214. During initialization, the kernel 233 is configured to access the cores 211-214 by way of reference indices corresponding to the core assignments 207. According to some embodiments, the core assignments 207 are implemented as a group of registers or a table of the ACPI framework 203, the kernel 233 operating according to conventional practices. In other embodiments, the core assignments 207 are provided to the kernel 233 by the boot loader of the MBR 231, and the kernel 233 uses the new core assignments 207 to effectively shift the default core designation of C(0) to one of the second core 212, the third core 213, or the fourth core 214. In yet other embodiments, the processor 210 provides the core assignments 207 to either the boot loader, or to the kernel 233 during initialization of the OS 232. According to further embodiments, after the boot process, during operation of the OS 232, the core assignments 207 are updated to new index values periodically or upon demand in order to spread the wear across the cores 211-214 during the life of the processor 210. After being re-assigned, the various processor cores 211-214 are assigned processes according to the new core assignments.
According to some embodiments, when the OS schedules a process for execution at a core 211-214, the OS refers to the cores 211-214 by an affinity mask. The affinity mask is a set of N bits, one for each of the N cores of the processor 210 in the device 200. The core information 205 translates for the OS 232 the physical core 211-214 that actually receives the task or thread of the particular process scheduled for execution.
According to some embodiments, core assignments are provided to the OS by making available indices by persistently storing the indices in a hardware component of a boot memory. One example hardware component is a nonvolatile complementary metal-oxide-semiconductor (CMOS) memory of the boot memory 202 of
The boot memory 402 includes an ACPI framework 403 and a BIOS 404 that allows an OS of the computing device 400 to use the processor 410 by scheduling processing instructions to be executed thereon. The ACPI framework 403 includes an ACPI persistent memory that can store values for operation of the components of the computing device 400. According to some embodiments, an ACPI persistent memory takes the form of an ACPI table, a group of ACPI registers, or a set of ACPI registers 405 as known to those in the art. The processor 410 is declared in an ACPI namespace of the ACPI framework 403. Generally, the ACPI namespace includes ACPI tables for operating the components of the motherboard 401 including the processor 410. During its initialization, an OS of the computing device 400 builds a namespace for itself from the ACPI tables. A device definition for the processor 410 is declared in the OS of the computing device 400 using a hardware identifier which the OS uses to schedule processes to execute on the cores 411-414 of the processor 410.
The OS uses the set of registers 405 to schedule processes on the processor 410. The ACPI framework 403 includes registers for each of the cores 411-414 of the processor 410 in the form of core assignments 407. According to some embodiments, the core assignments 407 correspond to bus numbers (e.g., 0x4C, 0x10) for the cores 411-414, but are represented as indices in
According to some embodiments, the assignments 407 are made during the boot process by executing a general-purpose event of the ACPI 403 as known in the art. According to one illustrative embodiment, the core assignments 407 corresponding to each of the physical core indices 406 (0-3) are generated by use of a core permutation table 408 with each row corresponding to one of N factorial number of permutations of N number of cores in the processor 410. For example, the indices shown as core assignments 407 in
As an example, during the boot process, a row index 409 is obtained such as from a persistent memory register 405. The row index 409 corresponds to one of the rows in the core permutation table 408. The permutation table 408 includes a series of rows, one row for each permutation of indices of the cores 411-414. According to one embodiment, the permutation table 408 is an ACPI table that is persistently stored in the boot memory 402 even when power is no longer provided to the motherboard 401. According to another embodiment, the permutation table 408 is generated each time the motherboard 401 of the device 400 is booted where the permutation table 408 is generated based on an answer of a query asking for a number of cores in the processor 410. The query is executed as AML byte code during the boot process. The row index 409 is persistently stored from boot to boot. During any given boot process, the row index 409 is advanced one, and the core assignments 407 are then generated by reference to a row in the permutation table 408 that corresponds to the new row index 409. As another example implementation, the row index 409 is selected based on a random or pseudo-random algorithm operative as AML byte code in the ACPI framework 403. In this way, each of the cores 411-414 receives processes for execution based on its corresponding core assignment 407.
Other mechanisms for generating the core assignments 407 are possible. As another example of a mechanism for generating core assignments 407, a random number generator algorithm programmed, compiled, and executed as AML byte code during the boot process assigns each of the core assignments 407 until all of the assignments are completed, one for each of the cores 411-414 of the processor 410.
At block 502, core assignments for the enumerated cores are generated. According to some embodiments, one row of a plurality of rows of an assignment table is accessed and a new core index number is provided to each of the enumerated cores. For example, for a four-core processor where the cores are physically numbered 0, 1, 2, and 3, each of these four cores is provided with a new index number. As shown at 407 in
At block 503, the method 500 includes persistently storing core assignments for use in passing processes to processor cores. For example, persistently storing includes storing an address (e.g., a bus address, a bus number) or identifier of each of the processor cores in the persistent boot memory such as in the ACPI table or ACPI registers 405 of
According to some embodiments, the processor 610 is a CPU and includes a plurality of cores including a first core 611, a second core 612, a third core 613, and a fourth core 614. One of the cores 611-614 is designated a default core C(0). The cores 611-614 include their own respective memory structures and may share a shared memory (e.g., an L3 cache) where such memory structures are not depicted in
The processor 610 also includes a core assignment module 615 and a core translation module 616. These modules 615, 616 are designed and operate according to one of a plurality of core assignment schemes. Two core assignment schemes are described herein as illustrative of the plurality of schemes to structure components of the processor 610. The components shuffle the designations of the cores 611-614 of the processor 610, and the components provide an interface to allow the cores to interoperate with other components of the device 600 including an OS.
According to some embodiments, and as one example scheme, during a processor configuration or initialization process (e.g., during the boot process), the core assignment module 615 configures the core translation module 616 using core assignment components 617 by providing core indices 618 (e.g., in the form of core indices, core addresses, or bus numbers) to the core translation module 616. After the boot process, during operation of the computing device 600, the OS routes process instructions as in a conventional scheduling mechanism by reference to a same set of bus numbers for the processor 610 as if no bus numbers had been changed at a bus of the processor 610. The OS interoperates with the ACPI framework 603 in a conventional way. However, based on core assignment components 617 operative during the boot process internal to the processor 610, process instructions coming from the OS are routed to the cores 611-614 based on the indices 618 of the core translation module 616. The processor 610 routes, via the core translation module 616, the instructions to the cores 611-614 internally according to a particular core index scheme represented as the core indices 618. Each time the processor 610 is initialized, an order or a sequence of these core indices 618 are changed. For example, a first process that is scheduled to be executed on the default core C(0) actually is passed to the core addressed in the first core index 618 which is “3” in
According to some embodiments, the processor 610 or the core assignment module 615 of the processor 610 includes a pseudo-random number generator (PRNG) 619 or components to implement core index number generation. The core assignment module 615 can call or activate the PRNG 619 to provide an index value to put within each register thereby providing the indices 618 according to a pseudo-random scheme. Core assignment components 617 can be provided so as to check to ensure that no illegal indices 618 are provided (e.g., a value of “5” when only 0-3 are possible for the four cores 611-614 of the processor 610). Alternatively, the core assignment module 615 can call or activate the PRNG 619 to select which register is to be designated as the default core C(0). Then, an address or a core bus number is provided to that particular register in the processor 610. This process can be repeated until all cores 611-614 have been assigned an index 618.
Alternatively, once a C(0) register has been identified and filled, the other registers can be filled in order without regard to any randomness so that at least the C(0) is selected pseudo-randomly for the processor 610. According to some embodiments, the motherboard 601 includes a real-time clock (RTC) that operates therein, and the PRNG 619 communicates with the RTC when providing the core indices 618 to the registers of the core translation module, the PRNG 619 basing its operations upon a value of the RTC. According to such an embodiment, the PRNG 619 uses the RTC to obtain entropy for distributing at least the C(0) designation to one of the registers corresponding to one of the cores 611-614.
According to a variation of this example scheme, during a processor configuration process, the core assignment module 615 configures the registers of the core translation module 616 using core assignment components 617 according to a round robin scheme. As used herein, the round robin scheme shifts a core index of each core by one position during a processor initialization step of the boot sequence. The positions are shifted each time the device operating the processor is subjected to a boot process or each time the processor 610 detects a reassignment signal at a bus of the processor 610.
As one example of operation, when the processor 610 detects a reassignment signal, core assignment components 617 pseudo-randomly select a first register and a second register of the set of registers holding the indices 618. The core assignment components 617 then switch the indices 618 of the first selected register and the second selected register. A reassignment signal can be sent by a scheduler of a kernel of an OS active in the device 600 after a predetermined core wear target time is exceeded, the predetermined core wear target time having been designated by a manufacturer or an OS programmer according to a typical lifespan estimate for the cores 611-614. By way of example, a core wear target time can be predetermined and can be set as a number of hours or days operating in a particular core assignment configuration.
According to other embodiments, and as another example scheme, during a processor configuration or initialization process (e.g., during the boot process), the core assignment module 615 configures ACPI registers or an ACPI table of the ACPI framework 603 (corresponding to the cores 611-614 of the processor 610) using core assignment components 617 by providing core indices 618, (e.g., in the form of indices, core addresses, or bus numbers) to the ACPI framework 603. According to some embodiments, the core indices 618 correspond to bus numbers (e.g., 0x4C, 0x10) for the cores 611-614. As one example of an implementation, the core assignment module 615 reads core indices 618 from the core translation module 616 and passes the indices 618 to the ACPI framework 603. According to another example implementation, the core translation module 616 includes a table of permutations of sets of core indices 618 or values that can be used in subsequent configuration or initialization steps. During an initialization step in the processor 610, the core assignment module 615 randomly selects, via the core assignment components 617, one of the rows from the table of permutations of sets of core indices 618 and passes the indices 618 to the ACPI framework 603.
In operation, according to the second example scheme, process instructions are routed from the OS via the information provided to the ACPI framework 603 by the core assignment module 615. The scheduler and the kernel of the OS of the computing device 600 operate using conventional core calls and core scheduling, but transparently the instructions are routed to one of the various cores 611-614 indicated by the core indices 618 and not by hard-wired designations as in conventional operation. For example, a first process that is scheduled to be executed on C(0) actually is passed to the core addressed in the first index which is “3” in
This scheme of scheduling is repeated using the core assignments 607 until the core assignments 607 are re-generated from time to time. Core re-assignment is performed at each reboot or on demand from time to time as scheduled or triggered from the OS or by some other component or combination of components in the computer device 600. In summary, as explained in relation to
According to another embodiment, as another example scheme, during a processor configuration or initialization process (e.g., during the boot process), a first core assignment is provided by a core assignment module of a first processor (e.g., an ARM processor) and its core assignment output is provided to a second processor such as processor 610 of
At block 702, the core re-assignment scheme created at block 701 is persistently stored. Storing may take the form of passing addresses such as bus addresses to another element in a computing device such as a boot memory, a memory structure of an ACPI framework, or a system RAM.
At block 703, process instructions for execution on the cores of a processor are passed to one of the respective cores based on the re-assignment scheme. For example, as shown at 618, a process that is scheduled and passed to core C(0) is actually sent to C(3), or to whichever core C(0) is re-assigned.
According to some embodiments, the processor 810 includes a plurality of cores including a first core 811, a second core 812, a third core 813, and a fourth core 814. The cores 811-814 include their own respective memory structures and share a shared memory (e.g., an L3 cache) where such memory structures are not depicted in
The boot memory 802 includes an ACPI framework 803 and a BIOS 804 that allows an OS of the computing device 800 to provide processes to the cores 811-814 of the processor 810 for execution thereon. The ACPI framework 803 includes an ACPI memory within or as part of the boot memory 802. The ACPI memory stores values for operation of the components of the computing device 800. According to some embodiments, an ACPI memory takes the form of an ACPI table, a group of ACPI registers, or a set of ACPI registers as known to those in the art. During a boot process, the processor 810 is declared in an ACPI namespace of the ACPI framework 803. The ACPI namespace includes ACPI tables for operating the components of the motherboard 801 including the processor 810 and its cores 811-814. During its initialization, an OS of the computing device 800 builds a namespace for itself from the ACPI tables. A device definition for the processor 810 is declared in the OS of the computing device 800 using a hardware identifier which the OS uses to schedule processes to execute on the cores 811-814 of the processor 810.
The OS uses information in the set of ACPI registers to schedule processes on the cores 811-814 of the processor 810. The ACPI framework 803 includes registers for each of the cores 811-814 of the processor 810 in the form of core assignments 807. According to some embodiments, the core assignments 807 correspond to bus numbers (e.g., 0x4C, 0x10) for the cores 811-814, but are represented as indices in
For example, a process that is scheduled to be executed at core index (0) at 806 (i.e., the default core C(0)) is actually passed to the core having index (3) at 807 (i.e., fourth core C(3)). In this way, the first core 811 that was originally and permanently hardwired or configured as the default core C(0) in a conventional system has been transformed into the fourth core C(3), and the process that was assigned to be executed on the first core 811 is actually sent to the fourth core 814. This scheduling is repeated using all of the respective core assignments 807 until the core assignments 807 are re-generated. From the perspective of the OS scheduler, the process is executed on the default core C(0), and in actuality, the process is transparently passed to and executed on the fourth core 814 or C(3). Thus, processes are passed to the respective core 811-814 corresponding to the indices of the core assignments 807 thereby creating a configurable interface between the OS and the processor cores 811-814. In short,
According to some embodiments, the core assignments 807 are made during the boot process by boot components during execution of a master boot record (MBR) 821. Before the MBR 821 is executed, certain BIOS instructions are executed from the boot memory 802. The BIOS 804 eventually activates the boot loader of the MBR 821 and the BIOS 804 stops directly controlling the motherboard 801 and the device 800. The MBR 821 includes a boot loader for the OS 822. The boot loader executes a bootstrap thread (e.g., a thread (0) in core (0) of processor (0)) that starts up fetching code. The fetching code pulls additional instructions from a first sector of the active partition 809 of the hard drive 808 starting from a particular address. The additional instructions include instructions to make the core assignments 807. The additional instructions also include instructions for loading the OS into the system memory 820 and initializing the OS 822 after the core assignments have been made.
Thus, according to some embodiments, the core assignments 807 are made prior to loading some or all of the OS 822 and operating the same. Once initialized, the instructions of the boot loader start the OS 822 by placing the OS 822 into a condition to execute user-defined instructions on the computing device 800. During its initialization, the OS 822 starts and initializes a kernel 823. The kernel 823 provides process instructions to the processor cores 811-814 using the core assignments 807.
With respect to
The instructions to determine the core assignments 807 take one of a plurality of forms. For example, the instructions make use of a core permutation table with each row corresponding to one of N factorial number of permutations of N number of cores in the processor 810. The number of cores may be determined during the boot process by instructions of the MBR 821 or the boot loader of the MBR 821 by reading one or more registers of the ACPI framework 803 during the boot process. As another example, the instructions of the MBR 821 include a random number generator algorithm that is called to make some or all of the core assignments 807. According to a first variation, a first random or pseudo-random assignment for the default core C(0) is made among the available cores 811-814. Subsequently, each of the other cores is sequentially assigned in bus order to make the remaining core assignments 807. According to a second variation for making core assignments 807, each of the cores (C(0) through C(3)) are randomly or pseudo-randomly assigned. The instructions for making the core assignments 807 includes persisting or otherwise making the assignments 807 available to the kernel 823 of the OS 822. One mechanism to do so includes executing instructions to write or re-rewrite certain registers, or one or more ACPI table entries in one or more respective ACPI tables, of the ACPI framework 803. According to some embodiments, the MBR 821 includes instructions to persist the core assignments 807.
In some embodiments, the apparatus and techniques described above are implemented in a device or a system including one or more integrated circuit (IC) devices (also referred to as integrated circuit packages or microchips), such as the multi-core processors described above with reference to
A computer readable storage medium may include any non-transitory storage medium, or combination of non-transitory storage media, accessible by a computer system during use to provide instructions and/or data to the computer system. Such storage media can include, but is not limited to, optical media (e.g., compact disc (CD), digital versatile disc (DVD), Blu-Ray disc), magnetic media (e.g., floppy disc, magnetic tape, or magnetic hard drive), volatile memory (e.g., random access memory (RAM) or cache), non-volatile memory (e.g., read-only memory (ROM) or Flash memory), or microelectromechanical systems (MEMS)-based storage media. The computer readable storage medium may be embedded in the computing system (e.g., system RAM or ROM), fixedly attached to the computing system (e.g., a magnetic hard drive), removably attached to the computing system (e.g., an optical disc or Universal Serial Bus (USB)-based Flash memory), or coupled to the computer system via a wired or wireless network (e.g., network accessible storage (NAS)).
In some embodiments, certain aspects of the techniques described above may implemented by one or more processors of a processing system executing software. The software includes one or more sets of executable instructions stored or otherwise tangibly embodied on a non-transitory computer readable storage medium. The software can include the instructions and certain data that, when executed by the one or more processors, manipulate the one or more processors to perform one or more aspects of the techniques described above. The non-transitory computer readable storage medium can include, for example, a magnetic or optical disk storage device, solid state storage devices such as Flash memory, a cache, random access memory (RAM) or other non-volatile memory device or devices, and the like. The executable instructions stored on the non-transitory computer readable storage medium may be in source code, assembly language code, object code, or other instruction format that is interpreted or otherwise executable by one or more processors.
Note that not all of the activities or elements described above in the general description are required, that a portion of a specific activity or device may not be required, and that one or more further activities may be performed, or elements included, in addition to those described. Still further, the order in which activities are listed are not necessarily the order in which they are performed. Also, the concepts have been described with reference to specific embodiments. However, one of ordinary skill in the art appreciates that various modifications and changes can be made without departing from the scope of the present disclosure as set forth in the claims below. Accordingly, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of the present disclosure.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any feature(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature of any or all the claims. Moreover, the particular embodiments disclosed above are illustrative only, as the disclosed subject matter may be modified and practiced in different but equivalent manners apparent to those skilled in the art having the benefit of the teachings herein. No limitations are intended to the details of construction or design herein shown, other than as described in the claims below. It is therefore evident that the particular embodiments disclosed above may be altered or modified and all such variations are considered within the scope of the disclosed subject matter. Accordingly, the protection sought herein is as set forth in the claims below.
Number | Name | Date | Kind |
---|---|---|---|
20030093695 | Dutta | May 2003 | A1 |
20080162878 | Zimmer et al. | Jul 2008 | A1 |
20100107166 | Topaloglu | Apr 2010 | A1 |
20140006767 | Chang et al. | Jan 2014 | A1 |
20150169363 | Anderson | Jun 2015 | A1 |
20170068546 | Henry et al. | Mar 2017 | A1 |
20170277571 | Yoo et al. | Sep 2017 | A1 |
Entry |
---|
International Search Report and Written Opinion dated Jan. 15, 2019 for corresponding International Application No. PCT/US2018/052456, 17 pages. |
International Preliminary Report on Patentability dated Jul. 2, 2020 for International Application No. PCT/US2018/052456, 13 pages. |
Number | Date | Country | |
---|---|---|---|
20190188001 A1 | Jun 2019 | US |