import torch.multiprocessing as mp
import torch

def foo(worker,tl):
    # tl[worker] += (worker+1) * 1000
    tl[worker][:] = torch.tensor([[1, 1], [1, 1]])

if __name__ == '__main__':
    tl = [torch.randn(2, 2), torch.randn(2, 2)]

    for t in tl:
        t.share_memory_()

    print("before mp: tl=")
    print(tl)

    p0 = mp.Process(target=foo, args=(0, tl))
    p1 = mp.Process(target=foo, args=(1, tl))
    p0.start()
    p1.start()
    p0.join()
    p1.join()

    print("after mp: tl=")
    print(tl)
