add the ability to add luns dynamically
This commit is contained in:
@@ -103,6 +103,10 @@ func (s *ISCSITargetDriver) NewTarget(tgtName string, configInfo *config.Config)
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s *ISCSITargetDriver) RereadTargetLUNMap() {
|
||||
s.SCSI.RereadTargetLUNMap()
|
||||
}
|
||||
|
||||
func (s *ISCSITargetDriver) AddiSCSIPortal(tgtName string, tpgt uint16, portal string) error {
|
||||
var (
|
||||
ok bool
|
||||
|
||||
@@ -26,6 +26,7 @@ import (
|
||||
type SCSITargetDriver interface {
|
||||
Run() error
|
||||
NewTarget(string, *config.Config) error
|
||||
RereadTargetLUNMap()
|
||||
}
|
||||
|
||||
type TargetDriverFunc func(*SCSITargetService) (SCSITargetDriver, error)
|
||||
|
||||
@@ -37,15 +37,20 @@ type SCSILUMap struct {
|
||||
|
||||
var globalSCSILUMap = SCSILUMap{AllDevices: make(api.LUNMap), TargetsLUNMap: make(map[string]api.LUNMap)}
|
||||
|
||||
func mappingLUN(deviceID uint64, lun uint64, target string) {
|
||||
type LUNMapping struct {
|
||||
TargetName string
|
||||
LUN uint64
|
||||
DeviceID uint64
|
||||
}
|
||||
|
||||
device := globalSCSILUMap.AllDevices[deviceID]
|
||||
lunMap := globalSCSILUMap.TargetsLUNMap[target]
|
||||
func mappingLUN(lm LUNMapping) {
|
||||
device := globalSCSILUMap.AllDevices[lm.DeviceID]
|
||||
lunMap := globalSCSILUMap.TargetsLUNMap[lm.TargetName]
|
||||
if lunMap == nil {
|
||||
globalSCSILUMap.TargetsLUNMap[target] = make(api.LUNMap)
|
||||
lunMap = globalSCSILUMap.TargetsLUNMap[target]
|
||||
globalSCSILUMap.TargetsLUNMap[lm.TargetName] = make(api.LUNMap)
|
||||
lunMap = globalSCSILUMap.TargetsLUNMap[lm.TargetName]
|
||||
}
|
||||
lunMap[lun] = device
|
||||
lunMap[lm.LUN] = device
|
||||
}
|
||||
|
||||
func GetLU(tgtName string, LUN uint64) *api.SCSILu {
|
||||
@@ -66,18 +71,39 @@ func GetTargetLUNMap(tgtName string) api.LUNMap {
|
||||
return lunMap
|
||||
}
|
||||
|
||||
func InitSCSILUMap(config *config.Config) error {
|
||||
var simpleOp *SCSISimpleReservationOperator
|
||||
var ok bool
|
||||
func AddBackendStorage(bs config.BackendStorage) error {
|
||||
globalSCSILUMap.mutex.Lock()
|
||||
defer globalSCSILUMap.mutex.Unlock()
|
||||
_, ok := globalSCSILUMap.AllDevices[bs.DeviceID]
|
||||
if ok {
|
||||
return fmt.Errorf("device %q already exists", bs.DeviceID)
|
||||
}
|
||||
|
||||
lu, err := NewSCSILu(&bs)
|
||||
if err != nil {
|
||||
return fmt.Errorf("Init SCSI LU map error: %v", err)
|
||||
}
|
||||
globalSCSILUMap.AllDevices[bs.DeviceID] = lu
|
||||
return nil
|
||||
}
|
||||
|
||||
func AddLUNMapping(m LUNMapping) error {
|
||||
globalSCSILUMap.mutex.Lock()
|
||||
defer globalSCSILUMap.mutex.Unlock()
|
||||
mappingLUN(m)
|
||||
// Init SCSISimpleReservationOperator
|
||||
op := GetSCSIReservationOperator()
|
||||
if simpleOp, ok := op.(*SCSISimpleReservationOperator); ok {
|
||||
simpleOp.InitLUReservation(m.TargetName, m.DeviceID)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func InitSCSILUMap(config *config.Config) error {
|
||||
for _, bs := range config.Storages {
|
||||
lu, err := NewSCSILu(&bs)
|
||||
if err != nil {
|
||||
return fmt.Errorf("Init SCSI LU map error: %v", err)
|
||||
if err := AddBackendStorage(bs); err != nil {
|
||||
return err
|
||||
}
|
||||
globalSCSILUMap.AllDevices[bs.DeviceID] = lu
|
||||
}
|
||||
|
||||
for tgtName, tgt := range config.ISCSITargets {
|
||||
@@ -86,12 +112,8 @@ func InitSCSILUMap(config *config.Config) error {
|
||||
if err != nil {
|
||||
return fmt.Errorf("LU Number must be a number")
|
||||
}
|
||||
mappingLUN(deviceID, lun, tgtName)
|
||||
// Init SCSISimpleReservationOperator
|
||||
op := GetSCSIReservationOperator()
|
||||
if simpleOp, ok = op.(*SCSISimpleReservationOperator); ok {
|
||||
simpleOp.InitLUReservation(tgtName, deviceID)
|
||||
}
|
||||
m := LUNMapping{DeviceID: deviceID, LUN: lun, TargetName: tgtName}
|
||||
AddLUNMapping(m)
|
||||
}
|
||||
}
|
||||
return nil
|
||||
|
||||
@@ -45,6 +45,15 @@ func (s *SCSITargetService) NewSCSITarget(tid int, driverName, name string) (*ap
|
||||
return target, nil
|
||||
}
|
||||
|
||||
func (s *SCSITargetService) RereadTargetLUNMap() {
|
||||
s.mutex.Lock()
|
||||
defer s.mutex.Unlock()
|
||||
|
||||
for _, tgt := range s.Targets {
|
||||
tgt.Devices = GetTargetLUNMap(tgt.Name)
|
||||
}
|
||||
}
|
||||
|
||||
func FindTargetGroup(target *api.SCSITarget, relPortID uint16) uint16 {
|
||||
for _, tpg := range target.TargetPortGroups {
|
||||
for _, port := range tpg.TargetPortGroup {
|
||||
|
||||
Reference in New Issue
Block a user