Advanced Driver Assistance Systems (ADAS) are vehicle-based systems that collect information about the environment surrounding the vehicle in order to provide for the safety and comfort of the driver. The information collected may be useful to warn the driver or automatically take appropriate actions, with features such as emergency braking, collision warning, object detection, lane departure warnings, lane keeping assist systems, traffic sign recognition, self-driving, etc. The ADAS may include an electronic control unit (ECU), various systems on chips (SoCs), microcontrollers (MCUs), monolithic microwave integrated circuits (MMICs), processors, memories, data storage systems, and other components.
Testing SoCs, integrated circuits (ICs), or other systems within an ADAS is important to ensure the reliability and safety of the ADAS. System-in-loop (SIL) testing is performed to test some or all of the parts of the ADAS in operation to ensure the parts work together without fault. SIL testing is also referred to as hardware-in-loop testing or software-in-loop testing. SIL testing reduces the time and cost of testing complex systems in their actual field of use. To perform SIL testing, data is captured from sensors in a real-world environment and stored in memory. Then, the data is used in a testing environment to determine if the ADAS and its algorithms (including hardware and software aspects) are operating properly, and to determine if the ADAS has any systematic faults.
In accordance with at least one example of the description, a system includes an interface configured to communicate over a set of virtual channels. The interface is also configured to store a table containing entries that map the set of virtual channels to a set of addresses. The interface is configured to provide, using the table, a packet received via a first virtual channel of the set of virtual channels for storing at a first address of the set of addresses. The system also includes a data modification module (DMM) coupled to the interface and configured to cause the interface to modify an entry of the table.
In accordance with at least one example of the description, a system includes a playback system including a controller. The system also includes a microcontroller of an ADAS. The microcontroller includes an interface configured to communicate over a set of virtual channels. The interface is also configured to store a table containing entries that map the set of virtual channels to a set of addresses. The interface is configured to provide, using the table, a packet received via a first virtual channel of the set of virtual channels for storing at a first address of the set of addresses. The microcontroller includes DMM coupled to the interface and configured to cause the interface to modify an entry of the table.
In accordance with at least one example of the description, a method includes receiving first data at a controller of an ADAS via a first virtual channel of a camera serial interface 2 (CSI-2) data interface. The method also includes receiving second data at the controller of the ADAS via a second virtual channel of the CSI-2 data interface. The method includes storing the first data at a first address in a memory, the first address specified by the first virtual channel. The method also includes storing the second data at a second address of a control register, the control register specified by the second data. The method includes performing a test using the first data and the second data.
For a detailed description of various examples, reference will now be made to the accompanying drawings in which:
Testing SoCs, ICs, or other systems within an ADAS using SIL testing is important to ensure the reliability and safety of the ADAS. During real-world operating conditions, data samples, such as data from a radar system, are captured and processed by the ADAS. To perform SIL testing, those data samples are stored in a database and used (e.g., played back using a playback system) in an SIL testing environment. The SIL testing environment attempts to recreate the operating environment of the ADAS. As an example, SIL testing is performed at the actual performance speed in which the system is used. The SIL testing environment receives, reads, and processes the data samples at the same rates that the samples are received and processed in the real-world operating conditions, to determine if the ADAS can adequately process, manage, and react to the data samples in real time. To do this, the SIL testing environment uses the same or similar software and hardware as actually deployed in the ADAS. This may avoid the complexity of adding an additional interface such as serial peripheral interface (SPI), universal asynchronous receiver-transmitter (UART), or a joint test action group (JTAG) interface, and supporting software.
In the ADAS, a data interface known as camera serial interface 2 (CSI-2) is useful to send captured data, such as captured radar sensor data, from an MMIC to an MCU. CSI-2 is a high-speed data interface that may transmit large amounts of data. During SIL testing, it is advantageous to use CSI-2 to transmit data to the MCU of the ADAS in the testing environment, just as CSI-2 is used in the operating environment. Both un-processed and processed data may be transmitted to the MCU using CSI-2. It is also desirable to transfer other types of data, such as control data, to the MCU during SIL testing. However, the CSI-2 protocol does not natively support transmitting control data to a specific memory addresses or control register within the MCU. In some alternative systems, an interface other than the CSI-2 interface may be used to transmit captured data and other types of data to the MCU during SIL testing. However, adding an additional interface to the MCU increases the cost of the MCU.
In examples herein, a data modification module (DMM) in the MCU enables the use of the CSI-2 interface to write data to a wide range of addresses and registers throughout the MCU data in which to write data during SIL testing of the MCU. More specifically, in examples, the CSI-2 interface is used for SIL testing, along with a DMM in the MCU. The DMM, combined with the CSI-2 interface, enables access to memory as well as control registers during SIL testing of the MCU. Access to specific addresses in the MCU is enabled by using virtual channels (VCs). The CSI-2 protocol supports up to four VCs that may be used to identify different streams of data. These separate streams of data may be directed toward different destinations within the MCU using different CSI-2 VCs for each type of data. The destination could be a control register or a specific location in a memory. In various examples, one or more DMMs may direct the data to a destination via an interconnect based on the VC. Thus, DMMs and VCs may be leveraged to enable a CSI-2 interface to transmit both data and other types of information during SIL testing.
MMIC 102 may be a radar front end that sends and receives radio frequency (RF) radar signals in one example. MMIC 102 may receive the RF signals and transform them into digital signals using an analog to digital converter (ADC, not shown in
MMIC 102 may couple to MCU 104 via a CSI-2 interface 106. MCU 104 is the master control unit of ADAS 100. MCU 104 may receive un-processed data or semi-processed data and perform further processing. MCU 104 may also send raw or semi-processed data to storage and or an electronic controller unit (ECU) 108 or take appropriate actions based on the data. For example, MMIC 102 may be a radar front-end chip that sends captured raw ADC samples to the MCU 104 so that the MCU 104 may process data to determine the range, angle, and velocity of an object. In this manner, the MCU 104 may use algorithms that detect objects and determine appropriate actions based on data received from MMIC 102.
MCU 104 sends data to ECU 108 via connection 110. ECU 108 may include a combination of hardware (such as processors, controllers, data interfaces, and memory) along with software that enables ECU 108 to process data streams quickly and reliably. ECU 108 processes sensor data, interprets the sensor data, and may take actions based on the sensor data to prevent accidents or provide other safety features. Connection 110 may be any appropriate type of bus, such as an Ethernet connection or a controller area network (CAN) bus.
SIL testing system 150 supports deploying the test system with the same or similar software and hardware as actually deployed in the ADAS 100. This enables SIL testing system 150 to test ADAS 100 at the data transmission and processing speeds that ADAS encounters during real-world operation. For example, if data is transmitted to MCU 104 in ADAS 100 at 600 Megabits per second, SIL testing system 150 is able to test the system with that same throughput. CSI-2 interface 106 provides a high-speed interface to transmit data to MCU 104. Accessing control registers in MCU 104 using the CSI-2 protocol is not natively supported by the protocol. However, as described below, the VCs of CSI-2 interface 106 are useful for accessing control registers in MCU 104. A DMM in MCU 104 (not shown in
MCU 104 includes a CSI-2 interface 214 that couples the MCU 104 to the SIL testing system 200. The CSI-2 interface 214 receives data from any other CSI-2 device, such as playback system 152 or MMIC 102, using a set of virtual channels (e.g., virtual channels 212A-D). The CSI-2 interface 214 includes a virtual-channel-to-address table 216, explained in further detail below, that is used to direct communications to various locations of the MCU 104. Accordingly, the CSI-2 interface 214 is coupled to an interconnect 202 to send and receive the data to and from the various components within MCU 104.
Interconnect 202, for example, is coupled to control registers (CR) 204, data modification module (DMM) 206, and memory 208. Interconnect 202 may also be coupled to other components not shown in
DMM 206 stores control data into CR 204. DMM 206 transfers data from an external device, such as playback system 152, to CR 204 in one example. In another example, DMM 206 may perform direct writes to memory 208 without intervention of a processor in MCU 104. DMM 206 may write to locations in memory 208 specified by data packets received from an external device, and may also write data to locations in memory 208 specified by DMM 206. In some examples, the DMM 206 is separate from the CSI-2 interface 214, although in other examples, the DMM 206 is incorporated into the CSI-2 interface 214.
Interconnect 202 is coupled to CR 204 via link 210A. Interconnect is coupled to DMM 206 via link 210B. Interconnect 202 is coupled to memory 208 via link 210C. Interconnect 202 is coupled to CSI-2 interface 214 via link 218. Interconnect 202 may also couple to any other components in MCU 104 to allow communication and data transfer among the components of MCU 104.
In an example, a stream of data from an external device, such as playback system 152, is transmitted to the CSI-2 interface 214 of the MCU 104 via virtual channels 212A, 212B, 212C, and/or 212D (collectively, VCs 212) of the CSI-2 protocol. Header data transmitted to MCU 104 identifies which of the four VCs is associated with a given stream of data. VCs 212 are configured to transmit certain types of data to MCU 104. In one example, a first VC 212 sends un-processed or semi-processed captured data to MCU 104. Captured data is the data acquired by a sensor, such as MMIC 102. CSI-2 transmits the captured data at speeds used during operation of ADAS 100. A second VC 212 is configured to send a different type of data to MCU 104, such as control data that is stored in CR 204. Each VC 212, including the third and fourth VCs 212, may be used to send either captured data or control data. For example, one type of test may use one VC 212 for control data and three VCs 212 for captured data. Another type of test may use three VCs 212 for control data and one VC 212 for captured data. In some examples, some of the VCs 212 may be idle during testing. Any number or combination of VCs 212 may be used in examples herein.
When data is received, the CSI-2 interface 214 determines the virtual channel associated with the data, then using table 216, determines a destination for the data. In some examples, the destination specified by the table 216 for a given virtual channel is an address within memory (e.g., memory 208). When the destination is a memory address, the CSI-2 interface 214 may provide the data to the memory via interconnect 202. The table 216 may also map a virtual channel to a control register (e.g., control register 204). When the destination is a control register, the CSI-2 interface 214 may provide the data directly to the control register via the interconnect 202 or may provide it to another component for writing to the control register. The table 216 may also map a virtual channel to a non-memory component (e.g., DMM 206). In some examples, table 216 maps a given virtual channel to DMM 206, which is used to write data to the control registers and may also be used to update the table 216. In this way, the CSI-2 interface 214 and the DMM 206 may provide access to the complete address space of MCU 104, and may direct data to the appropriate address.
The DMM 206 receives and parses the update packet 300 and recognizes that the value of the address field 308 maps to an address of an entry in the table 216 for a particular virtual channel. The virtual channel used to send the update packet 300 may be different from the virtual channel associated with the table entry in the address field 308. For example, an update packet 300 sent via VCO may be used to update a table entry for VC1. The value in the data field 310 of the update packet 300 represents the new address to be stored in the table entry. Thus, the DMM 206 may provide the value in the data field 310 back to the CSI-2 interface for writing in the table 216 at the entry indicated by the value in the address field 308. In this way, subsequent data received via the virtual channel associated with the address field 308 of the update packet 300 is written to the address specified in the data field 310 of the update packet 300.
The playback system 152 may also provide to the MCU 104 data for writing to the memory 208 and/or control registers 204. In particular, the playback system 152 may provide a packet for writing to the control registers 204 using a virtual channel mapped to the DMM 206. The packet is received by the CSI-2 interface 214, which determines, based on the virtual channel and table 216, that the destination is the DMM 206 and forwards the update packet 300 to the DMM 206 via the interconnect 202. The packet 300 may include control information and the address of the particular CR 204 to which the control information should be written. DMM 206 parses the data received via the packet 300 and writes the control information to the correct CR 204, based on the address included with the control information. In this example, one VC 212 may be dedicated to sending control information to CR 204 via DMM 206, while one or more of the other three VCs 212 are dedicated to sending captured data to memory 208. DMM 206 stores the control information in the correct CR 204 using the address information included with the control information, and the captured data is stored in memory 208.
In another example, a test may be performed to test the algorithms in ADAS 100 using the captured data stored in playback system 152. Algorithms in ADAS 100 are used to process radar data collected by MMIC 102. Radar data is collected by a radar sensor such as MMIC 102 and then processing is performed on the radar data. First dimension, second dimension, and third dimension FFTs may be performed on the radar data to produce FFT data and determine the range, velocity, and angle of the radar data. The range indicates the distance of an object from the radar sensor. The velocity indicates the speed of approach of the object, and the angle indicates the angle of the object to the radar sensor. Classification algorithms in ADAS 100 use the range, velocity, and angle data produced by performing one or more FFTs to determine whether the object is a person, vehicle, obstruction, etc. Then, based on the results of the classification algorithm, an appropriate action may be taken, such as providing a warning to the driver or applying emergency braking.
The radar data is transmitted to memory 208 via one or more VCs 212. The VC 212 that is used indicates the address in memory 208 where the specific radar data should be written. For example, data from a first VC 212 may be stored beginning at a first location in memory 208, while data from a second VC 212 may be stored beginning at a second location in memory 208. During operation, the algorithms that provide the driver assistance services in ADAS 100 expect certain types of data to be located in certain addresses in memory 208. If the correct and expected data is written to those locations in memory 208, the algorithms retrieve the correct data from the expected locations in memory 208 and process the data. Then, an appropriate action may be taken by the algorithms based on the results of processing the data. The algorithms used in SIL testing system 200 are the same algorithms used when ADAS 100 is deployed in real-world operating conditions. Therefore, SIL testing system 200 allows the algorithms in ADAS 100 to be tested in similar operating conditions to a real-world ADAS deployment. These operating conditions include transmitting captured data at a high speed using the CSI-2 protocol.
As noted above, data transmitted over a VC 212 may be sent directly to an address in memory 208 with or without the use of DMM 206. Thus, in some examples, the CSI-2 interface 214 is configured to send the data to the address in memory 208 where the captured data should be stored via the interconnect 202. In this example, interconnect 202 directs the data to memory 208, where the captured data is stored in the proper location in memory 208. In another example, data may be transmitted from the CSI-2 interface 214 to DMM 206, and DMM 206 then transmits the data to memory 208.
In some examples, different types of data may be written to different locations in memory 208. For example, un-processed data captured by MMIC 102 may be written to a first address, while processed or semi-processed data from MMIC 102 may be written to a second address. To change the address indicated by VC 212A to which the data is to be written, playback system 152 can send a command through VC 212A to update a base address that indicates where VC 212A is to send data. Therefore, examples herein allow data to be written to any address in memory 208 or in CR 204.
Data transmitted over VCs 212 may indicate the size of the data to be stored as well as the address to which the data is to be stored. For example, the size of the data may be byte, word, double-word, 64-bit, etc. DMM 206 parses the size and the address information found in header data to store the captured data to the appropriate location in memory 208 or CR 204. DMM 206 issues an appropriate command to write the captured data to the appropriate address, and the command may include the size of the captured data as well. As one example, DMM 206 may issue a word-write command to indicate that the captured data is word sized. If the captured data is double-word sized, DMM 206 may issue a double-word-write command. Other data sizes and other write commands may be used in other examples.
Method 400 begins at 410, where a controller of an ADAS, such as MCU 104, receives first data via a first virtual channel of a CSI-2 data interface. As described in
Method 400 continues at 420, where a controller of the ADAS, such as MCU 104, receives second data via a second virtual channel of the CSI-2 data interface. A VC such as VC 212B may be used to transmit the second data. Transmitting different types of data over different VCs 212 allows for MCU 104 to handle the data from different VCs in a different manner. Data from different VCs may be stored in different locations or directed to different components within MCU 104.
Method 400 continues at 430, where MCU 104 stores the first data at a first address in a memory, where the first address is specified by the first virtual channel. The memory may be a memory such as memory 208. In an example, the first virtual channel stores the data directly to the correct address in memory 208. In another example, DMM 206 may store the captured data in memory 208.
Method 400 continues at 440, where MCU 104 stores the second data in a control register, where the control register is specified by the second data. As described above, DMM 206 may receive the second data via a second VC 212B, and DMM 206 may read an address included with the second data that indicates where the second data should be stored. DMM 206 has access to CR 204 in MCU 104, and may write control data into any control register of CR 204.
Method 400 continues at step 450, where a test is performed on MCU 104 using the first data and the second data. Therefore, using this technique, control data from playback system 152 may be transmitted to MCU 104 using the CSI-2 protocol, and DMM 206 may store the control data in the appropriate control register of CR 204. In addition, the CSI-2 protocol allows for high speed transfer of captured data, such as radar data, so that SIL testing may be performed in conditions that mimic the real-world operating conditions of ADAS 100.
Method 500 begins at 510, where an MCU 104 receives a VC mapping update packet. The VC mapping update packet specifies a new destination, such as an address or entity within the MCU 104 to associate with a given virtual channel. In some examples, the VC mapping update packet 300 includes an address field 308 that specifies a table entry associated with the given virtual channel and a data field 310 that specifies the new destination. The VC mapping update packet is sent via a virtual channel 212 associated with a DMM 206 of the MCU 104 and is received by a CSI-2 interface 214 of the MCU 104.
Method 500 continues at 520, where the CSI-2 interface 214 determines, based on the virtual channel 212 and a current virtual-channel-to-address table 216, that the destination is the DMM 206 and forwards the update packet 300 to the DMM 206.
Method 500 continues at 530, where the DMM 206 receives and parses the update packet 300 and recognizes that the value of the address field 308 maps to an entry in the virtual-channel-to-address table 216 for the given virtual channel 212.
Method 500 continues at 540, where the DMM 206 provides the value in the data field 310, which represents the new destination, to the CSI-2 interface 214 for writing in the virtual-channel-to-address table 216. At 550, the virtual-channel-to-address table is updated. In this way, subsequent data received via the virtual channel 212 associated with the address field 308 of the update packet 300 is written to the address specified in the data field 310 of the update packet 300. In examples herein, the same CSI-2 interface on MCU 104 that sends sensor data to MCU 104 during operation of ADAS 100 is also used to send captured data and control information to MCU 104 during SIL testing. Using the same CSI-2 interface for both applications saves the cost of adding an additional interface to MCU 104. Also, using the same CSI-2 interface during SIL testing enables SIL testing to more closely re-create the actual real-world operating conditions of ADAS 100, such as the speed that sensor data is transmitted to MCU 104.
The term “couple” is used throughout the specification. The term may cover connections, communications, or signal paths that enable a functional relationship consistent with this description. For example, if device A generates a signal to control device B to perform an action, in a first example device A is coupled to device B, or in a second example device A is coupled to device B through intervening component C if intervening component C does not substantially alter the functional relationship between device A and device B such that device B is controlled by device A via the control signal generated by device A.
A device that is “configured to” perform a task or function may be configured (e.g., programmed and/or hardwired) at a time of manufacturing by a manufacturer to perform the function and/or may be configurable (or re-configurable) by a user after manufacturing to perform the function and/or other additional or alternative functions. The configuring may be through firmware and/or software programming of the device, through a construction and/or layout of hardware components and interconnections of the device, or a combination thereof.
Unless otherwise stated, “about,” “approximately,” or “substantially” preceding a value means +/−10 percent of the stated value. Modifications are possible in the described examples, and other examples are possible within the scope of the claims.
The present application claims priority to U.S. Provisional Patent Application No. 62/985,445, which was filed Mar. 5, 2020, is titled “System-In-Loop Testing For ADAS SoCs,” and is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62985445 | Mar 2020 | US |