[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20170815.215834.141971110430980112.davem@davemloft.net>
Date: Tue, 15 Aug 2017 21:58:34 -0700 (PDT)
From: David Miller <davem@...emloft.net>
To: khalid.aziz@...cle.com
Cc: dave.hansen@...ux.intel.com, corbet@....net, bob.picco@...cle.com,
steven.sistare@...cle.com, pasha.tatashin@...cle.com,
mike.kravetz@...cle.com, mingo@...nel.org,
nitin.m.gupta@...cle.com, kirill.shutemov@...ux.intel.com,
tom.hromatka@...cle.com, eric.saint.etienne@...cle.com,
allen.pais@...cle.com, cmetcalf@...lanox.com,
akpm@...ux-foundation.org, geert@...ux-m68k.org,
tklauser@...tanz.ch, atish.patra@...cle.com,
vijay.ac.kumar@...cle.com, peterz@...radead.org, mhocko@...e.com,
jack@...e.cz, lstoakes@...il.com, hughd@...gle.com,
thomas.tai@...cle.com, paul.gortmaker@...driver.com,
ross.zwisler@...ux.intel.com, dave.jiang@...el.com,
willy@...radead.org, ying.huang@...el.com, zhongjiang@...wei.com,
minchan@...nel.org, vegard.nossum@...cle.com,
imbrenda@...ux.vnet.ibm.com, aneesh.kumar@...ux.vnet.ibm.com,
aarcange@...hat.com, linux-doc@...r.kernel.org,
linux-kernel@...r.kernel.org, sparclinux@...r.kernel.org,
linux-mm@...ck.org, khalid@...ehiking.org
Subject: Re: [PATCH v7 9/9] sparc64: Add support for ADI (Application Data
Integrity)
From: Khalid Aziz <khalid.aziz@...cle.com>
Date: Wed, 9 Aug 2017 15:26:02 -0600
> +void adi_restore_tags(struct mm_struct *mm, struct vm_area_struct *vma,
> + unsigned long addr, pte_t pte)
> +{
...
> + tag = tag_start(addr, tag_desc);
> + paddr = pte_val(pte) & _PAGE_PADDR_4V;
> + for (tmp = paddr; tmp < (paddr+PAGE_SIZE); tmp += adi_blksize()) {
> + version1 = (*tag) >> 4;
> + version2 = (*tag) & 0x0f;
> + *tag++ = 0;
> + asm volatile("stxa %0, [%1] %2\n\t"
> + :
> + : "r" (version1), "r" (tmp),
> + "i" (ASI_MCD_REAL));
> + tmp += adi_blksize();
> + asm volatile("stxa %0, [%1] %2\n\t"
> + :
> + : "r" (version2), "r" (tmp),
> + "i" (ASI_MCD_REAL));
> + }
> + asm volatile("membar #Sync\n\t");
You do a membar here.
> + for (i = pfrom; i < (pfrom + PAGE_SIZE); i += adi_blksize()) {
> + asm volatile("ldxa [%1] %2, %0\n\t"
> + : "=r" (adi_tag)
> + : "r" (i), "i" (ASI_MCD_REAL));
> + asm volatile("stxa %0, [%1] %2\n\t"
> + :
> + : "r" (adi_tag), "r" (pto),
> + "i" (ASI_MCD_REAL));
But not here.
Is this OK? I suspect you need to add a membar this this second piece
of MCD tag storing code.
Powered by blists - more mailing lists