From 20813e01e76e71c0400165b7fb8b2e412d18c0a2 Mon Sep 17 00:00:00 2001
From: Owen Anderson
- RegisterPass<Hello> X("hello", "Hello World Pass", + INITIALIZE_PASS(Hello, "hello", "Hello World Pass", false /* Only looks at CFG */, false /* Analysis Pass */); } // end of anonymous namespace @@ -299,7 +299,7 @@ initialization value is not important.Lastly, we register our class Hello, giving it a command line argument "hello", and a name "Hello World Pass". -Last two RegisterPass arguments are optional. Their default value is false. +Last two arguments describe its behavior. If a pass walks CFG without modifying it then third argument is set to true. If a pass is an analysis pass, for example dominator tree pass, then true is supplied as fourth argument.
@@ -326,8 +326,9 @@ is supplied as fourth argument. }; char Hello::ID = 0; - RegisterPass<Hello> X("hello", "Hello World Pass"); + INITIALIZE_PASS(Hello, "Hello", "Hello World Pass", false, false); } +
Now that it's all together, compile the file with a simple "gmake" @@ -348,7 +349,7 @@ them) to be useful.
Now that you have a brand new shiny shared object file, we can use the opt command to run an LLVM program through your pass. Because you -registered your pass with the RegisterPass template, you will be able to +registered your pass with the INITIALIZE_PASS macro, you will be able to use the opt tool to access it, once loaded.
To test it, follow the example at the end of the Function or its contents from a pass registration works, and discussed some of the reasons that it is used and what it does. Here we discuss how and why passes are registered.
-As we saw above, passes are registered with the RegisterPass -template, which requires you to pass at least two -parameters. The first parameter is the name of the pass that is to be used on +
As we saw above, passes are registered with the INITIALIZE_PASS +macro. The first parameter is the name of the pass that is to be used on the command line to specify that the pass should be added to a program (for example, with opt or bugpoint). The second argument is the name of the pass, which is to be used for the -help output of -- cgit v1.1