File: x86_extras_embed.lem

package info (click to toggle)
sail-ocaml 0.19.1%2Bdfsg5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,008 kB
  • sloc: ml: 75,941; ansic: 8,848; python: 1,342; exp: 560; sh: 474; makefile: 218; cpp: 36
file content (24 lines) | stat: -rw-r--r-- 964 bytes parent folder | download
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