Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[ISAC] - PTE Permissions Check Function and prev. instr. csr track func Updated #563

Open
wants to merge 3 commits into
base: dev
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
61 changes: 37 additions & 24 deletions riscv-isac/riscv_isac/coverage.py
Original file line number Diff line number Diff line change
Expand Up @@ -961,6 +961,7 @@ def compute_per_line(queue, event, cgf_queue, stats_queue, cgf, xlen, flen, addr
old_csr_regfile[i] = int(csr_regfile[i],16)
else:
old_csr_regfile[i] = csr_regfile[i]

def old_fn_csr_comb_covpt(csr_reg):
return old_csr_regfile[csr_reg]

Expand Down Expand Up @@ -1038,31 +1039,43 @@ def get_pte(pa, pte_addr, pgtb_addr):
return None

def get_pte_prop(prop_name, pte_addr):
'''
Function to return whether a specific Permission is given to the PTE or not
:param prop_name: an input property ., example: 'U' for U bit or 'RWX' for a combination of bits
:param pte_addr: PTE address for which we want to get the information
"""
Function to check specific permissions of a PTE.

:param prop_name: string containing properties to check.
Uppercase letters mean the bits should be set.
Lowercase letters mean the bits should NOT be set.
Example: "uAdW" checks U and D bits are NOT set,
while A and W bits are set.
:param pte_addr: PTE address to examine (int or hex).
:return: 1 if conditions are met, 0 otherwise.
"""
if pte_addr is None:
return 0

bitmask_dict = {
'V': 0x01, 'R': 0x02, 'W': 0x04, 'X': 0x08,
'U': 0x10, 'G': 0x20, 'A': 0x40, 'D': 0x80
}

:type prop_name: str
:type pte_addr: hex/int
# Get permission bits from PTE address
pte_per = pte_addr & 0x3FF

# Check each property in prop_name
for char in prop_name:
# Check if uppercase character should be set or lowercase should NOT be set
bitmask = bitmask_dict.get(char.upper())
if bitmask is None:
return 0 # If unrecognized character, then return overall zero prematurely.

if (char.isupper() and not (pte_per & bitmask)) or (char.islower() and (pte_per & bitmask)):
return 0

return 1

:return: 1 or 0 depending whether the specific (or combination of) permission/s is set or not respectively.
'''
bitmask_dict = {'v': 0x01, 'r': 0x02, 'w': 0x04, 'x': 0x08, 'u': 0x10, 'g': 0x20, 'a': 0x40, 'd': 0x80}

if pte_addr is not None:
# Get the permissions bit out of the pte_addr
pte_per = pte_addr & 0x3FF

# Check each character in prop_name
for char in prop_name.lower():
if char in bitmask_dict and (pte_per & bitmask_dict[char] == 0):
return 0
return 1
else:
return 0

globals()['get_addr'] = check_label_address
globals()['old_csr_val'] = old_fn_csr_comb_covpt
globals()['get_mem_val'] = get_mem_val
globals()['get_pte'] = get_pte
globals()['get_pte_prop'] = get_pte_prop
Expand Down Expand Up @@ -1196,7 +1209,7 @@ def get_key_from_value(dictionary, target_value):
return key
return None
#check the old_csr_value only for the register of interest
pattern_csr = r'old\("([^"]+)"\)'
pattern_csr = r'old_csr_val\("([^"]+)"\)'
match = re.search(pattern_csr, coverpoints)
if match:
required_csr = match.group(1)
Expand All @@ -1207,7 +1220,7 @@ def get_key_from_value(dictionary, target_value):
coverpoints,
{
"__builtins__":None,
"old": old_fn_csr_comb_covpt,
"old_csr_val": old_fn_csr_comb_covpt,
"write": write_fn_csr_comb_covpt,
"get_addr": check_label_address,
"get_mem_val":get_mem_val,
Expand Down Expand Up @@ -1238,7 +1251,7 @@ def get_key_from_value(dictionary, target_value):
coverpoints,
{
"__builtins__":None,
"old": old_fn_csr_comb_covpt,
"old_csr_val": old_fn_csr_comb_covpt,
"write": write_fn_csr_comb_covpt,
"get_addr": check_label_address,
"get_mem_val":get_mem_val,
Expand Down