The disclosure generally relates to CPC class H04L and subclass 63/10.
A serverless architecture allows development of an application without the burden of managing underlying infrastructure. In terms of cloud computing, a cloud service provider provides Backend as a Service (BaaS) so that the application developer can focus on application development and not infrastructure management. The cloud service provider provisions, scales, and manages the infrastructure required to run application code.
With a serverless architecture, a serverless application can be developed. A serverless application is an application written with serverless functions to be run in stateless computer containers. The serverless functions are functions that are event-driven, ephemeral, and managed by the cloud service provider.
Embodiments of the disclosure may be better understood by referencing the accompanying drawings.
While the serverless paradigm has many advantages, the fine granularity of identity access and management (IAM) at a per-serverless function granularity can be problematic. This granularity of role assignment may allow for powerful security enforcement, but the complexity leads to developers assigning over-permissive roles to serverless functions. Over-permissive execution roles can be abused to perform unintended operations and allow security breaches.
The serverless security access control system disclosed herein facilitates adherence to the principles of least privilege and single responsibility. This serverless security access control system leverages static analysis information about application code and runtime information to create and assign on-the-fly transient serverless function roles. Instead of developers creating and assigning various roles to the serverless functions of a serverless application, a default role can be initially assigned to serverless functions of the application. The default role allows the function to communicate with a security access broker or access broker. The access broker accesses least privilege information about an invoked serverless function and then creates and assigns a transient role to the serverless function based on that information. The short life of the role reduces and possibly eliminates the security risk of an over-permissive role. The access broker can update the least privilege information based on updated analysis of the application code and runtime information to allow flexibility and adaptation over executions.
At stage A, a code scanner 101 performs static analysis of the program code for the serverless application 103A. The code scanner 101 determines least privilege(s) information 111 (e.g., read access of a specific database) for each of the serverless functions 105, 107. The code scanner 101 provides this information 111 for storing into a database 109 that is accessible by the SAB 113. The code scanner 101 can be an application tool or service.
At stage B, the serverless application 103A is deployed to the cloud infrastructure 131. The cloud service provider corresponding to the cloud infrastructure 131 will provision resources for the deployed serverless application 103B.
During warm-up execution of the deployed serverless application 103B, runtime instrumentation on each of the serverless functions 105, 107 will execute to authenticate with the SAB 113 to obtain a tailored role for a corresponding serverless function at stage C. The instrumented serverless functions 105, 107 are programmed with a default role that constrains access to communicating with the SAB 113, as illustrated in
At stage D, the SAB 113 accesses the database 109 to determine least privilege(s) for the invoked function 105. The database 109 is organized to associate each serverless function of a serverless application with one or more privileges deemed necessary for proper execution of the associated function. The association can be between a function identifier (e.g., concatenation of application identifier and function identifier or hash of concatenation of application identifier and function identifier) and indications of privileges (e.g., READ DB1; WRITE DB2; PERMIT API XX2).
After obtaining the least privilege(s) from the database 109, the SAB 113 interacts with a service 133 of the cloud service provider to create a role with the determined least privilege(s) at stage E. The SAB 113 provides the least privilege(s) (e.g., as arguments or parameters) to the service 133 for role creation. The service 133 returns to the SAB 113 a role identifier to the SAB 113. Since the SAB 113 may be brokering role creation for multiple applications, the SAB 113 may organize created roles by application and even cloud service provider, as well as function.
At stage F, the SAB 113 communicates the created role for the invoked function 105 to the serverless application 103B. The corresponding runtime instrumentation assigns the communicated role to the function 105 and then executes the serverless function 105 with that role.
At stage G, the SAB maintains the on-the-fly tailored roles per function instance. As part of the security mechanism, the created roles expire. The SAB 113 sets an expiration period based on execution time of the function and/or execution times of functions (e.g., greatest execution time) of the serverless application 103B. Upon expiration, the SAB 113 interacts with the service 133 to terminate or delete the expired role.
While the name security access broker is used for consistency with the earlier description, programs/module can be given a variety of names while having substantially similar functionality. The name chosen for the program code is not to be limiting on the claims. Structure and organization of a program can vary due to platform, programmer/architect preferences, programming language, etc. In addition, names of code units (programs, modules, methods, functions, etc.) can vary for the same reasons and can be arbitrary. A “security access broker” is a program(s) that runs external to one or more serverless applications and can run within or external to a corresponding cloud service provider. The program or program(s) operate as an intermediary between the serverless application and a role creation service/function of the cloud service provider that supports the serverless application. An access broker can be implemented as a service or standalone application.
At block 205, serverless function runtime instrumentation 201 requests authentication of a corresponding serverless function instance based on detected invocation of the serverless function. As instrumented, the runtime instrumentation 201 will execute prior to the program code of the serverless function. The runtime instrumentation 201 will have access to credentials for authenticating the serverless function. The runtime instrumentation 201 may include program code to query an underlying infrastructure or operating system for host information (e.g., a network address assigned to a host of the serverless application that includes the serverless function.
At block 207, a security access broker 203 authenticates the serverless function instance. The security access broker 203 can invoke or communicate with another program or module responsible for authentication. If the authentication is successful, then program flow continues to block 211. Otherwise, program flow continues to block 209.
At block 209, the security access broker 203 generates a notification of the failed authentication. This notification can be logged, communicated to the serverless application instance encapsulating the runtime instrumentation 201, communicated to the runtime instrumentation 201, etc.
At block 211, the security access broker 203 notifies the runtime instrumentation 201 of the successful authentication. Based on the successful authentication, the security access broker 203 may populate a data structure that tracks successfully authenticated serverless functions that are active. For example, the security access broker 203 can maintain a data structure with an entry for each successfully authenticated serverless function that will be used for regulating the life of the role to be created and assigned (i.e., used for managing role expiration). The security access broker 203 can then mark entries as expired and/or delete the entries corresponding to serverless functions assigned expired roles.
At block 213, the serverless function runtime instrumentation 201 requests a role for the serverless function instance. As part of the request, the runtime instrumentation 201 communicates to the security access broker 203 information identifying the serverless function instance. Examples of the identifying information include a function identifier; an application identifier; a combination of a function identifier and an application identifier; a combination of a function identifier, an application identifier, and a value identifying cloud infrastructure supporting the serverless application.
At block 215, the security access broker 203 obtains previously determined least privilege(s) for the serverless function based on the communicated function instance information. The security access broker accesses a database that indicates previously identified serverless functions of the serverless application and the previously determined least privilege(s) of each function. The information may have been determined with static analysis from code scanning, knowledge/documentation for the serverless application, and/or behavioral analysis of prior (laboratory or live) executions of the serverless application.
At block 217, the security access broker 203 creates a least privileged role based on the obtained least privilege(s) for the serverless function, and binds the created role to the instance of the serverless function. To create the role, the security access broker 203 interacts with a service, command interface, or application programming interface of a cloud service corresponding the cloud infrastructure that supports the serverless application. The security access broker 203 communicates indications of the obtained least privilege(s) to the cloud service for creation of the role. An indication of the created role (e.g., role identifier) is returned to the security access broker 203. The security access broker 203 binds the role to the information that identifies the serverless function instance (e.g., the network address of a cloud server hosting the serverless application). “Binding” the role to the serverless function instance can be updating the previously mentioned data structure entry for the serverless function instance with the role identifier.
At block 219, the security access broker 203 sets an expiration time for the created role and updates execution tracking data. For example, the security access broker 203 updates the aforementioned data structure (hereinafter “transient role structure”) with an expiration time (e.g., 3 minutes). The security access broker 203 can be programmed to set expiration based on expected execution time of the serverless function instance and additional time accounting for communication of the role to the runtime instrumentation 201. The security access broker also updates the transient role structure to indicate a timestamp of first execution of the serverless function instance and/or increments an execution counter for the serverless function instance.
At block 221, the security access broker 203 communicate the created role to the runtime instrumentation 201. For example, the security access broker 203 indicates the created role identifier in the message to the runtime instrumentation 201.
At block 223, the runtime instrumentation 201 assigns the role communicated from the security access broker 203 to the serverless function and executes the serverless function. The runtime instrumentation 201 can modify code to set the created least privileged role to override the default role for the serverless function. The runtime instrumentation 201 may execute the serverless function with the least privileged role identifier as an argument or parameter in the invocation.
Despite static analysis and past behavior analysis of a serverless application providing intelligence for creation of a least privileged role tailored for each serverless function of the serverless application, execution behavior can change and analysis may not be perfect. Changing execution behavior and/or imprecise analysis can lead to under-permissive privileges or over-permissive privileges over time/executions. To minimize the impact of imperfect analysis and adapt to execution behavior over time/executions, the security access broker is programmed to adjust accordingly. The flowcharts depicted in
At block 305, serverless function runtime instrumentation 301 detects an access violation by a serverless function instance with an on-the-fly tailored role. It is assumed at this point in the flow that the serverless function instance has already been assigned a least privileged role from the security access broker. For example, the serverless function instance may have attempted to write to a database X while the least privileged role only specified write permission to a database Y. Or the serverless function instance may have attempted to write to a database X with a least privileged role that only provides read permission to the database X. The runtime instrumentation 301 can detect the access violation differently. For instance, the runtime instrumentation 301 may receive a message indicating an IAM violation based on failed execution of the serverless function instance.
At block 307, the runtime instrumentation 301 requests a new role for the serverless function instance with an additional privilege based on the access violation. The request may include a flag or argument that distinguishes the request as a request for expanding privilege or a role. The request includes information that identifies the serverless function instance (e.g., function identifier and network address of cloud server) and indicates the access violation. The request can be a beacon request (i.e., a request message that complies with the Beacon interface specification.
At block 309, the security access broker 303 determines whether the expansion criterion has been satisfied for the serverless function instance. The security access broker 303 accesses the transient role structure to read the entry for the serverless function instance indicated by the runtime instrumentation 301. If the expansion criterion is defined by time, the security access broker 303 reads a timestamp from the entry that indicates when the serverless function instance was first invoked. The security access broker 303 would then determine whether the time-based expansion criterion has lapsed since the initial invocation of the serverless function instance. If the expansion criterion is defined by numbers of executions, the security access broker 303 reads an execution counter from the appropriate transient role structure entry.
If the expansion criterion is not satisfied, then the security access broker denies the request for the new expanded role at block 311. For example, the security access broker 303 would not fulfill the request if the execution counter for the serverless function instance indicates 120 executions and the expansion criterion is that executions should be equal to or less than 100. As another example, the security access broker 303 would not fulfill the request if the initial execution timestamp for the serverless function instance indicates 13:42:05.12 20200126, the current invocation has a timestamp of 03:07:26.09 20200127 and the expansion criterion is 12 hours or less.
If the expansion criterion is satisfied, then the security access broker 303 updates a database of least privilege(s) per serverless function with an additional privilege for the serverless function at block 315. The security access broker 303 accesses the database and inserts or adds indication of the privilege that would overcome the access violation.
At block 317, the security access broker destroys or deletes the previously created role (if not already expired) and creates a new least privileged role with the additional privilege. If the under-permissive role has not yet expired, the security access broker communicates with the cloud service to destroy the role and create the new expanded role. The security access broker 303 then updates the transient role structure entry corresponding to the serverless function instance to bind the new expanded role to the serverless function instance.
At block 319, the security access broker 303 sets the expiration time for the created role and updates the execution tracking data. For example, the security access broker 303 updates the transient role structure with an expiration time for the newly expanded role based on when the new role is created or communicated. If an execution counter is being used, then the security access broker 303 also updates the transient role structure by incrementing the execution counter.
At block 321, the security access broker 303 communicates the created expanded role to the runtime instrumentation 301. For example, the security access broker 303 indicates the created role identifier in the message to the runtime instrumentation 301.
At block 323, the runtime instrumentation 301 assigns the role communicated from the security access broker 303 to the serverless function instance and re-executes the serverless function. The runtime instrumentation 301 can modify code to set the created expanded, least privileged role in place of the under-permissive role that has been eliminated. The runtime instrumentation 301 may execute the serverless function with the expanded least privileged role identifier as an argument or parameter in the invocation.
At block 401, a security access broker detects a reduction evaluation trigger. The reduction evaluation trigger can be defined differently depending upon administrator preference, developer preference, cloud infrastructure constraints, or application knowledge, as examples. For instance, the reduction evaluation trigger can be periodic (e.g., every week) and/or event driven (e.g., manual command or detection of analysis results). Reduction evaluation is depending upon availability of new information. The new information can be from continuous or repeated static analysis of the serverless application code. The new information can also or instead be from analysis of an execution log(s) of the serverless application and/or cloud infrastructure supporting the serverless application.
At block 403, the security access broker begins evaluating privilege(s) of each serverless function. The evaluations involve comparing indicated least privilege(s) for a serverless function with resource accesses by the serverless function from historical executions of the serverless function instance.
At block 405, the security access broker determines resource accesses by the serverless function based on execution data in a time interval corresponding to the evaluation trigger. A time interval corresponding to the evaluation trigger may be a preceding week or quarter, or be a specific historical time period (e.g., time of a specific application event such as peak usage or a business event). The security access broker determines resources accessed by the serverless function and types of access in the time interval(s). The security access broker may organize the determines resource accesses to facilitate efficient searching and examination.
At block 407, the security access broker begins comparison of each privilege indicated for the serverless function against the determined resource accesses. The description refers to a privilege being compared in a current iteration as the “selected” privilege.
At block 409, the security access broker determines whether the serverless function utilized the selected privilege according to the determined resource accesses. The security access broker can search the resource accesses for the selected privilege. If the selected privilege was not used, then program flow continues to block 411. If the selected privilege was used by the serverless function, then program flow continues to block 413.
At block 411, the security access broker removes the selected privilege indication for the serverless function. The security access broker updates the database entry for the serverless function to remove the unused privilege. Program flow continues from block 411 to block 413.
At block 413, the security access broker determines whether there is another privilege indicated for the serverless function to evaluate. If so, program flow returns to block 407 for the security access broker to select the next privilege for evaluation. If there is not another privilege indicated, then program flow continues to block 415. At block 415, the security access broker determines whether there is another serverless function of the serverless application evaluate. If so, program flow returns to block 403 for the security access broker to select the next serverless function for evaluation. If there is not another serverless function, then program flow ends.
Variations
Embodiments of the technology are not constrained to the specific examples described herein. For example, an embodiment can expand under-permissive roles based on detection of an access violation by the security access broker instead of runtime instrumentation of a serverless function. The security access broker may have a helper thread or background process that monitors execution logs of a serverless application and/or logs of the cloud infrastructure to determine access violations by a serverless function instance. When the security access broker detects a violation in the logs, then the security access broker can update the database of least privileges accordingly. Embodiments can also employ both techniques for detecting access violations and adjusting privileges accordingly.
The flowcharts are provided to aid in understanding the illustrations and are not to be used to limit scope of the claims. The flowcharts depict example operations that can vary within the scope of the claims. Additional operations may be performed; fewer operations may be performed; the operations may be performed in parallel; and the operations may be performed in a different order. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by program code. The program code may be provided to a processor of a general purpose computer, special purpose computer, or other programmable machine or apparatus.
As will be appreciated, aspects of the disclosure may be embodied as a system, method or program code/instructions stored in one or more machine-readable media. Accordingly, aspects may take the form of hardware, software (including firmware, resident software, micro-code, etc.), or a combination of software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” The functionality presented as individual modules/units in the example illustrations can be organized differently in accordance with any one of platform (operating system and/or hardware), application ecosystem, interfaces, programmer preferences, programming language, administrator preferences, etc.
Any combination of one or more machine readable medium(s) may be utilized. The machine readable medium may be a machine readable signal medium or a machine readable storage medium. A machine readable storage medium may be, for example, but not limited to, a system, apparatus, or device, that employs any one of or combination of electronic, magnetic, optical, electromagnetic, infrared, or semiconductor technology to store program code. More specific examples (a non-exhaustive list) of the machine readable storage medium would include the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a machine readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device. A machine readable storage medium is not a machine readable signal medium.
A machine readable signal medium may include a propagated data signal with machine readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A machine readable signal medium may be any machine readable medium that is not a machine readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a machine readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
The program code/instructions may also be stored in a machine readable medium that can direct a machine to function in a particular manner, such that the instructions stored in the machine readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
Plural instances may be provided for components, operations or structures described herein as a single instance. Finally, boundaries between various components, operations and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the disclosure. In general, structures and functionality presented as separate components in the example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements may fall within the scope of the disclosure.
This description uses shorthand terms related to cloud technology for efficiency and ease of explanation. When referring to “a cloud,” this description is referring to the resources of a cloud service provider. For instance, a cloud can encompass the servers, virtual machines, and storage devices of a cloud service provider. In more general terms, a cloud service provider resource accessible to serverless function is a resource owned/manage by the cloud service provider entity that is accessible via network connections. Often, the access is in accordance with an application programming interface or software development kit provided by the cloud service provider.
Use of the phrase “at least one of” preceding a list with the conjunction “and” should not be treated as an exclusive list and should not be construed as a list of categories with one item from each category, unless specifically stated otherwise. A clause that recites “at least one of A, B, and C” can be infringed with only one of the listed items, multiple of the listed items, and one or more of the items in the list and another item not listed.
Number | Name | Date | Kind |
---|---|---|---|
7113994 | Swift | Sep 2006 | B1 |
7912971 | Dunn | Mar 2011 | B1 |
8024186 | De Bonet | Sep 2011 | B1 |
8474018 | Mardikar et al. | Jun 2013 | B2 |
10255422 | Last | Apr 2019 | B1 |
10430727 | Fusillo | Oct 2019 | B1 |
10649861 | Natanzon | May 2020 | B1 |
10671443 | Ramachandran | Jun 2020 | B1 |
10678522 | Yerramreddy | Jun 2020 | B1 |
10715542 | Wei | Jul 2020 | B1 |
10771468 | Walker et al. | Sep 2020 | B1 |
10782934 | Chawda | Sep 2020 | B1 |
10817346 | Culp | Oct 2020 | B1 |
10860433 | Lieberman | Dec 2020 | B1 |
10896060 | Sciarrino | Jan 2021 | B1 |
11057480 | Wells | Jul 2021 | B1 |
11144513 | Padisetty | Oct 2021 | B1 |
20040168082 | Foster | Aug 2004 | A1 |
20050108678 | Goodwin | May 2005 | A1 |
20060288404 | Kirshnan | Dec 2006 | A1 |
20080127292 | Cooper | May 2008 | A1 |
20080313716 | Park | Dec 2008 | A1 |
20090177721 | Mimatsu | Jul 2009 | A1 |
20090222894 | Kenny et al. | Sep 2009 | A1 |
20090249063 | Sakurai | Oct 2009 | A1 |
20110055918 | Keefe | Mar 2011 | A1 |
20110162046 | Forster et al. | Jun 2011 | A1 |
20120060142 | Fliess | Mar 2012 | A1 |
20120102539 | Robb | Apr 2012 | A1 |
20120259877 | Raghunathan | Oct 2012 | A1 |
20120324540 | Wu | Dec 2012 | A1 |
20130133024 | MacLeod | May 2013 | A1 |
20130219372 | Li | Aug 2013 | A1 |
20140282889 | Ishaya | Sep 2014 | A1 |
20140359692 | Chari et al. | Dec 2014 | A1 |
20140359695 | Chari et al. | Dec 2014 | A1 |
20150095968 | Steiner | Apr 2015 | A1 |
20170295181 | Parimi et al. | Oct 2017 | A1 |
20180113793 | Fink | Apr 2018 | A1 |
20180115551 | Cole | Apr 2018 | A1 |
20180121659 | Sawhney | May 2018 | A1 |
20180173806 | Forstmann | Jun 2018 | A1 |
20180227323 | Jevans | Aug 2018 | A1 |
20180255102 | Ward | Sep 2018 | A1 |
20180302277 | Shimamura | Oct 2018 | A1 |
20190007458 | Shulman | Jan 2019 | A1 |
20190014171 | Stein | Jan 2019 | A1 |
20190028552 | Johnson, II | Jan 2019 | A1 |
20190079744 | Bosch | Mar 2019 | A1 |
20190140913 | Guim Bernat | May 2019 | A1 |
20190188049 | Choudhary | Jun 2019 | A1 |
20190205186 | Zhang | Jul 2019 | A1 |
20190332366 | Natanzon | Oct 2019 | A1 |
20190332781 | Natanzon | Oct 2019 | A1 |
20190334886 | Lelcuk | Oct 2019 | A1 |
20190334905 | Lelcuk | Oct 2019 | A1 |
20190384726 | Murphy | Dec 2019 | A1 |
20190384912 | Branson | Dec 2019 | A1 |
20200012569 | Natanzon | Jan 2020 | A1 |
20200019471 | Natanzon | Jan 2020 | A1 |
20200026850 | Levin | Jan 2020 | A1 |
20200026865 | Hulick, Jr. | Jan 2020 | A1 |
20200089881 | Graun | Mar 2020 | A1 |
20200120112 | Cybulski | Apr 2020 | A1 |
20200175152 | Xu | Jun 2020 | A1 |
20200195645 | Wei | Jun 2020 | A1 |
20200213279 | Xiong | Jul 2020 | A1 |
20200213320 | Levin | Jul 2020 | A1 |
20200213338 | Lotem | Jul 2020 | A1 |
20200213357 | Levin | Jul 2020 | A1 |
20200225724 | Macnamara | Jul 2020 | A1 |
20200226009 | Bachmutsky | Jul 2020 | A1 |
20200241999 | Guim Bernat | Jul 2020 | A1 |
20200242237 | Simpson | Jul 2020 | A1 |
20200244692 | Shua | Jul 2020 | A1 |
20200250316 | Rickerd | Aug 2020 | A1 |
20200259865 | Raff | Aug 2020 | A1 |
20200267155 | Segal | Aug 2020 | A1 |
20200306643 | Borovikov | Oct 2020 | A1 |
20200314168 | Nauerz | Oct 2020 | A1 |
20200351345 | Bansod | Nov 2020 | A1 |
20200389401 | Enguehard | Dec 2020 | A1 |
20210036921 | dos Santos Silva | Feb 2021 | A1 |
20210075908 | Murphy | Mar 2021 | A1 |
20210099459 | Zhang | Apr 2021 | A1 |
20210117217 | Croteau | Apr 2021 | A1 |
20210117558 | Robbins | Apr 2021 | A1 |
20210126938 | Trost | Apr 2021 | A1 |
20210141670 | Yassin | May 2021 | A1 |
20210160271 | Garcarz | May 2021 | A1 |
20210184941 | Tootaghaj | Jun 2021 | A1 |
20210192586 | Gomez | Jun 2021 | A1 |
20210200527 | Sanchez | Jul 2021 | A1 |
20210200596 | Sanchez | Jul 2021 | A1 |
20210233045 | Singh | Jul 2021 | A1 |
20210243209 | Ramani | Aug 2021 | A1 |
20210294976 | Markarian | Sep 2021 | A1 |
20210326458 | Watson | Oct 2021 | A1 |
Entry |
---|
Baldini, et al., “The Serverless Trilemma: Function Composition for Serverless Computing”, Onward! The 2017 ACM SIGPLAN International Symposium on New Ideas, New Paradigms, and Reflections on programming and Software, Vancouver BC Canada, Oct. 25-27, 2017, pp. 89-103. |
Hall, et al., “An Execution Model for Severless Functions at the Edge”, IoTDI '19: International Conference on Internet of Things Design and Implementation, Montreal QC Canada, Apr. 15-18, 2019, pp. 225-236, retrieved on Apr. 17, 2020 from https://www.cc.gatech.edu/projects/up/publications/iotdi19-AdamHall.pdf. |
U.S. Appl. No. 16/024,863, Advisory Action dated Nov. 17, 2020, 6 pages. |
U.S. Appl. No. 16/024,863, Final Office Action, dated Sep. 4, 2020, 34 pages. |
U.S. Appl. No. 16/024,863 Non-Final Office Action, dated Mar. 5, 2020, 19 pages. |
U.S. Appl. No. 16/024,863, Non-Final Office Action dated Sep. 1, 2021, 33 pages. |
U.S. Appl. No. 16/024,863, Final Office Action, dated Feb. 24, 2022, 32 pages. |
Number | Date | Country | |
---|---|---|---|
20210329003 A1 | Oct 2021 | US |