# NDIA Automatic Test Committee Project Report

September 10, 2017 Renaissance Schaumburg ATC17



- Two projects identified by US Government ATS leadership for industry investigation
  - FPGA Test and Support
  - Standardized Software Architecture for Synthetic Instrumentation

# **FPGA Test & Support Background**

### • Issues include:

- Multiple manufacturers, each with their own sets of development tools.
- Programming data not consistent between manufacturers for the same functionality.
- Where to put the emphasis in FPGA test? TPS or ATE or somewhere in between? How do we control the interface boundaries between vendor, ATE, and TPS programming?
- No DoD standards or programming style preferences. This can lead to portability problems and obsolescence issues.

# **FPGA Test & Support Project**

### • Group Leader: Mike Dewey

- Group members from industry, US Navy, US Army and US Air Force
- Meeting monthly via telecon
- **Objective:** Define Goals via SOW & Develop Recommendations and Guidelines
- Status:

1) SOW created and approved by NDIA ATS committee

2) Recommendations & Guidelines created & delivered

• Next Step: Receive feedback from NDIA ATS committee

## **FPGA Test & Support Project SOW**

Statement of Work – NDIA ATC Project Incorporating User Programmable FPGA Designs into ATS Applications – Recommendations and Guidelines

I.

Prepared by: Revision: Revision Date: Mike Dewey, Carl Heide, Pat Griffin, additions from RWL & JRB R4 3/28/2017

Purpose

This statement of work defines the framework / outline for the creation of a document that will provide recommendations / guidelines when incorporating user programmable" or "user-defined" Field Programmable Gate Array (FPGA) devices / designs into an Automatic Test Bystem (ATB), in addition, the document will provide guidelines / recommendations regarding the adoption / feasibility of user defined FPGAs for ATB applications. In this community the ATB includes the Automatic Test Equipment (ATE), Test Program Bet (TPB), interface Test Adapter (ITA) applications, and documentation.

The purpose of the resulting document is to provide developers of test systems and test programs that employ user-programmable FPGA devices and modules, guidelines regarding the use of user programmable FPGAs as well as facilitating maintainability and extended life cycle management of both systems and test programs. This statement of work details the targeted audience, what will be addressed, what will not be addressed, and an overall timeframe for completion of the final document.

#### 1. Targeted Audience

- Suppliers of test systems / applications to the DoD services that incorporate userprogrammable FGPA devices and modules that are incorporated into a test system's instrumentation, ITAs and associated test programs
- Test engineering managers and test engineers developing test programs that include user-programmable FPGA devices and modules as a component of a test program or test system
- Personnel associated with contracting and/or acquiring ATS equipment and applications that may incorporate user programmable FPGA devices and modules
- Standards organizations e.g. IEEE, VXI P&P, etc., should the resulting document be managed and adopted by one of these standards organizations

#### What will be addressed in the document

- Best practices for ensuring long term and organic support for test systems and applications that employ user-programmable FPGA devices and modules
- Use of user-programmable FPGA device and module design tools that promote long term sustainability.
- Use of intellectual Property (IP) and associated data rights that will promote organic support and long term sustainability of test systems that employ user-programmable FPGA devices and modules.
- 4. Configuration management / documentation methods for user-defined FPGA applications
- Use of user-programmable FPGA devices and modules in conjunction with test programs and associated ITAs
- Identity and define the use of standardized interfaces that communicate and control IP that is
  part of an FPGA device or module in order to facilitate organic / long term support of test
  systems that employ FPGA-based designs as well as facilitating the use of FPGAs from
  various vendors
- Define a standardized policy for sustaining designs / TPS that employ user-programmable FPGA devices and modules.

#### Statement of Work – NDIA ATC Project

Incorporating User Programmable FPGA Designs into ATS

- Applications Recommendations and Guidelines
- Identity / define the use of IEEE standards for configuring / programming of userprogrammable FPGA devices and modules
- Investigate the feasibility of transitioning this document to an open, industry standard which can be managed by an industry standards group.

#### 3. What will not be addressed in the document

- Cyber security management as it relates to user programmable FPGAs. It is acknowledged that the use of programmable devices including FPGAs represents a cyber security threat which can be susceptible to malware and viruses. However, addressing cyber security as part of this current effort is a topic best addressed as part of a future project that can encompass all potential cyber threat avenues – test programs, programmable devices, network connections, etc.
- Instrumentation or test systems that employ FPGAs which are non-accessible by the end user. Virtually all instruments and test systems are now including programmable devices. However, the task for this project needs to be focused on addressing those applications that employ "user programmable" FPGA devices. FPGA devices that cannot be accessed / programmed by the end user are not part of this effort.

#### 4. Proposed timeline for this project

The estimated timeline for this project is as follows:

- Initial BOW creation and review by the project working group: End of January 2017
- Updates to SOW and submission to NDIA ATC for review and agreement: End of February 2017
- Development of document: March June 2017
- Review and updates: July 2017
- Final review and release of document by NDIA ATC: August 2017

#### End of SOW

## **FPGA Test & Support Project**

### **Recommendations & Guidelines**

