1 2 3 4 UNITED STATES DISTRICT COURT FOR THE WESTERN DISTRICT OF WASHINGTON 5 6 **ALTAIR LOGIX LLC,** Case No. 19-cv-1933 7 Plaintiff, 8 COMPLAINT FOR PATENT V. **INFRINGEMENT** 9 PHYTEC AMERICA L.L.C., DEMAND FOR JURY TRIAL 10 Defendant. 11 Plaintiff Altair Logix LLC files this Original Complaint for Patent Infringement 12 against Phytec America L.L.C., and would respectfully show the Court as follows: 13 I. NATURE OF THE LAWSUIT 14 15 1. This is an action for patent infringement under the Patent Laws of the United 16 States, Title 35 United States Code ("U.S.C.") resulting from Phytec America L.L.C. 17 infringing, in an illegal and unauthorized manner and without authorization and/or consent 18 from Altair Logix LLC, United States Patent No. 6,289,434 pursuant to 35 U.S.C. §271, and 19 to recover damages, attorney's fees, and costs. 20 II. THE PARTIES 21 2. Plaintiff Altair Logix LLC ("Altair Logix" or "Plaintiff") is a Texas limited 22 23 liability company with its principal place of business at 15922 Eldorado Pkwy, Suite 500 24 #1513, Frisco, TX 75035. 25 3. On information and belief, Defendant Phytec America L.L.C. ("Defendant") 26 is a limited liability company organized and existing under the laws of Washington with a 27 place of business at 203 Parfitt Way SW Ste 100, Bainbridge Island, WA, 98110. 28 COMPLAINT - 1

MANN LAW GROUP PLLC 107 Spring St. Seattle, WA 98104 TELEPHONE: 206 436-0900

6

7

5

8 9

10 11

12 13

14 15

16

17

18 19

20

21 22

23

24 25

26

27

28

Defendant's registered agent is Thomas L. Walker, 5225 Taylor Ave NE, Bainbridge Island, WA, 98110.

#### **III.JURISDICTION AND VENUE**

- 4. This action arises under the patent laws of the United States, Title 35 of the United States Code. This Court has subject matter jurisdiction of such action under 28 U.S.C. §§ 1331 and 1338(a).
- 5. On information and belief, Defendant is subject to this Court's specific and general personal jurisdiction, pursuant to due process and the Washington Long-Arm Statute, due at least to its business in this forum, including at least a portion of the infringements alleged herein. Furthermore, Defendant is subject to this Court's specific and general personal jurisdiction because Defendant is a Washington limited liability company.
- 6. Without limitation, on information and belief, within this State and this District, Defendant has used, sold, and/or offered for sale the patented inventions thereby committing, and continuing to commit, acts of patent infringement alleged herein. In addition, on information and belief, Defendant has derived revenues from its infringing acts occurring within Washington and the Western District of Washington. information and belief, Defendant is subject to the Court's general jurisdiction, including from regularly doing or soliciting business, engaging in other persistent courses of conduct, and deriving substantial revenue from goods and services provided to persons or entities in Washington and the Western District of Washington. Further, on information and belief, Defendant is subject to the Court's personal jurisdiction at least due to its sale of products and/or services within Washington and the Western District of Washington. Defendant has committed such purposeful acts and/or transactions in Washington and the Western District

of Washington such that it reasonably should know and expect that it could be haled into this Court as a consequence of such activity.

- 7. Venue is proper in this district under 28 U.S.C. § 1400(b). On information and belief, Defendant is incorporated in Washington and the Western District of Washington. Under the patent laws, because Defendant was formed in Washington and the Western District of Washington, Washington. On information and belief, from and within this District Defendant has committed at least a portion of the infringements at issue in this case and has a business location within this District.
- 8. For these reasons, personal jurisdiction exists and venue is proper in this Court under 28 U.S.C. § 1400(b).

# IV.<u>COUNT I</u> (PATENT INFRINGEMENT OF UNITED STATES PATENT NO. 6,289,434)

- 9. Plaintiff incorporates the above paragraphs herein by reference.
- 10. On September 11, 2001, United States Patent No. 6,289,434 ("the '434 Patent") was duly and legally issued by the United States Patent and Trademark Office. The application leading to the '434 patent was filed on February 27, 1998. (Ex. A at cover).
- 11. The '434 Patent is titled "Apparatus and Method of Implementing Systems on Silicon Using Dynamic-Adaptive Run-Time Reconfigurable Circuits for Processing Multiple, Independent Data and Control Streams of Varying Rates." A true and correct copy of the '434 Patent is attached hereto as Exhibit A and incorporated herein by reference.
- 12. Plaintiff is the assignee of all right, title and interest in the '434 patent, including all rights to enforce and prosecute actions for infringement and to collect damages for all relevant times against infringers of the '434 Patent. Accordingly, Plaintiff possesses

the exclusive right and standing to prosecute the present action for infringement of the '434 Patent by Defendant.

