summaryrefslogtreecommitdiff
path: root/old/x86/x86_extras_embed.lem
blob: f513099562230909109d187c11e1a160ae4ff147 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
open import Pervasives
open import Pervasives_extra
open import Sail_impl_base
open import Sail_values
open import Prompt

val rMEM             : (vector bitU * integer) -> M (vector bitU)
val rMEM_locked      : (vector bitU * integer) -> M (vector bitU)

let rMEM (addr,size)             = read_mem false Read_plain addr size
let rMEM_locked  (addr,size)     = read_mem false Read_X86_locked addr size

val MEMea                 : (vector bitU * integer) -> M unit
val MEMea_locked          : (vector bitU * integer) -> M unit

let MEMea (addr,size)                 = write_mem_ea Write_plain addr size
let MEMea_locked      (addr,size)     = write_mem_ea Write_X86_locked addr size

val MEMval                 : (vector bitU * integer * vector bitU) -> M unit
val MEMval_conditional     : (vector bitU * integer * vector bitU) -> M bitU

let MEMval (_,_,v)                 = write_mem_val v >>= fun _ -> return ()

let X86_MFENCE () = barrier Barrier_x86_MFENCE