Skip to content

Commit

Permalink
platform/local: Extract swtpm functionality
Browse files Browse the repository at this point in the history
So that it can be added to kola spawn more easily.

Signed-off-by: Jeremi Piotrowski <jpiotrowski@microsoft.com>
  • Loading branch information
jepio committed Apr 10, 2024
1 parent 745d0b9 commit 18fe09d
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 51 deletions.
59 changes: 8 additions & 51 deletions kola/tests/misc/tpm.go
Original file line number Diff line number Diff line change
@@ -1,20 +1,16 @@
package misc

import (
"fmt"
"os"
"strings"

"github.com/coreos/go-semver/semver"
"github.com/coreos/pkg/capnslog"
"github.com/flatcar/mantle/kola/cluster"
"github.com/flatcar/mantle/kola/register"
"github.com/flatcar/mantle/platform"
"github.com/flatcar/mantle/platform/conf"
"github.com/flatcar/mantle/platform/local"
"github.com/flatcar/mantle/platform/machine/qemu"
"github.com/flatcar/mantle/platform/machine/unprivqemu"
"github.com/flatcar/mantle/system/exec"
"github.com/flatcar/mantle/util"
)

var (
Expand Down Expand Up @@ -161,17 +157,21 @@ func init() {
}

func tpmTest(c cluster.TestCluster, userData *conf.UserData, mountpoint string) {
swtpm, err := startSwtpm()
swtpmDir, err := os.MkdirTemp("", "swtpm-")
if err != nil {
c.Fatalf("mkdir: %v", err)
}
swtpm, err := local.NewSwtpm(swtpmDir)
if err != nil {
c.Fatalf("could not start software TPM emulation: %v", err)
}
defer swtpm.stop()
defer swtpm.Stop()

options := platform.MachineOptions{
AdditionalDisks: []platform.Disk{
{Size: "520M", DeviceOpts: []string{"serial=secondary"}},
},
SoftwareTPMSocket: swtpm.socketPath,
SoftwareTPMSocket: swtpm.SocketPath(),
}
var m platform.Machine
switch pc := c.Cluster.(type) {
Expand Down Expand Up @@ -200,46 +200,3 @@ func tpmTest(c cluster.TestCluster, userData *conf.UserData, mountpoint string)

checkIfMountpointIsEncrypted(c, m, mountpoint)
}

type softwareTPM struct {
process *exec.ExecCmd
socketPath string
dir string
}

func startSwtpm() (*softwareTPM, error) {
swtpm := &softwareTPM{}

swtpmDir, err := os.MkdirTemp("", "swtpm-")
if err != nil {
return nil, err
}
swtpm.dir = swtpmDir
swtpm.socketPath = fmt.Sprintf("%v/swtpm-sock", swtpm.dir)

swtpm.process = exec.Command("swtpm", "socket", "--tpmstate", fmt.Sprintf("dir=%v", swtpm.dir), "--ctrl", fmt.Sprintf("type=unixio,path=%v", swtpm.socketPath), "--tpm2")
out, err := swtpm.process.StdoutPipe()
if err != nil {
return nil, err
}
go util.LogFrom(capnslog.INFO, out)

if err = swtpm.process.Start(); err != nil {
return nil, err
}

plog.Debugf("swtpm PID: %v", swtpm.process.Pid())

return swtpm, nil
}

func (swtpm *softwareTPM) stop() {
if err := swtpm.process.Kill(); err != nil {
plog.Errorf("Error killing swtpm: %v", err)
}
// To be double sure that we do not delete the wrong directory, check that "tpm" occurs in the directory path we delete.
if strings.Contains(swtpm.dir, "tpm") {
plog.Debugf("Delete swtpm temporary directory %v", swtpm.dir)
os.RemoveAll(swtpm.dir)
}
}
55 changes: 55 additions & 0 deletions platform/local/tpm.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
package local

import (
"fmt"
"os"
"strings"

"github.com/coreos/pkg/capnslog"
"github.com/flatcar/mantle/system/exec"
"github.com/flatcar/mantle/util"
)

type SoftwareTPM struct {
process *exec.ExecCmd
socketPath string
dir string
}

func NewSwtpm(dir string) (*SoftwareTPM, error) {
swtpm := &SoftwareTPM{}

os.Mkdir(dir, 0700)
swtpm.dir = dir
swtpm.socketPath = fmt.Sprintf("%v/sock", swtpm.dir)

swtpm.process = exec.Command("swtpm", "socket", "--tpmstate", fmt.Sprintf("dir=%v", swtpm.dir), "--ctrl", fmt.Sprintf("type=unixio,path=%v", swtpm.socketPath), "--tpm2")
out, err := swtpm.process.StderrPipe()
if err != nil {
return nil, err
}
go util.LogFrom(capnslog.INFO, out)

if err = swtpm.process.Start(); err != nil {
return nil, err
}

plog.Debugf("swtpm PID: %v", swtpm.process.Pid())

return swtpm, nil
}

func (swtpm *SoftwareTPM) Stop() {
if err := swtpm.process.Kill(); err != nil {
plog.Errorf("Error killing swtpm: %v", err)
}
// To be double sure that we do not delete the wrong directory, check that "tpm" occurs in the directory path we delete.
if strings.Contains(swtpm.dir, "tpm") {
plog.Debugf("Delete swtpm temporary directory %v", swtpm.dir)
os.RemoveAll(swtpm.dir)
}
}

func (swtpm *SoftwareTPM) SocketPath() string {
return swtpm.socketPath
}

0 comments on commit 18fe09d

Please sign in to comment.