- dynamic-adaptive digital circuits which can implement a myriad of digital processing functions related to systems control, digital signal processing, communications, image processing, speech and voice recognition or synthesis, three-dimensional graphics rendering, and video processing. (Ex. A at col. 1:32-38). The object of the invention is to provide a new method and apparatus for implementing systems on silicon or other chip material which will enable the user a means for achieving the performance of fixed-function implementations at a lower cost. (*Id.* at col. 2:64 col. 3:1).
- 14. The most common method of implementing various functions on an integrated circuit is by specifically designing the function or functions to be performed by placing on silicon an interconnected group of digital circuits in a non-modifiable manner (hard-wired or fixed function implementation). (*Id.* at col. 1:42-47). These circuits are designed to provide the fastest possible operation of the circuit in the least amount of silicon area. (*Id.* at col. 1:47-49). In general, these circuits are made up of an interconnection of various amounts of random-access memory and logic circuits. (*Id.* at col. 1:49-51). Complex systems on silicon are broken up into separate blocks and each block is designed separately to only perform the function that it was intended to do. (*Id.* at col. 1:51-54). Each block has to be individually tested and validated, and then the whole system has to be tested to make sure that the constituent parts work together. (*Id.* at col. 1:54-56). This process is becoming increasingly complex as we move into future generations of single-chip system implementations. (*Id.* at col. 1:57-59). Systems implemented in this way generally tend to be the highest performing systems since each block in the system has been

individually tuned to provide the expected level of performance. (*Id.* at col. 1:59-62). This method of implementation may be the smallest (cheapest in terms of silicon area) method when compared to three other distinct ways of implementing such systems. (*Id.* at col. 1:62-65). Each of the other three have their problems and generally do not tend to be the most cost-effective solution. (*Id.* at col. 1:65-67).

- 15. The first way is implemented in software using a microprocessor and associated computing system, which can be used to functionally implement any system. (*Id.* at col. 2:1-2). However, such systems would not be able to deliver real-time performance in a cost-effective manner for the class of applications that was described above. (*Id.* at col. 2:3-5). Their use is best for modeling the subsequent hard-wired/fixed-function system before considerable design effort is put into the system design. (*Id.* at col. 2:5-8).
- 16. The second way of implementing such systems is by using an ordinary digital signal processor (DSP). (*Id.* at col. 2:9-10). This class of computing machines is useful for real-time processing of certain speech, audio, video and image processing problems and in certain control functions. (*Id.* at col. 2:10-13). However, they are not cost-effective when it comes to performing certain real time tasks which do not have a high degree of parallelism in them or tasks that require multiple parallel threads of operation such as three-dimensional graphics. (*Id.* at col. 2:13-17).
- 17. The third way of implementing such systems is by using field programmable gate arrays (FPGA). (*Id.* at col. 2:18-19). These devices are made up of a two-dimensional array of fine grained logic and storage elements which can be connected together in the field by downloading a configuration stream which essentially routes signals between these elements. (*Id.* at col. 2:19-23). This routing of the data is performed by pass-transistor

logic. (*Id.* at col. 2:24-25). FPGAs are by far the most flexible of the three methods mentioned. (*Id.* at col. 2:25-26). The problem with trying to implement complex real-time systems with FPGAs is that although there is a greater flexibility for optimizing the silicon usage in such devices, the designer has to trade it off for increase in cost and decrease in performance. (*Id.* at col. 2:26-30). The performance may (in some cases) be increased considerably at a significant cost, but still would not match the performance of hard-wired fixed function devices. (*Id.* at col. 2:30-33).

- 18. These three ways do not reduce the cost or increase the performance over fixed-function systems. (*Id.* at col. 2:35-37). In terms of performance, fixed-function systems still outperform the three ways for the same cost. (*Id.* at col. 2:37-39).
- 19. The three systems can theoretically reduce cost by removing redundancy from the system. (*Id.* at col. 2:40-41). Redundancy is removed by re-using computational blocks and memory. (*Id.* at col. 2:41-42). The only problem is that these systems themselves are increasingly complex, and therefore, their computational density when compared with fixed-function devices is very high. (*Id.* at col. 2:42-45).
- 20. Most systems on silicon are built up of complex blocks of functions that have varying data bandwidth and computational requirements. (*Id.* at col. 2:46-48). As data and control information moves through the system, the processing bandwidth varies enormously. (*Id.* at col. 2:48-50). Regardless of the fact that the bandwidth varies, fixed-function systems have logic blocks that exhibit a "temporal redundancy" that can be exploited to drastically reduce the cost of the system. (*Id.* at col. 2:50-53). This is true, because in fixed function implementations all possible functional requirements of the necessary data processing must be implemented on the silicon regardless of the final application of the device or the nature of the data to be processed. (*Id.* at col. 2:53-57).

