source: mainline/kernel/test/mm/purge1.c@ 9d58539

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 9d58539 was 9d58539, checked in by Prutkov Alex <prutkov.alex@…>, 13 years ago

Fixed unix permissions for all files

  • Property mode set to 100644
File size: 2.7 KB
RevLine 
[7c322bd]1/*
[df4ed85]2 * Copyright (c) 2005 Jakub Jermar
[7c322bd]3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
[f272cb8]28
[7c322bd]29#include <print.h>
30#include <test.h>
31#include <mm/page.h>
32#include <mm/frame.h>
33#include <mm/as.h>
34#include <arch/mm/page.h>
35#include <arch/mm/tlb.h>
[d99c1d2]36#include <typedefs.h>
[7c322bd]37#include <debug.h>
38
39extern void tlb_invalidate_all(void);
[98000fb]40extern void tlb_invalidate_pages(asid_t asid, uintptr_t va, size_t cnt);
[f272cb8]41
[a000878c]42const char *test_purge1(void)
[7c322bd]43{
44 tlb_entry_t entryi;
45 tlb_entry_t entryd;
[96348adc]46
[7c322bd]47 int i;
[17f168e]48
[f272cb8]49 entryd.word[0] = 0;
50 entryd.word[1] = 0;
[17f168e]51
[f272cb8]52 entryd.p = true; /* present */
53 entryd.ma = MA_WRITEBACK;
54 entryd.a = true; /* already accessed */
55 entryd.d = true; /* already dirty */
56 entryd.pl = PL_KERNEL;
57 entryd.ar = AR_READ | AR_WRITE;
58 entryd.ppn = 0;
59 entryd.ps = PAGE_WIDTH;
[7c322bd]60
[f272cb8]61 entryi.word[0] = 0;
62 entryi.word[1] = 0;
63
64 entryi.p = true; /* present */
65 entryi.ma = MA_WRITEBACK;
66 entryi.a = true; /* already accessed */
67 entryi.d = true; /* already dirty */
68 entryi.pl = PL_KERNEL;
69 entryi.ar = AR_READ | AR_EXECUTE;
70 entryi.ppn = 0;
71 entryi.ps = PAGE_WIDTH;
72
73 for (i = 0; i < 100; i++) {
74 itc_mapping_insert(0 + i * (1 << PAGE_WIDTH), 8, entryi);
75 dtc_mapping_insert(0 + i * (1 << PAGE_WIDTH), 9, entryd);
76 }
[7c322bd]77
[17f168e]78 tlb_invalidate_pages(8, 0x0c000, 14);
[7c322bd]79
[17f168e]80 /* tlb_invalidate_all(); */
[96348adc]81
82 return NULL;
[f272cb8]83}
Note: See TracBrowser for help on using the repository browser.