skip to main content
10.1145/1370750.1370761acmconferencesArticle/Chapter ViewAbstractPublication PagesicseConference Proceedingsconference-collections
research-article

Understanding bug fix patterns in verilog

Published: 10 May 2008 Publication History

Abstract

Today, many electronic systems are developed using a hardware description language, a kind of software that can be converted into integrated circuits or programmable logic devices. Like traditional software projects, hardware projects have bugs, and significant developer time is spent fixing them. A useful first step toward reducing bugs in hardware is developing an understanding of the frequency of different types of errors. Once the most common types are known, it is then possible to focus attention on eliminating them. As most hardware projects use software configuration management repositories, these can be mined for the textual bug fix changes. In this project, we analyze the bug fix history of four hardware projects written in Verilog and manually define 25 bug fix patterns. The frequency of each bug type is then computed for all projects. We find that 29 -- 55% of the bug fix pattern instances in Verilog involve assignment statements, while 18 -- 25% are related to if statements.

References

[1]
Pan, Kai, "Using Evolution Patterns to Find Duplicated Bugs", Ph.D Dissertation, Computer Science, UC Santa Cruz, 2006. Available at http://www.soe.ucsc.edu/~ejw/dissertations/pan-dissertation.pdf
[2]
A. Mockus and L.G. Votta, Identifying Reasons for Software Changes Using Historic Database, In Proceedings of International Conference on Software Maintenance (ICSM 2000), San Jose, California, 2000, pp 120--130.
[3]
M. Fischer, M. Pinzger and H. Gall, Populating a Release History Database from Version Control and Bug Tracking Systems, In Proceedings of 2003 International Conference on Software Maintenance (ICSM'03), Amsterdam, Netherlands, 2003, pp 23--32.
[4]
D. Cubranic and G.C. Murphy, Hipikat: Recommending Pertinent Software Development Artifacts, In Proceedings of the 25th International Conference on Software Engineering, Portland, Oregon, 2003, pp 408--418.
[5]
D. Hovemeyer and W. Pugh, Finding Bugs is Easy, ACM SIGPLAN Notices, vol. 39, no. 12, pp 92--106,
[6]
C. Artho, Finding Faults in Multi-threaded Programs, Master's Thesis, Institute of Computer Systems, Federal Institute of Technology, Zurich/Austin, 2001. JLint, http://artho.com/jlint .
[7]
C. Flanagan, K. R. M. Leino, M. Lillibridge, G. Nelson, J. B. Saxe, R. Stata, Extended Static Checking for Java, In Proceedings of the 2002 ACM SIGPLAN Conference on Programming Language Design and Implementation, pp 234--245, Berlin, Germany, June 2002.
[8]
D. Van Campenhout and H. Al-Asaad and J. Hayes and T. Mudge and R. Brown, High-level design verification of microprocessors via error modeling, Trans. Design Automation of Electronic Systems, 3(4):581--599, October 1998. PMD/Java, http://pmd.sourceforge.net .
[9]
E. Allen, Bug Patterns in Java, APress, 2002.
[10]
R. F. Crew, ASTLOG: A Language for Examining Abstract Syntax Trees, In Proceedings of the Conference on Domain-Specific Languages, Santa Barbara, California, Oct 1997.
[11]
N. Rutar, C. B. Almazan and J. S. Foster, A Comparison of Bug Finding Tools for Java, in The 15th IEEE International Symposium on Software Reliability Engineering (ISSRE'04), pp 245--256, Saint-Malo, Bretagne, France, November 2004.
[12]
S. Sudhakrishnan, J. Madhavan, E.J. Whitehead, J. Renau. Understanding Bug Fix Patterns in Verilog Available at http://www.soe.ucsc.edu/~sangeetha/papers/bug-patterns.pdf

Cited By

View all

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Conferences
MSR '08: Proceedings of the 2008 international working conference on Mining software repositories
May 2008
162 pages
ISBN:9781605580241
DOI:10.1145/1370750
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 10 May 2008

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. VHDL
  2. error classification
  3. verilog

Qualifiers

  • Research-article

Conference

ICSE '08
Sponsor:

Upcoming Conference

ICSE 2025

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)23
  • Downloads (Last 6 weeks)0
Reflects downloads up to 01 Jan 2025

Other Metrics

Citations

Cited By

View all

View Options

Login options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media