A Pipelined Processor Architecture for Regular Expression String Matching.

Li Qiyue,Li Jie,Wang Jianping,Zhao Baohua,Qu Yugui
DOI: https://doi.org/10.1016/j.micpro.2012.04.004
IF: 3.503
2012-01-01
Microprocessors and Microsystems
Abstract:The expressive power of regular expressions has been often adopted in network intrusion detection systems, virus scanners, and spam filtering applications. However in the CPU based systems, pattern matching is one of the most computation intensive parts. In this paper, we present the design, implementation and evaluation of a regular expression string matching processing unit (SMPU). This special purpose processor is a parallel and pipelined architecture which can deal with the regular expression semantics. Two hardware stacks are implemented in SMPU to support fast branches when the non-matching occurs. Our implementation processes four characters per clock cycle (maximum performance of state of the art solutions) and occupies only O(n) memory (where n is the length of the regular expression) via synthesizing the verilog description and analyzing area/time constraints, SMPU can achieve 200–400 times speedup over traditional CPU implementations and up to 7.9Gbps in processing throughput. Besides it outperforms the counterparts greatly as the complexity of regular expressions increases.
What problem does this paper attempt to address?