Rev 4338 | Rev 4344 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 4338 | Rev 4339 | ||
---|---|---|---|
Line 470... | Line 470... | ||
470 | /* |
470 | /* |
471 | * Forward the page fault to address space page fault handler. |
471 | * Forward the page fault to address space page fault handler. |
472 | */ |
472 | */ |
473 | page_table_unlock(AS, true); |
473 | page_table_unlock(AS, true); |
474 | if (as_page_fault(va, PF_ACCESS_EXEC, istate) == AS_PF_FAULT) { |
474 | if (as_page_fault(va, PF_ACCESS_EXEC, istate) == AS_PF_FAULT) { |
475 | fault_if_from_uspace(istate,"Page fault at %p",va); |
475 | fault_if_from_uspace(istate,"Page fault at %p.",va); |
476 | panic("%s: va=%p, rid=%d, iip=%p\n", __func__, va, rid, |
476 | panic("%s: va=%p, rid=%d, iip=%p.", __func__, va, rid, |
477 | istate->cr_iip); |
477 | istate->cr_iip); |
478 | } |
478 | } |
479 | } |
479 | } |
480 | } |
480 | } |
481 | 481 | ||
Line 529... | Line 529... | ||
529 | 529 | ||
530 | dtc_mapping_insert(page, TASK->as->asid, entry); |
530 | dtc_mapping_insert(page, TASK->as->asid, entry); |
531 | return 1; |
531 | return 1; |
532 | } else { |
532 | } else { |
533 | fault_if_from_uspace(istate, |
533 | fault_if_from_uspace(istate, |
534 | "IO access fault at %p", va); |
534 | "IO access fault at %p.", va); |
535 | } |
535 | } |
536 | } |
536 | } |
537 | } |
537 | } |
538 | 538 | ||
539 | return 0; |
539 | return 0; |
Line 581... | Line 581... | ||
581 | /* |
581 | /* |
582 | * Forward the page fault to the address space page fault |
582 | * Forward the page fault to the address space page fault |
583 | * handler. |
583 | * handler. |
584 | */ |
584 | */ |
585 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
585 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
586 | fault_if_from_uspace(istate,"Page fault at %p",va); |
586 | fault_if_from_uspace(istate,"Page fault at %p.",va); |
587 | panic("%s: va=%p, rid=%d, iip=%p\n", __func__, va, rid, |
587 | panic("%s: va=%p, rid=%d, iip=%p.", __func__, va, rid, |
588 | istate->cr_iip); |
588 | istate->cr_iip); |
589 | } |
589 | } |
590 | } |
590 | } |
591 | } |
591 | } |
592 | 592 | ||
Line 597... | Line 597... | ||
597 | * @param vector Interruption vector. |
597 | * @param vector Interruption vector. |
598 | * @param istate Structure with saved interruption state. |
598 | * @param istate Structure with saved interruption state. |
599 | */ |
599 | */ |
600 | void data_nested_tlb_fault(uint64_t vector, istate_t *istate) |
600 | void data_nested_tlb_fault(uint64_t vector, istate_t *istate) |
601 | { |
601 | { |
602 | panic("%s\n", __func__); |
602 | panic("%s.", __func__); |
603 | } |
603 | } |
604 | 604 | ||
605 | /** Data Dirty bit fault handler. |
605 | /** Data Dirty bit fault handler. |
606 | * |
606 | * |
607 | * @param vector Interruption vector. |
607 | * @param vector Interruption vector. |
Line 628... | Line 628... | ||
628 | */ |
628 | */ |
629 | t->d = true; |
629 | t->d = true; |
630 | dtc_pte_copy(t); |
630 | dtc_pte_copy(t); |
631 | } else { |
631 | } else { |
632 | if (as_page_fault(va, PF_ACCESS_WRITE, istate) == AS_PF_FAULT) { |
632 | if (as_page_fault(va, PF_ACCESS_WRITE, istate) == AS_PF_FAULT) { |
633 | fault_if_from_uspace(istate,"Page fault at %p",va); |
633 | fault_if_from_uspace(istate,"Page fault at %p.",va); |
634 | panic("%s: va=%p, rid=%d, iip=%p\n", __func__, va, rid, |
634 | panic("%s: va=%p, rid=%d, iip=%p.", __func__, va, rid, |
635 | istate->cr_iip); |
635 | istate->cr_iip); |
636 | } |
636 | } |
637 | } |
637 | } |
638 | page_table_unlock(AS, true); |
638 | page_table_unlock(AS, true); |
639 | } |
639 | } |
Line 664... | Line 664... | ||
664 | */ |
664 | */ |
665 | t->a = true; |
665 | t->a = true; |
666 | itc_pte_copy(t); |
666 | itc_pte_copy(t); |
667 | } else { |
667 | } else { |
668 | if (as_page_fault(va, PF_ACCESS_EXEC, istate) == AS_PF_FAULT) { |
668 | if (as_page_fault(va, PF_ACCESS_EXEC, istate) == AS_PF_FAULT) { |
669 | fault_if_from_uspace(istate, "Page fault at %p", va); |
669 | fault_if_from_uspace(istate, "Page fault at %p.", va); |
670 | panic("%s: va=%p, rid=%d, iip=%p\n", __func__, va, rid, |
670 | panic("%s: va=%p, rid=%d, iip=%p.", __func__, va, rid, |
671 | istate->cr_iip); |
671 | istate->cr_iip); |
672 | } |
672 | } |
673 | } |
673 | } |
674 | page_table_unlock(AS, true); |
674 | page_table_unlock(AS, true); |
675 | } |
675 | } |
Line 700... | Line 700... | ||
700 | */ |
700 | */ |
701 | t->a = true; |
701 | t->a = true; |
702 | dtc_pte_copy(t); |
702 | dtc_pte_copy(t); |
703 | } else { |
703 | } else { |
704 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
704 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
705 | fault_if_from_uspace(istate, "Page fault at %p", va); |
705 | fault_if_from_uspace(istate, "Page fault at %p.", va); |
706 | panic("%s: va=%p, rid=%d, iip=%p\n", __func__, va, rid, |
706 | panic("%s: va=%p, rid=%d, iip=%p.", __func__, va, rid, |
707 | istate->cr_iip); |
707 | istate->cr_iip); |
708 | } |
708 | } |
709 | } |
709 | } |
710 | page_table_unlock(AS, true); |
710 | page_table_unlock(AS, true); |
711 | } |
711 | } |
Line 741... | Line 741... | ||
741 | dtc_pte_copy(t); |
741 | dtc_pte_copy(t); |
742 | page_table_unlock(AS, true); |
742 | page_table_unlock(AS, true); |
743 | } else { |
743 | } else { |
744 | page_table_unlock(AS, true); |
744 | page_table_unlock(AS, true); |
745 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
745 | if (as_page_fault(va, PF_ACCESS_READ, istate) == AS_PF_FAULT) { |
746 | fault_if_from_uspace(istate, "Page fault at %p", va); |
746 | fault_if_from_uspace(istate, "Page fault at %p.", va); |
747 | panic("%s: va=%p, rid=%d\n", __func__, va, rid); |
747 | panic("%s: va=%p, rid=%d.", __func__, va, rid); |
748 | } |
748 | } |
749 | } |
749 | } |
750 | } |
750 | } |
751 | 751 | ||
752 | /** @} |
752 | /** @} |