Reverse engineering is reverse forward engineering

Ira D. Baxter,Michael Mehlich
DOI: https://doi.org/10.1016/s0167-6423(99)00034-9
IF: 1.039
2000-03-01
Science of Computer Programming
Abstract:Reverse Engineering is focused on the challenging task of understanding legacy program code without having suitable documentation. Using a transformational forward engineering perspective, we gain the insight that much of this difficulty is caused by design decisions made during system development. Such decisions “hide” the program functionality and performance requirements in the final system by applying repeated refinements through layers of abstraction, and information-spreading optimizations, both of which change representations and force single program entities to serve multiple purposes. To be able to reverse engineer, we essentially have to reverse these design decisions. Following the transformational approach we can use the transformations of a forward engineering methodology and apply them “backwards” to reverse engineer code to a more abstract specification. Since most of the existing code was not generated by transformational synthesis, this produces a plausible formal transformational design rather than the original authors’ actual design. As an example, a small fragment of a real-time operating system is reverse-engineered using this approach. A byproduct of the transformational reverse engineering process is a design database for the program that then can be maintained to minimize the need for further reverse engineering during the remaining lifetime of the system. A consequence of a transformational forward engineering perspective is the belief that the standard plan recognition methods proposed for reverse engineering are not sufficient.
computer science, software engineering
What problem does this paper attempt to address?