Therefore, if a fixed function device must adaptively process data, then it must commit silicon resources to process all possible flavors of the data. (*Id.* at col. 2:58-60). Furthermore, state-variable storage in all fixed function systems are implemented using area inefficient storage elements such as latches and flip-flops. (*Id.* at col. 2:60-63).

- 21. The inventors therefore sought to provide a new apparatus for implementing systems on a chip that will enable the user to achieve performance of fixed-function implementation at a lower cost. (*Id.* at col. 2:64 col. 3:1). The lower cost is achieved by removing redundancy from the system. (*Id.* at col. 3:1-2). The redundancy is removed by re-using groups of computational and storage elements in different configurations. (*Id.* at col. 3:2-4). The cost is further reduced by employing only static or dynamic ram as a means for holding the state of the system. (*Id.* at col. 3:4-6). This invention provides a way for effectively adapting the configuration of the circuit to varying input data and processing requirements. (*Id.* at col. 3:6-8). All of this reconfiguration can take place dynamically in run-time without any degradation of performance over fixed-function implementations. (*Id.* at col. 3:8-11).
- 22. The present invention is therefore an apparatus for adaptively dynamically reconfiguring groups of computations and storage elements in run-time to process multiple separate streams of data and control at varying rates. (*Id.* at col. 3:14-18). The '434 patent refers to the aggregate of the dynamically reconfigurable computational and storage elements as a "media processing unit."
- 23. The claimed apparatus has addressable memory for storing data and a plurality of instructions that can be provided through a plurality of inputs/outputs that is couple to the input/output of a plurality of media processing units. (*Id.* at col. 55:21-30). The media processing unit comprises a multiplier, an arithmetic unit, and arithmetic logic

### Case 3:19-cv-06142-JRC Document 1 Filed 11/26/19 Page 8 of 29