| 1. Introductio                                                                                         | n                                                                                                                                                                                                                                                                                        | 4        |
|--------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| 1.1                                                                                                    | Scope                                                                                                                                                                                                                                                                                    |          |
| 1.2                                                                                                    | Intended Audience                                                                                                                                                                                                                                                                        | 5        |
| 1.3                                                                                                    | Terminology                                                                                                                                                                                                                                                                              |          |
| 1.4                                                                                                    | Applicable Documents                                                                                                                                                                                                                                                                     |          |
| 2. User-Progra                                                                                         | mmable FPGA Devices and Modules - Overview                                                                                                                                                                                                                                               | 8        |
| 2.1                                                                                                    | What is an FPGA?                                                                                                                                                                                                                                                                         |          |
| 2.2                                                                                                    | Reconfigurable Hardware Architecture                                                                                                                                                                                                                                                     |          |
| 2.3                                                                                                    | Reconfigurable Hardware Advantages                                                                                                                                                                                                                                                       |          |
| 2.4                                                                                                    | Summary                                                                                                                                                                                                                                                                                  |          |
| Use Feasil<br>4. Overview of                                                                           | a User-Programmable FPGA Design – Requirements Val<br>pility<br>Design Tools & Methods                                                                                                                                                                                                   | 1:<br>1: |
| Use Feasil<br>4. Overview of                                                                           | Design Tools & Methods                                                                                                                                                                                                                                                                   | 13       |
| Use Feasil                                                                                             | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design                                                                                                                                                                                                          |          |
| Use Feasil<br>4. Overview of<br>4.1                                                                    | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design<br>Design Tool Options / Methodologies                                                                                                                                                                   | 13<br>   |
| Use Feasil<br>4. Overview of<br>4.1<br>4.2                                                             | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design                                                                                                                                                                                                          |          |
| Use Feasil<br>4. Overview of<br>4.1<br>4.2<br>4.3<br>4.4                                               | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design<br>Design Tool Options / Methodologies<br>Use of High Level, Vendor Specific Tools – Considerations                                                                                                      |          |
| Use Feasil<br>4. Overview of<br>4.1<br>4.2<br>4.3<br>4.4<br>5. Recomme                                 | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design<br>Design Tool Options / Methodologies<br>Use of High Level, Vendor Specific Tools – Considerations<br>Programming                                                                                       | 13       |
| Use Feasil<br>4. Overview of<br>4.1<br>4.2<br>4.3<br>4.4<br>5. Recomme<br>6. Control an                | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design<br>Design Tool Options / Methodologies<br>Use of High Level, Vendor Specific Tools – Considerations<br>Programming                                                                                       |          |
| Use Feasil<br>4. Overview of<br>4.1<br>4.2<br>4.3<br>4.4<br>5. Recomme<br>6. Control an<br>7. Programm | Design Tools & Methods<br>Design Process Overview – Creating a User FPGA Design<br>Design Tool Options / Methodologies<br>Use of High Level, Vendor Specific Tools – Considerations<br>Programming<br>ndations for Design Tools and Standards<br>d Programmatic Interface for User FPGAs |          |

### **FPGA Test & Support Project** Recommendations & Guidelines

Appendix A maps the SOW's Section 2 items to the applicable sections in this document. The purpose of this section is to ensure that this document addresses the key areas Identified as requirements in the SOW.

| SOW Requirement                                 | Referenced Section in FPGA                    |
|-------------------------------------------------|-----------------------------------------------|
|                                                 | <b>Recommendations Document</b>               |
| Best practices for ensuring long term and       | Section 5                                     |
| organic support for test systems and            |                                               |
| applications that employ user-programmable      |                                               |
| FPGA devices and modules                        |                                               |
| Use of user-programmable FPGA device and        | Section 5                                     |
| module design tools that promote long term      |                                               |
| sustainability.                                 |                                               |
| Use of Intellectual Property (IP) and           | Section 9                                     |
| associated data rights that will promote        |                                               |
| organic support and long term sustainability of |                                               |
| test systems that employ user-programmable      |                                               |
| FPGA devices and modules.                       |                                               |
| Configuration management / documentation        | Section 8                                     |
| methods for user-defined FPGA applications      |                                               |
| Use of user-programmable FPGA devices and       | Sections 2, 3 & 4                             |
| modules in conjunction with test programs and   |                                               |
| associated ITAs                                 |                                               |
| Identify and define the use of standardized     | Section 6                                     |
| interfaces that communicate and control IP      |                                               |
| that is part of an FPGA device or module in     |                                               |
| order to facilitate organic / long term support |                                               |
| of test systems that employ FPGA-based          |                                               |
| designs as well as facilitating the use of      |                                               |
| FPGAs from various vendors                      |                                               |
| Define a standardized policy for sustaining     | Not addressed. Definition of a policy or      |
| designs / TPS that employ user-programmable     | standard goes beyond the scope of this        |
| FPGA devices and modules                        | document which is to provide                  |
|                                                 | recommendations and guidelines. We would      |
|                                                 | suggest that based on this document, the NDIA |
|                                                 | ATS group can decide if a policy / standard   |
|                                                 | should be established that addresses the      |
|                                                 | incorporation of user FPGAs as part of a TPS  |
|                                                 | or ATE system.                                |

## Standardized Software Architecture for Synthetic Instrumentation

- This is not a new project but has come back to the committee as something we should explore.
- Originally was examined in 2014. Wade Lowdermilk and Dave Carey presented Trade Study.
- ATS chair asked DoD attendees to discuss the need for this project at the next AMB and NxTest IPT meetings. Howard will report on this activity.
- Lead for project Mike Seavey
- Will need to establish a team if Howard reports specific requests from AMB and NxTest IPT.