mirror of
https://github.com/danog/gllvm.git
synced 2024-11-30 06:19:03 +01:00
Merge pull request #37 from trailofbits/ww/make-extraction-errors-fatal
extractor: Make extraction errors fatal
This commit is contained in:
commit
165d3369bf
@ -42,11 +42,9 @@ func main() {
|
|||||||
// Parse command line
|
// Parse command line
|
||||||
var args = os.Args
|
var args = os.Args
|
||||||
|
|
||||||
shared.Extract(args)
|
exitCode := shared.Extract(args)
|
||||||
|
|
||||||
shared.LogInfo("Calling %v DID NOT TELL US WHAT HAPPENED\n", os.Args)
|
shared.LogInfo("Calling %v DID NOT TELL US WHAT HAPPENED\n", os.Args)
|
||||||
|
|
||||||
// could be more honest about our success here
|
os.Exit(exitCode)
|
||||||
os.Exit(0)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -58,6 +58,7 @@ type ExtractionArgs struct {
|
|||||||
SortBitcodeFiles bool // sort the arguments to linking and archiving (debugging too)
|
SortBitcodeFiles bool // sort the arguments to linking and archiving (debugging too)
|
||||||
BuildBitcodeModule bool // buld an archive rather than a module
|
BuildBitcodeModule bool // buld an archive rather than a module
|
||||||
KeepTemp bool // keep temporary linking folder
|
KeepTemp bool // keep temporary linking folder
|
||||||
|
StrictExtract bool // turn extraction failures into errors
|
||||||
LinkArgSize int // maximum size of a llvm-link command line
|
LinkArgSize int // maximum size of a llvm-link command line
|
||||||
InputType int
|
InputType int
|
||||||
ObjectTypeInArchive int // Type of file that can be put into an archive
|
ObjectTypeInArchive int // Type of file that can be put into an archive
|
||||||
@ -67,7 +68,7 @@ type ExtractionArgs struct {
|
|||||||
LlvmArchiverName string
|
LlvmArchiverName string
|
||||||
ArchiverName string
|
ArchiverName string
|
||||||
ArArgs []string
|
ArArgs []string
|
||||||
Extractor func(string) []string
|
Extractor func(string) ([]string, bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
//for printing out the parsed arguments, some have been skipped.
|
//for printing out the parsed arguments, some have been skipped.
|
||||||
@ -85,10 +86,11 @@ ea.OutputFile: %v
|
|||||||
ea.LlvmArchiverName: %v
|
ea.LlvmArchiverName: %v
|
||||||
ea.LlvmLinkerName: %v
|
ea.LlvmLinkerName: %v
|
||||||
ea.ArchiverName: %v
|
ea.ArchiverName: %v
|
||||||
|
ea.StrictExtract: %v
|
||||||
`
|
`
|
||||||
return fmt.Sprintf(format, ea.Verbose, ea.WriteManifest, ea.SortBitcodeFiles, ea.BuildBitcodeModule,
|
return fmt.Sprintf(format, ea.Verbose, ea.WriteManifest, ea.SortBitcodeFiles, ea.BuildBitcodeModule,
|
||||||
ea.KeepTemp, ea.LinkArgSize, ea.InputFile, ea.OutputFile, ea.LlvmArchiverName,
|
ea.KeepTemp, ea.LinkArgSize, ea.InputFile, ea.OutputFile, ea.LlvmArchiverName,
|
||||||
ea.LlvmLinkerName, ea.ArchiverName)
|
ea.LlvmLinkerName, ea.ArchiverName, ea.StrictExtract)
|
||||||
}
|
}
|
||||||
|
|
||||||
//ParseSwitches parses the command line into an ExtractionArgs object.
|
//ParseSwitches parses the command line into an ExtractionArgs object.
|
||||||
@ -106,6 +108,7 @@ func ParseSwitches(args []string) (ea ExtractionArgs) {
|
|||||||
flagSet.StringVar(&ea.LlvmLinkerName, "l", "llvm-link", "the llvm linker (i.e. llvm-link)")
|
flagSet.StringVar(&ea.LlvmLinkerName, "l", "llvm-link", "the llvm linker (i.e. llvm-link)")
|
||||||
flagSet.IntVar(&ea.LinkArgSize, "n", 0, "maximum llvm-link command line size (in bytes)")
|
flagSet.IntVar(&ea.LinkArgSize, "n", 0, "maximum llvm-link command line size (in bytes)")
|
||||||
flagSet.BoolVar(&ea.KeepTemp, "t", false, "keep temporary linking folder")
|
flagSet.BoolVar(&ea.KeepTemp, "t", false, "keep temporary linking folder")
|
||||||
|
flagSet.BoolVar(&ea.StrictExtract, "S", false, "exit with an error if extraction fails")
|
||||||
|
|
||||||
err := flagSet.Parse(args[1:])
|
err := flagSet.Parse(args[1:])
|
||||||
|
|
||||||
@ -257,7 +260,11 @@ func resolveTool(defaultPath string, envPath string, usrPath string) (path strin
|
|||||||
|
|
||||||
func handleExecutable(ea ExtractionArgs) (success bool) {
|
func handleExecutable(ea ExtractionArgs) (success bool) {
|
||||||
// get the list of bitcode paths
|
// get the list of bitcode paths
|
||||||
artifactPaths := ea.Extractor(ea.InputFile)
|
var artifactPaths []string
|
||||||
|
artifactPaths, success = ea.Extractor(ea.InputFile)
|
||||||
|
if !success && ea.StrictExtract {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if len(artifactPaths) < 20 {
|
if len(artifactPaths) < 20 {
|
||||||
// naert: to avoid saturating the log when dealing with big file lists
|
// naert: to avoid saturating the log when dealing with big file lists
|
||||||
@ -304,7 +311,11 @@ func handleThinArchive(ea ExtractionArgs) (success bool) {
|
|||||||
for index, obj := range objectFiles {
|
for index, obj := range objectFiles {
|
||||||
LogInfo("obj = '%v'\n", obj)
|
LogInfo("obj = '%v'\n", obj)
|
||||||
if len(obj) > 0 {
|
if len(obj) > 0 {
|
||||||
artifacts := ea.Extractor(obj)
|
var artifacts []string
|
||||||
|
artifacts, success = ea.Extractor(obj)
|
||||||
|
if !success && ea.StrictExtract {
|
||||||
|
return
|
||||||
|
}
|
||||||
LogInfo("\t%v\n", artifacts)
|
LogInfo("\t%v\n", artifacts)
|
||||||
artifactFiles = append(artifactFiles, artifacts...)
|
artifactFiles = append(artifactFiles, artifacts...)
|
||||||
for _, bc := range artifacts {
|
for _, bc := range artifacts {
|
||||||
@ -456,8 +467,11 @@ func handleArchive(ea ExtractionArgs) (success bool) {
|
|||||||
for i := 1; i <= instance; i++ {
|
for i := 1; i <= instance; i++ {
|
||||||
|
|
||||||
if obj != "" && extractFile(ea, inputFile, obj, i) {
|
if obj != "" && extractFile(ea, inputFile, obj, i) {
|
||||||
|
var artifacts []string
|
||||||
artifacts := ea.Extractor(obj)
|
artifacts, success = ea.Extractor(obj)
|
||||||
|
if !success && ea.StrictExtract {
|
||||||
|
return
|
||||||
|
}
|
||||||
LogInfo("\t%v\n", artifacts)
|
LogInfo("\t%v\n", artifacts)
|
||||||
artifactFiles = append(artifactFiles, artifacts...)
|
artifactFiles = append(artifactFiles, artifacts...)
|
||||||
for _, bc := range artifacts {
|
for _, bc := range artifacts {
|
||||||
@ -671,7 +685,7 @@ func linkBitcodeFiles(ea ExtractionArgs, filesToLink []string) (success bool) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func extractSectionDarwin(inputFile string) (contents []string) {
|
func extractSectionDarwin(inputFile string) (contents []string, success bool) {
|
||||||
machoFile, err := macho.Open(inputFile)
|
machoFile, err := macho.Open(inputFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
LogError("Mach-O file %s could not be read.", inputFile)
|
LogError("Mach-O file %s could not be read.", inputFile)
|
||||||
@ -679,19 +693,20 @@ func extractSectionDarwin(inputFile string) (contents []string) {
|
|||||||
}
|
}
|
||||||
section := machoFile.Section(DarwinSectionName)
|
section := machoFile.Section(DarwinSectionName)
|
||||||
if section == nil {
|
if section == nil {
|
||||||
LogWarning("The %s section of %s is missing!\n", DarwinSectionName, inputFile)
|
LogError("The %s section of %s is missing!\n", DarwinSectionName, inputFile)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
sectionContents, errContents := section.Data()
|
sectionContents, errContents := section.Data()
|
||||||
if errContents != nil {
|
if errContents != nil {
|
||||||
LogWarning("Error reading the %s section of Mach-O file %s.", DarwinSectionName, inputFile)
|
LogError("Error reading the %s section of Mach-O file %s.", DarwinSectionName, inputFile)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
contents = strings.Split(strings.TrimSuffix(string(sectionContents), "\n"), "\n")
|
contents = strings.Split(strings.TrimSuffix(string(sectionContents), "\n"), "\n")
|
||||||
|
success = true
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func extractSectionUnix(inputFile string) (contents []string) {
|
func extractSectionUnix(inputFile string) (contents []string, success bool) {
|
||||||
elfFile, err := elf.Open(inputFile)
|
elfFile, err := elf.Open(inputFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
LogError("ELF file %s could not be read.", inputFile)
|
LogError("ELF file %s could not be read.", inputFile)
|
||||||
@ -699,15 +714,16 @@ func extractSectionUnix(inputFile string) (contents []string) {
|
|||||||
}
|
}
|
||||||
section := elfFile.Section(ELFSectionName)
|
section := elfFile.Section(ELFSectionName)
|
||||||
if section == nil {
|
if section == nil {
|
||||||
LogWarning("Error reading the %s section of ELF file %s.", ELFSectionName, inputFile)
|
LogError("Error reading the %s section of ELF file %s.", ELFSectionName, inputFile)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
sectionContents, errContents := section.Data()
|
sectionContents, errContents := section.Data()
|
||||||
if errContents != nil {
|
if errContents != nil {
|
||||||
LogWarning("Error reading the %s section of ELF file %s.", ELFSectionName, inputFile)
|
LogError("Error reading the %s section of ELF file %s.", ELFSectionName, inputFile)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
contents = strings.Split(strings.TrimSuffix(string(sectionContents), "\n"), "\n")
|
contents = strings.Split(strings.TrimSuffix(string(sectionContents), "\n"), "\n")
|
||||||
|
success = true
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user