| 1  | unit and a |
|----|------------|
| 2  | examples   |
| 3  | (multiplie |
| 4  |            |
| 5  | 17:10 – c  |
| 6  | media pro  |
| 7  | unit inpu  |
| 8  | (Id. at co |
| 9  | operating  |
| 10 | And the b  |
| 11 | logic uni  |
| 12 | _          |
| 13 | Each of t  |
| 14 | simultane  |
| 15 | (Id. at co |
| 16 | instructio |
| 17 | produce a  |
| 18 | 56:26-33)  |
| 19 | 2/         |
| 20 | 22         |
| 21 | the '434 p |
| 22 |            |
| 23 |            |
| 24 |            |
|    |            |

| unit and a bit manipulation unit. ( <i>Id.</i> at col. $55:31 - col. 56:20$ ). The '434 patent provides |
|---------------------------------------------------------------------------------------------------------|
| examples to explain each of the parts of the media processing unit. (Id. at col. 16:27-61               |
| (multiplier and adder); id. at col. 16:62 - col. 17:1-9 (arithmetic logic unit); and id. at col.        |
| 17:10 – col. 17:43 (bit manipulation unit)). Each of the parts has a data input coupled to the          |
| media processing unit input/output, an instruction input coupled to the mediate processing              |
| unit input/output, and a data output coupled to the mediate processing unit input/output.               |
| (Id. at col. 55:31 - col. 56:20). Furthermore, the arithmetic logic unit must be capable of             |
| operating concurrently with either the multiplier and arithmetic unit. (Id. at col. 56:6-12).           |
| And the bit manipulation unit must be capable of operating concurrently with the arithmetic             |
| logic unit and at least either the multiplier or the arithmetic unit. (Id. at col. 56:13-20).           |
| Each of the plurality of media processing units must be capable of performing an operating              |
| simultaneously with the performance of other operations by other media processing units.                |
| (Id. at col. 56:21-24). An operation comprises the media processing unit receiving an                   |
| instruction and data from memory, processing the data responsive to the instruction to                  |
| produce a result, and providing the result to the media processor input/output. (Id. at col.            |
| 56:26-33).                                                                                              |

An exemplary block diagram of the claimed systems is shown in Figure 3 of 4. patent:

25

26 27



(*Id.* at Fig. 3). Exemplary architecture and coding for the apparatus is disclosed in the '599 patent. (*E.g.*, *id.* at col. 16:15 - col. 52:20; Figs. 9 - 106).

- 25. As further demonstrated by the prosecution history of the '434 patent, the claimed invention in the '434 patent was unconventional. Claim 1 of the '434 patent was an originally filed claim that issued without any amendment. There was no rejection in the prosecution history contending that claim 1 was anticipated by any prior art.
- 26. A key element behind the invention is one of reconfigurability and reusability. (*Id.* at col. 13:26-27). Each apparatus is therefore made up of very high-speed core elements that on a pipelined basis can be configured to form a more complex function. (*Id.* at col. 13:27-30). This leads to a lower gate count, thereby giving a smaller die size and ultimately a lower cost. (*Id.* at col. 13:30-31). Since the apparatuses are virtually identical to each other, writing software becomes very easy. (*Id.* at col. 13:32-33). The RISC-like

nature of each of the media processing units also allows for a consistent hardware platform for simple operating system and driver development. (*Id.* at col. 13:33-36). Any one of the media processing units can take on a supervisory role and act as a central controller if necessary. (*Id.* at col. 13:36-37). This can be very useful in set top applications where a controlling CPU may not be necessary, further reducing system cost. (*Id.* at col. 13:37-40). The claimed apparatus is therefore an unconventional way of implementing processors that can achieve the performance of fixed-function implementations at a lower cost. (*Id.* at col. 2:64 – col. 3:11).

Direct Infringement. Upon information and belief, Defendant has been directly infringing claim of the '434 patent in Washington and the Western District of Washington, and elsewhere in the United States, by making, using, selling, and/or offering for sale an apparatus for processing data for media processing that satisfies each and every limitation of claim 1, including without limitation the phyFLEX-i.MX6 SOM ("Accused Instrumentality").

https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-

microcontrollers/arm-based-processors-and-mcus/i.mx-applications-processors/i.mx-6-

processors/i.mx-6quad-processors-high-performance-3d-graphics-hd-video-arm-cortex-a9-

2 core:i.MX6Q).

modules/phyflex/i.mx6/;

28. The Accused Instrumentality comprises an addressable memory (e.g., memory system of the accused product) for storing the data, and a plurality of instructions, and having a plurality of input/outputs, each said input/output for providing and receiving at least one selected from the data and the instructions. As shown below, the accused product comprises a memory system which is coupled to multicore ARM processors through

https://www.nxp.com/products/processors-and-

multiple internal inputs/outputs. The memory system provides instructions and stored data for processing and receives processed data.





Contact us to learn more

Get A Quote



Call 1-800-278-9913 to talk to a technical sales engineer

The phyFLEX-i.MX6 SOM supports the Freescale™ i.MX6 Solo, i.MX6 Dual, and i.MX6 Quad application processors offering a broad range of solutions with emphasis from cost-efficiency to high demand performance at low power. The three innovative SOM interconnects provide standardization across the phyFLEX product family and highlight features such as 64-bit DDR3, USB, Gigabit Ethernet, integrated FlexCAN and MLB busses, PCIe, SATA-II, multiple simultaneous displays, camera interface, and HDMI v1.4.

(E.g., https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-onmodules/phyflex/i.mx6/).

**SOM Highlights** 

i.MX6 Single, Dual, Quad core

VPU, IPUv3H, GPU2Dv2, OpenVG 1.2

Up to 4 GB DDR3 / 16 GB NAND

Up to 1.2 GHz / core

USB 2.0 OTG and Host

CAN, UART, SPI, I2C, I2S

Up to 4 displays + HDMI

Linux and Compact 7 BSPs

SD/SDIO/MMC

PCIe, SATA II

Camera interface

View all specs

| 70 mm         |       |
|---------------|-------|
| PHYTEC 1352.6 | 60 mm |
|               |       |

(e.g., https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-onmodules/phyflex/i.mx6/).

29. The accused product comprises a plurality of media processing units (e.g., ARM cortex A9 Dual/Quad Core processors), each media processing unit having an input/output coupled to at least one of the addressable memory input/outputs. As shown below, the accused product comprises ARM cortex A9 Dual/Quad Core processors, each processor comprises a NEON media coprocessor and acts as a media processing unit. The ARM processors are coupled to the memory system. The processors receive instructions and data from the memory system by multiple internal inputs and provides processed data to the memory system by multiple internal outputs.

2

3

5

67

8

9

11

12

1314

15

16

17

18

19

2021

22

2324

25

2627

28

Memory

DDR

2x32 LP-DDR2, 1x64 DDR3 / LV-DDR3

NAND

SLC/MLC, 40-bit ECC, ONFI2.2, DDR

(e.g., <a href="https://www.nxp.com/products/processors-and-microcontrollers/arm-based-processors-and-mcus/i.mx-applications-processors/i.mx-6-processors/i.mx-6-processors/i.mx-6-processors/i.mx-6-processors/i.mx-6-processors/i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.mx-6-processors-i.

## i.MX 6Quad Multimedia Applications Processor Block Diagram



(E.g., id.).

COMPLAINT - 13

(E.g.,

17 <u>m.pdf</u>).

COMPLAINT - 14



http://infocenter.arm.com/help/topic/com.arm.doc.ddi0388f/DDI0388F\_cortex\_a9\_r2p2\_tr

#### Background

The NEON subsystem is an advanced SIMD (Single Instruction, Multiple Data) processing unit. This means that it can apply a single type of instruction to many pieces of data at one time in parallel. This is extremely helpful when it comes to media processing such as audio/video filters and codecs.

The NEON system is NOT the floating point unit of the ARM processor. There is separate FPU known as the VFP system. They use the same register space but this is taken care of by the compiler/kernel. There are a few differences between the NEON and VFP systems such as: NEON does not support double-precision floating point numbers, NEON only works on vectors and does not support advanced operations such as square root and divide.

(e.g., http://www.add.ece.ufl.edu/4924/docs/arm/ARM%20NEON%20Development.pdf).

The accused product comprises media processors with each processor

comprising a multiplier (e.g., an Integer MUL or FP MUL) having a data input coupled to the media processing unit input/output, an instruction input coupled to the media processing unit input/output, and a data output coupled to the media processing unit input/output. As shown below, the accused product comprises multiple ARM cortex-A9 Dual/Quad core processor, each processor comprises a NEON media coprocessor and acts as a media processing unit. NEON media coprocessor comprises a multiplier which is coupled to the inputs/outputs of the processor. Upon information and belief, the multiplier comprises a data input, an instruction input, and a data output coupled to the input/output of the processor.





The phyFLEX-i.MX6 SOM supports the Freescale™ i.MX6 Solo, i.MX6 Dual, and i.MX6 Quad application processors offering a broad range of solutions with emphasis from cost-efficiency to high demand performance at low power. The three innovative SOM interconnects provide standardization across the phyFLEX product family and highlight features such as 64-bit DDR3, USB, Gigabit Ethernet, integrated FlexCAN and MLB busses, PCIe, SATA-II, multiple simultaneous displays, camera interface, and HDMI v1.4.

(e.g., <a href="https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-modules/phyflex/i.mx6/">https://web.archive.org/web/20140625161036/http://phytec.com/products/system-on-modules/phyflex/i.mx6/</a>).

1 **SOM Highlights** 2 i.MX6 Single, Dual, Quad core 3 Up to 1.2 GHz / core VPU, IPUv3H, GPU2Dv2, OpenVG 1.2 4 Up to 4 GB DDR3 / 16 GB NAND 5 SD/SDIO/MMC USB 2.0 OTG and Host 6 PCIe, SATA II 7 CAN, UART, SPI, I2C, I2S Camera interface 8 Up to 4 displays + HDMI 9 Linux and Compact 7 BSPs 10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

70 mm

60 mm

View all specs

(e.g., id.).

## i.MX 6Quad Multimedia Applications Processor Block Diagram



(E.g., id.).

COMPLAINT - 16

MANN LAW GROUP PLLC 107 Spring St. Seattle, WA 98104 TELEPHONE: 206.436-0900



Cortex-A9 processor Program Trace Performance Macrocell (PTM) Monitoring Unit (PMU) interface Register Dispatch Writeback rename stage stages ALU/MUL stage ALU Virtual to Instruction physical queue and egister pool dispatch FPU or NEON **Dual instruction** Out of order decode stage multi-issue **Branches** with speculation Load/store address generation unit Instructions Predictions Media processor Instruction prefetch stage Memory system Branch prediction Instruction Translation Memory Dynamic branch Load store aueue lookaside management prediction unit buffer unit Instruction Return stack Preload Engine (optional) Data cache Instruction fetch

(e.g.,

http://infocenter.arm.com/help/topic/com.arm.doc.ddi0388f/DDI0388F\_cortex\_a9\_r2p2\_tr m.pdf).

18

19

20

21

22

23

24

25

26

27

14

15

16

17



345

6789

101112

1314

15

161718

19

2021

222324

25

26

28

27

(E.g., http://www.add.ece.ufl.edu/4924/docs/arm/ARM%20NEON%20Development.pdf).

31. The accused product comprises media processors with each processor comprising an arithmetic unit (*e.g.*, an FP ADD) having a data input coupled to the media processing unit input/output, an instruction input coupled to the media processing unit input/output, and a data output coupled to the media processing unit input/output. As shown below, the accused product comprises multiple ARM cortex-A9 Dual/Quad core processor, each processor comprises a NEON media coprocessor and acts as a media processing unit. NEON media coprocessor comprises an arithmetic unit which is coupled to the inputs/outputs of the processor. Upon information and belief, the arithmetic unit comprises a data input, an instruction input, and a data output coupled to the input/output of the processor.



(E.g., <a href="http://www.add.ece.ufl.edu/4924/docs/arm/ARM%20NEON%20Development.pdf">http://www.add.ece.ufl.edu/4924/docs/arm/ARM%20NEON%20Development.pdf</a>).

32. The accused product comprises media processors with each processor comprising an arithmetic logic unit (*e.g.*, an ALU) having a data input coupled to the media processing unit input/output, an instruction input coupled to the media processing unit input/output, and a data output coupled to the media processing unit input/output, capable of operating concurrently with at least one selected from the multiplier (*e.g.*, an Integer MUL or FP MUL) and arithmetic unit (*e.g.*, a FP ADD). As shown below, the accused product comprises multiple ARM cortex-A9 Dual/Quad core processor, each processor comprises a NEON media coprocessor and acts as a media processing unit. NEON media coprocessor comprises an arithmetic logical unit which is coupled to the inputs/outputs of the processor. Upon information and belief, the arithmetic logical unit (*e.g.*, the Integer ALU) is capable of operating concurrently with at least one selected from the multiplier (*e.g.*, the Integer MUL or FP MUL) and arithmetic unit (*e.g.*, the FP ADD).



3

6 7

5

9 10

8

11 12

13

1415

16

17

18

19 20

21

22

23

24

25

2627

28

 $(\textit{E.g.}, \underline{\text{http://www.add.ece.ufl.edu/4924/docs/arm/ARM\%20NEON\%20Development.pdf}}).$ 

33. The accused product comprises media processors with each processor comprising a bit manipulation unit (e.g., an Integer Shift unit) having a data input coupled to the media processing unit input/output, an instruction input coupled to the media processing unit input/output, and a data output coupled to the media processing unit input/output, capable of operating concurrently with the arithmetic logic unit (e.g., an Integer ALU) and at least one selected from the multiplier (e.g., an Integer MUL or FP MUL) and arithmetic unit (e.g., a FP ADD). As shown below, the accused product comprises multiple ARM cortex-A9 Dual/Quad core processors, each processor comprising a NEON media coprocessor that acts as a media processing unit. The NEON media coprocessor comprises an integer shift unit (i.e., bit manipulation unit) which is coupled to the inputs/outputs of the processor. Upon information and belief, the integer shift unit (i.e., bit manipulation unit) comprises a data input, an instruction input, and a data output coupled to the input/output of the processor. Upon information and belief, the integer shift unit (i.e., bit manipulation unit) is capable of operating concurrently with the arithmetic logic unit (e.g., the Integer ALU) and at least one selected from the multiplier (e.g., the Integer MUL or FP MUL) and arithmetic unit (e.g., the FP ADD).



 $(\textit{E.g.}, \underline{\text{http://www.add.ece.ufl.edu/4924/docs/arm/ARM\%20NEON\%20Development.pdf}}).$ 

34. The accused product comprises a plurality of media processors (*e.g.*, ARM cortex-A9 Dual/Quad core processors) for performing at least one operation, simultaneously with the performance of other operations by other media processing units (*e.g.*, other ARM cortex-A9 Dual/Quad core processors on the same chip).

COMPLAINT - 21

# phyFLEX®-i.MX6

#### Contact us to learn more

Get A Quote



Call 1-800-278-9913 to talk to a technical sales engineer

8

9

10

11

The phyFLEX-i.MX6 SOM supports the Freescale™ i.MX6 Solo, i.MX6 Dual, and i.MX6 Quad application processors offering a broad range of solutions with emphasis from cost-efficiency to high demand performance at low power. The three innovative SOM interconnects provide standardization across the phyFLEX product family and highlight features such as 64-bit DDR3, USB, Gigabit Ethernet, integrated FlexCAN and MLB busses, PCIe, SATA-II, multiple simultaneous displays, camera interface, and HDMI v1.4.

12 13

(e.g., https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-

15

16

14

#### **SOM Highlights**

17

. i.MX6 Single, Dual, Quad core

18

19

20

21

22

23

24

Up to 1.2 GHz / core

modules/phyflex/i.mx6/).

- VPU, IPUv3H, GPU2Dv2, OpenVG 1.2
- Up to 4 GB DDR3 / 16 GB NAND

SD/SDIO/MMC

USB 2.0 OTG and Host

PCIe, SATA II

CAN, UART, SPI, I2C, I2S

Camera interface

- Up to 4 displays + HDMI
- Linux and Compact 7 BSPs

25

View all specs

26 27

(e.g., id.).

28

70 mm

60 mm

COMPLAINT - 22

Register

rename stage

Virtual to

physical

egister pool

Branches

Branch prediction

Dynamic branch

prediction

Return stack

**Dual instruction** 

decode stage

Predictions

Instruction prefetch stage

Instructions

Instruction

queue

Instruction

cache

Instruction

fetch

Cortex-A9 processor

Dispatch

stages

Instruction

queue and

dispatch

Out of order

multi-issue

with speculation

Load store

unit

Program Trace

Macrocell (PTM)

interface

ALU/MUL

ALU

FPU or NEON

Load/store address generation unit

Translation

lookaside

buffer

Memory system

Memory

management

unit

Preload Engine (optional)

Data cache

Performance

Monitoring Unit

(PMU)

Writeback

stage

Media

processor

(E.g.,

http://infocenter.arm.com/help/topic/com.arm.doc.ddi0388f/DDI0388F\_cortex\_a9\_r2p2\_tr m.pdf).

18

19

20

21

22

23

15

16

17

#### Background

The NEON subsystem is an advanced SIMD (Single Instruction, Multiple Data) processing unit. This means that it can apply a single type of instruction to many pieces of data at one time in parallel. This is extremely helpful when it comes to media processing such as audio/video filters and codecs.

The NEON system is NOT the floating point unit of the ARM processor. There is separate FPU known as the VFP system. They use the same register space but this is taken care of by the compiler/kernel. There are a few differences between the NEON and VFP systems such as: NEON does not support double-precision floating point numbers, NEON only works on vectors and does not support advanced operations such as square root and divide.

24

25

(E.g., http://www.add.ece.ufl.edu/4924/docs/arm/ARM%20NEON%20Development.pdf).

26

35. The accused product comprises a plurality of media processors (*e.g.*, ARM cortex-A9 Dual/Quad core processors), each processor receiving at the media processor

28

input/output an instruction and data from the memory, and processing the data responsive to the instruction received to produce at least one result. As shown below, each ARM cortex-A9 Dual/Quad core media processor comprises a NEON media coprocessor which receives instructions and data from memory and processes the data responsive to the instruction received in order to produce a result.

#### i.MX 6Quad Multimedia Applications Processor Block Diagram



(E.g.,https://www.nxp.com/products/processors-and-microcontrollers/arm-basedprocessors-and-mcus/i.mx-applications-processors/i.mx-6-processors/i.mx-6quadprocessors-high-performance-3d-graphics-hd-video-arm-cortex-a9-core:i.MX6Q).

18

19

20

21

22

23

24

25

26

27

28

**SOM Highlights** 

Up to 1.2 GHz / core

USB 2.0 OTG and Host

CAN, UART, SPI, I2C, I2S

Up to 4 displays + HDMI

Linux and Compact 7 BSPs

SD/SDIO/MMC

PCIe, SATA II

Camera interface

View all specs

i.MX6 Single, Dual, Quad core

VPU, IPUv3H, GPU2Dv2, OpenVG 1.2

Up to 4 GB DDR3 / 16 GB NAND

70 mm

60 mm

(e.g., <a href="https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-modules/phyflex/i.mx6/">https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-modules/phyflex/i.mx6/</a>).



 $(\textit{E.g.}, \underline{\text{http://www.add.ece.ufl.edu/4924/docs/arm/ARM\%20NEON\%20Development.pdf}}).$ 

COMPLAINT - 25

36. The accused product comprises a plurality of media processors (*e.g.*, ARM cortex-A9 Dual/Quad core processors), each processor providing at least one of the at least one result at the media processor input/output. (*Id.*).





Contact us to learn more

Get A Quote



Call 1-800-278-9913 to talk to a technical sales engineer

The phyFLEX-i.MX6 SOM supports the Freescale™ i.MX6 Solo, i.MX6 Dual, and i.MX6 Quad application processors offering a broad range of solutions with emphasis from cost-efficiency to high demand performance at low power. The three innovative SOM interconnects provide standardization across the phyFLEX product family and highlight features such as 64-bit DDR3, USB, Gigabit Ethernet, integrated FlexCAN and MLB busses, PCIe, SATA-II, multiple simultaneous displays, camera interface, and HDMI v1.4.

(*e.g.*, <a href="https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-modules/phyflex/i.mx6/">https://web.archive.org/web/20140625161036/http:/phytec.com/products/system-on-modules/phyflex/i.mx6/</a>).

| 1  | SOM Highlights                                                                             | 70 mm              |          |
|----|--------------------------------------------------------------------------------------------|--------------------|----------|
| 2  | i.MX6 Single, Dual, Quad core                                                              | THE REAL PROPERTY. |          |
| 3  | <ul> <li>Up to 1.2 GHz / core</li> </ul>                                                   |                    |          |
| 4  | <ul> <li>VPU, IPUv3H, GPU2Dv2, OpenVG 1.2</li> <li>Up to 4 GB DDR3 / 16 GB NAND</li> </ul> | Branch A.          | 60 mm    |
| 5  | SD/SDIO/MMC                                                                                |                    | 00 11811 |
| 6  | <ul> <li>USB 2.0 OTG and Host</li> </ul>                                                   |                    |          |
|    | PCIe, SATA II                                                                              |                    |          |
| 7  | <ul> <li>CAN, UART, SPI, I2C, I2S</li> </ul>                                               | O 1362.0           |          |
| 8  | Camera interface     Us to 4 displays a NDMI                                               |                    |          |
| 9  | <ul> <li>Up to 4 displays + HDMI</li> <li>Linux and Compact 7 BSPs</li> </ul>              |                    |          |
| 10 |                                                                                            |                    |          |
| 11 | View all specs                                                                             |                    |          |
| 12 |                                                                                            |                    |          |
| 13 | (e.g., id.).                                                                               |                    |          |
|    | _                                                                                          |                    |          |
| 14 | Features                                                                                   |                    |          |
| 15 | ▶ CPU Complex                                                                              |                    |          |
| 16 | ▼ Multimedia                                                                               |                    |          |
| 17 | <ul><li>GPU 3D</li><li>Vivante GC2000</li></ul>                                            |                    |          |
| 18 | <ul> <li>200Mtri/s 1000Mpxl/s<br/>and Halti, CL EP</li> </ul>                              | s, OpenGL ES 3.0   |          |
|    | GPU 2D(Vector Graphics)                                                                    |                    |          |
| 19 | <ul><li>Vivante GC355</li><li>300Mpxl/s, OpenVG</li></ul>                                  | 1.1                |          |
| 20 | ■ GPU 2D(Composition)                                                                      |                    |          |
| 21 | <ul><li>Vivante GC320</li><li>600Mpxl/s, BLIT</li></ul>                                    |                    |          |
| 22 | ■ Video Decode                                                                             |                    |          |
| 23 | <ul><li>1080p 60 h.264</li><li>Video Encode</li></ul>                                      |                    |          |
| 24 | = 1080p30 H.264 BP/ [                                                                      | Dual 720p encode   |          |
|    | <ul><li>Camera Interface</li><li>Types: 1x 20-bit para</li></ul>                           | illel MIPLCSI2 (4  |          |
| 25 | lanes), three simultar                                                                     |                    |          |
| 26 |                                                                                            |                    |          |
| 27 |                                                                                            |                    |          |
| 28 |                                                                                            |                    |          |

(*e.g.*, <a href="https://www.nxp.com/products/processors-and-microcontrollers/arm-based-processors-and-mcus/i.mx-applications-processors/i.mx-6-processors/i.mx-6-processors/i.mx-6-quad-processors-high-performance-3d-graphics-hd-video-arm-cortex-a9-core:i.MX6O).

- 37. Plaintiff has been damaged as a result of Defendant's infringing conduct. Defendant is thus liable to Plaintiff for damages in an amount that adequately compensates Plaintiff for such Defendant's infringement of the '434 patent, *i.e.*, in an amount that by law cannot be less than would constitute a reasonable royalty for the use of the patented technology, together with interest and costs as fixed by this Court under 35 U.S.C. § 284.
- 38. On information and belief, Defendant has had at least constructive notice of the '434 patent by operation of law, and there are no marking requirements that have not been complied with.

#### IV. JURY DEMAND

Plaintiff, under Rule 38 of the Federal Rules of Civil Procedure, requests a trial by jury of any issues so triable by right.

#### V.PRAYER FOR RELIEF

WHEREFORE, Plaintiff respectfully requests that the Court find in its favor and against Defendant, and that the Court grant Plaintiff the following relief:

- a. Judgment that one or more claims of United States Patent No. 6,289,434 have been infringed, either literally and/or under the doctrine of equivalents, by Defendant;
- b. Judgment that Defendant account for and pay to Plaintiff all damages to and costs incurred by Plaintiff because of Defendant's infringing activities and other conduct complained of herein, and an accounting of all infringements and damages not presented at trial;
- c. That Plaintiff be granted pre-judgment and post-judgment interest on the damages caused by Defendant's infringing activities and other conduct complained of herein; and

### Case 3:19-cv-06142-JRC Document 1 Filed 11/26/19 Page 29 of 29

| 1  |                                         |        |    |                                                      |  |  |
|----|-----------------------------------------|--------|----|------------------------------------------------------|--|--|
| 2  | iust and proper under the circumstances |        |    |                                                      |  |  |
| 3  |                                         |        |    |                                                      |  |  |
| 4  |                                         |        |    |                                                      |  |  |
| 5  | November 26                             | , 2019 |    | Respectfully Submitted,                              |  |  |
| 6  |                                         |        | Ву | /s/Philip P. Mann Philip P. Mann, WSBA No: 28860     |  |  |
| 7  |                                         |        |    | MANN LAW GROUP PLLC<br>107 Spring St.                |  |  |
| 8  |                                         |        |    | Seattle, Washington 98104<br>(206) 436-0900          |  |  |
| 9  |                                         |        |    | Fax (866) 341-5140 phil@mannlawgroup.com             |  |  |
| 11 |                                         |        |    | David R. Bennett                                     |  |  |
| 12 |                                         |        |    | (Application for Admission Pro Hac Vice to be filed) |  |  |
| 13 |                                         |        |    | Direction IP Law<br>P.O. Box 14184                   |  |  |
| 14 |                                         |        |    | Chicago, IL 60614-0184                               |  |  |
| 15 |                                         |        |    | (312) 291-1667<br>dbennett@directionip.com           |  |  |
| 16 |                                         |        |    |                                                      |  |  |
| 17 |                                         |        |    | Attorneys for Plaintiff Altair Logix LLC             |  |  |
| 18 |                                         |        |    |                                                      |  |  |
| 19 |                                         |        |    |                                                      |  |  |
| 20 |                                         |        |    |                                                      |  |  |
| 21 |                                         |        |    |                                                      |  |  |
| 22 |                                         |        |    |                                                      |  |  |
| 23 |                                         |        |    |                                                      |  |  |
| 24 |                                         |        |    |                                                      |  |  |
| 25 |                                         |        |    |                                                      |  |  |
| 26 |                                         |        |    |                                                      |  |  |
| 27 |                                         |        |    |                                                      |  |  |
| 28 |                                         |        |    |                                                      |  |  |