Skip to content

Commit

Permalink
add deviceMapCache
Browse files Browse the repository at this point in the history
Signed-off-by: Sunyanan Choochotkaew <[email protected]>
  • Loading branch information
sunya-ch committed Nov 1, 2023
1 parent 6cd2a17 commit bbafa18
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 5 deletions.
25 changes: 25 additions & 0 deletions daemon/src/iface/iface.go
Original file line number Diff line number Diff line change
Expand Up @@ -164,3 +164,28 @@ func GetInterfaces() []backend.InterfaceInfoType {
}
return interfaces
}

func getNetAddressFromDevice(devName string) (string, error) {
devLink, err := netlink.LinkByName(devName)
if err != nil {
log.Printf("cannot find link %s: %v", devName, err)
return "", err
}
addrs, err := netlink.AddrList(devLink, netlink.FAMILY_V4)
if err != nil || len(addrs) == 0 {
log.Printf("cannot list address on %s: %v", devName, err)
return "", err
}
addr := addrs[0].IPNet
if addr == nil {
log.Printf("no address set on %s", devName)
return "", err
}
if devLink.Attrs().Flags&net.FlagUp == 0 {
// interface down
log.Printf("%s down", devName)
return "", err
}
netAddress := getNetAddress(addr)
return netAddress, nil
}
30 changes: 27 additions & 3 deletions daemon/src/iface/pci.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ const (

var CheckPointfile string = "/var/lib/kubelet/device-plugins/kubelet_internal_checkpoint"

var deviceMapCache = InitSafeCache()

// modify from https://github.com/k8snetworkplumbingwg/multus-cni/blob/9b45d4b211728aa0db44a1624aac8e61843390cf/pkg/checkpoint/checkpoint.go#L72
// DeviceIDs can map[string]string or []string
type PodDevicesEntry struct {
Expand Down Expand Up @@ -121,10 +123,32 @@ func GetDeviceMap(resourceMap map[string][]string, resourceName string) map[stri

if deviceIDs, exist := resourceMap[resourceName]; exist {
for _, deviceID := range deviceIDs {
masterName, err := GetPfName(deviceID)
if err == nil {
if netAddress, exist := nameNetMap[masterName]; exist {
var masterName string
deviceNameInterface := deviceMapCache.GetCache(deviceID)
if deviceNameInterface != nil {
masterName = deviceNameInterface.(string)
} else {
var err error
masterName, err = GetPfName(deviceID)
if err != nil {
log.Printf("cannot get physical device %s: %v\n", deviceID, err)
} else {
log.Printf("set deviceMapCache %s=%s\n", deviceID, masterName)
deviceMapCache.SetCache(deviceID, masterName)
}
}
if netAddress, exist := nameNetMap[masterName]; exist {
deviceMap[netAddress] = deviceID
} else {
netAddress, err := getNetAddressFromDevice(masterName)
if err != nil {
log.Printf("cannot get network address of device %s: %v\n", masterName, err)
} else {
deviceMap[netAddress] = deviceID
// found new device, update interfaces
GetInterfaces()
nameNetMap = GetNameNetMap()
log.Printf("updated nameNetMap map: %v\n", nameNetMap)
}
}
}
Expand Down
4 changes: 2 additions & 2 deletions daemon/src/selector/selector.go
Original file line number Diff line number Diff line change
Expand Up @@ -71,8 +71,6 @@ func getDefaultResponse(req NICSelectRequest, masterNameMap map[string]string, n
}

func Select(req NICSelectRequest) NICSelectResponse {
masterNameMap := iface.GetInterfaceNameMap()
nameNetMap := iface.GetNameNetMap()
deviceMap := make(map[string]string)
resourceMap := make(map[string][]string)

Expand All @@ -93,6 +91,8 @@ func Select(req NICSelectRequest) NICSelectResponse {
log.Printf("Cannot get pod: %v\n", err)
}

masterNameMap := iface.GetInterfaceNameMap()
nameNetMap := iface.GetNameNetMap()
netSpec, err := MultinicnetHandler.Get(req.NetAttachDefName, req.PodNamespace)
if err != nil {
return getDefaultResponse(req, masterNameMap, nameNetMap, deviceMap, resourceMap)
Expand Down

0 comments on commit bbafa18

Please sign in to comment.