summaryrefslogtreecommitdiff
path: root/vendor/github.com/mmcloughlin/avo/pass/isa.go
blob: 951834d17d123babd5f3314f7311767148065e0c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
package pass

import (
	"sort"

	"github.com/mmcloughlin/avo/ir"
)

// RequiredISAExtensions determines ISA extensions required for the given
// function. Populates the ISA field.
func RequiredISAExtensions(fn *ir.Function) error {
	// Collect ISA set.
	set := map[string]bool{}
	for _, i := range fn.Instructions() {
		for _, isa := range i.ISA {
			set[isa] = true
		}
	}

	if len(set) == 0 {
		return nil
	}

	// Populate the function's ISA field with the unique sorted list.
	for isa := range set {
		fn.ISA = append(fn.ISA, isa)
	}
	sort.Strings(fn.ISA)

	return nil
}