Support zero-initialized pointers in globals

Этот коммит содержится в:
Ayke van Laethem 2018-08-30 05:38:27 +02:00
родитель 5edf94ea10
коммит a5252d07f0
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: E97FF5335DFDFDED
2 изменённых файлов: 12 добавлений и 4 удалений

Просмотреть файл

@ -866,6 +866,13 @@ func (c *Compiler) getInterpretedValue(value Value) (llvm.Value, error) {
return llvm.ConstPtrToInt(elem, c.uintptrType), nil
case *PointerValue:
if value.Elem == nil {
typ, err := c.getLLVMType(value.Type)
if err != nil {
return llvm.Value{}, err
}
return llvm.ConstPointerNull(typ), nil
}
elem, err := c.getInterpretedValue(*value.Elem)
if err != nil {
return llvm.Value{}, err

Просмотреть файл

@ -39,7 +39,7 @@ func (p *Program) interpret(instrs []ssa.Instruction) (int, error) {
if err != nil {
return i, err
}
locals[instr] = &PointerValue{&alloc}
locals[instr] = &PointerValue{nil, &alloc}
case *ssa.Convert:
x, err := p.getValue(instr.X, locals)
if err != nil {
@ -77,7 +77,7 @@ func (p *Program) interpret(instrs []ssa.Instruction) (int, error) {
default:
panic("expected a pointer")
}
locals[instr] = &PointerValue{&structVal.Fields[instr.Field]}
locals[instr] = &PointerValue{nil, &structVal.Fields[instr.Field]}
case *ssa.IndexAddr:
x, err := p.getValue(instr.X, locals)
if err != nil {
@ -95,7 +95,7 @@ func (p *Program) interpret(instrs []ssa.Instruction) (int, error) {
}
switch x := x.(type) {
case *ArrayValue:
locals[instr] = &PointerValue{&x.Elems[index]}
locals[instr] = &PointerValue{nil, &x.Elems[index]}
default:
return i, errors.New("todo: init IndexAddr not on an array or struct")
}
@ -234,7 +234,7 @@ func (p *Program) getZeroValue(t types.Type) (Value, error) {
case *types.Map:
return &MapValue{typ, nil, nil}, nil
case *types.Pointer:
return &PointerValue{nil}, nil
return &PointerValue{typ, nil}, nil
case *types.Struct:
elems := make([]Value, typ.NumFields())
for i := range elems {
@ -265,6 +265,7 @@ type ZeroBasicValue struct {
}
type PointerValue struct {
Type types.Type
Elem *Value
}