feat: supply: only grab genesis msig locks for writes
This commit is contained in:
parent
dcdd1bc214
commit
bc87017ea5
@ -56,6 +56,8 @@ func (sm *StateManager) setupGenesisVestingSchedule(ctx context.Context) error {
|
|||||||
return xerrors.Errorf("setting up genesis pledge: %w", err)
|
return xerrors.Errorf("setting up genesis pledge: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sm.genesisMsigLk.Lock()
|
||||||
|
defer sm.genesisMsigLk.Unlock()
|
||||||
sm.genesisPledge = gp
|
sm.genesisPledge = gp
|
||||||
|
|
||||||
totalsByEpoch := make(map[abi.ChainEpoch]abi.TokenAmount)
|
totalsByEpoch := make(map[abi.ChainEpoch]abi.TokenAmount)
|
||||||
@ -122,6 +124,8 @@ func (sm *StateManager) setupPostIgnitionVesting(ctx context.Context) error {
|
|||||||
totalsByEpoch[sixYears] = big.NewInt(100_000_000)
|
totalsByEpoch[sixYears] = big.NewInt(100_000_000)
|
||||||
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(300_000_000))
|
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(300_000_000))
|
||||||
|
|
||||||
|
sm.genesisMsigLk.Lock()
|
||||||
|
defer sm.genesisMsigLk.Unlock()
|
||||||
sm.postIgnitionVesting = make([]msig0.State, 0, len(totalsByEpoch))
|
sm.postIgnitionVesting = make([]msig0.State, 0, len(totalsByEpoch))
|
||||||
for k, v := range totalsByEpoch {
|
for k, v := range totalsByEpoch {
|
||||||
ns := msig0.State{
|
ns := msig0.State{
|
||||||
@ -172,6 +176,9 @@ func (sm *StateManager) setupPostCalicoVesting(ctx context.Context) error {
|
|||||||
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(300_000_000))
|
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(300_000_000))
|
||||||
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(9_805_053))
|
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(9_805_053))
|
||||||
|
|
||||||
|
sm.genesisMsigLk.Lock()
|
||||||
|
defer sm.genesisMsigLk.Unlock()
|
||||||
|
|
||||||
sm.postCalicoVesting = make([]msig0.State, 0, len(totalsByEpoch))
|
sm.postCalicoVesting = make([]msig0.State, 0, len(totalsByEpoch))
|
||||||
for k, v := range totalsByEpoch {
|
for k, v := range totalsByEpoch {
|
||||||
ns := msig0.State{
|
ns := msig0.State{
|
||||||
@ -192,21 +199,20 @@ func (sm *StateManager) setupPostCalicoVesting(ctx context.Context) error {
|
|||||||
func (sm *StateManager) GetFilVested(ctx context.Context, height abi.ChainEpoch) (abi.TokenAmount, error) {
|
func (sm *StateManager) GetFilVested(ctx context.Context, height abi.ChainEpoch) (abi.TokenAmount, error) {
|
||||||
vf := big.Zero()
|
vf := big.Zero()
|
||||||
|
|
||||||
sm.genesisMsigLk.Lock()
|
|
||||||
defer sm.genesisMsigLk.Unlock()
|
|
||||||
|
|
||||||
// TODO: combine all this?
|
// TODO: combine all this?
|
||||||
if sm.preIgnitionVesting == nil || sm.genesisPledge.IsZero() {
|
if sm.preIgnitionVesting == nil || sm.genesisPledge.IsZero() {
|
||||||
err := sm.setupGenesisVestingSchedule(ctx)
|
err := sm.setupGenesisVestingSchedule(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return vf, xerrors.Errorf("failed to setup pre-ignition vesting schedule: %w", err)
|
return vf, xerrors.Errorf("failed to setup pre-ignition vesting schedule: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
if sm.postIgnitionVesting == nil {
|
if sm.postIgnitionVesting == nil {
|
||||||
err := sm.setupPostIgnitionVesting(ctx)
|
err := sm.setupPostIgnitionVesting(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return vf, xerrors.Errorf("failed to setup post-ignition vesting schedule: %w", err)
|
return vf, xerrors.Errorf("failed to setup post-ignition vesting schedule: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
if sm.postCalicoVesting == nil {
|
if sm.postCalicoVesting == nil {
|
||||||
err := sm.setupPostCalicoVesting(ctx)
|
err := sm.setupPostCalicoVesting(ctx)
|
||||||
|
Loading…
Reference in New Issue
Block a user