Olivier Houchard
7bfacf3dc6
strd needs the destination to be double-word aligned, but the pointer passed
...
to savectx isn't always, so always use stmia, savectx isn't called enough
to need that kind of optimization.
2005-10-04 20:42:42 +00:00
Olivier Houchard
db7db23dd8
dump_avail has nothing to do with ARM_USE_SMALL_ALLOC, so move its
...
declaration out of the #ifdef.
2005-10-04 16:29:31 +00:00
Olivier Houchard
6270a55ec3
Remove duplicate entry for DDB.
2005-10-04 14:39:33 +00:00
Olivier Houchard
7c616799dc
Fix build when DDB isn't defined.
2005-10-04 14:37:03 +00:00
Olivier Houchard
70359cf526
Bring in the good version of this file.
2005-10-03 22:44:54 +00:00
Olivier Houchard
31fbb5019f
Add dma and aau.
2005-10-03 14:20:44 +00:00
Olivier Houchard
50f31d87f2
Import dummy drivers for the i80321 DMA controller and AAU.
...
The DMA controller driver only knows how to do memory to memory copies, and
the AAU driver how to zero a chunk of memory.
Use them to process big (>=1KB) copying/zeroing.
2005-10-03 14:19:55 +00:00
Olivier Houchard
9ea7c8bb52
Make mem.c know about the pages allocated with ARM_USE_SMALL_ALLOC.
2005-10-03 14:18:21 +00:00
Olivier Houchard
735a72bbee
Export the variables needed for the copy/zero API.
2005-10-03 14:17:45 +00:00
Olivier Houchard
edcbfd05d1
Make sure the interrupt is masked before processing it, or bad things
...
can happen.
2005-10-03 14:17:16 +00:00
Olivier Houchard
1f59105ee7
If a thread already tries to allocate a new memory range, wait for it
...
instead of trying to do the same.
2005-10-03 14:16:41 +00:00
Olivier Houchard
b834efd591
Provide a dump_avail[] variable, which contains the page ranges to be
...
dumped.
For iq31244_machdep.c, attempt to recognize hints provided by the elf
trampoline.
2005-10-03 14:15:50 +00:00
Olivier Houchard
92399cb788
- Provide the kernel l1pt physical address, for userland.
...
- Use the new API for pmap_copy_page() and pmap_zero_page().
- Just write-back the pages in pmap_qenter(), and invalidate it in
pmap_qremove().
- Nuke the cache flushing in pmap_enter_quick(), it's not needed anymore.
2005-10-03 14:13:50 +00:00
Olivier Houchard
0122bd1470
Add a new API to let platform-specific ports provide functions for big
...
copy/zeroing.
2005-10-03 14:12:10 +00:00
Olivier Houchard
87351d5fd2
Export the virtual and physical address in which the kernel was loaded,
...
needed for userland when reading kernel dumps.
2005-10-03 14:10:55 +00:00
Olivier Houchard
b91c6ffecb
Import a small ELF trampoline, in which the kernel is embedded, and that
...
is able to load the kernel into memory, symbol table included. This is
needed to be able to access the symbol table from DDB without a boot
loader.
2005-10-03 14:09:36 +00:00
Olivier Houchard
ffbce9965f
*blush*
...
Don't try to dereference map if it's NULL.
While I'm there, increase the minimum value to write-back/invalidate the
whole dcache in bus_dmamap_sync().
2005-10-03 14:07:57 +00:00
Olivier Houchard
31c197a753
Only save the registers that are used.
2005-10-03 14:07:09 +00:00
Olivier Houchard
93d18f4760
asm versions of in_cksum_hdr() and in_pseudo().
2005-10-03 14:06:44 +00:00
Olivier Houchard
6d918e02d0
Implement savectx().
...
Obtained from: NetBSD
2005-10-03 14:05:38 +00:00
Olivier Houchard
f7a1a1e2e5
Kernel dump for arm, ripped from the ia64/amd64 version.
2005-10-03 14:05:03 +00:00
John Baldwin
3c2bc2bf26
Add a new atomic_fetchadd() primitive that atomically adds a value to a
...
variable and returns the previous value of the variable.
Tested on: i386, alpha, sparc64, arm (cognet)
Reviewed by: arch@
Submitted by: cognet (arm)
MFC after: 1 week
2005-09-27 17:39:11 +00:00
Olivier Houchard
0cc67e3dd6
Fix multiple abuses of __RMAN_RESOURCE_VISIBLE in the arm code.
...
Spotted out by: phk
2005-09-25 21:06:50 +00:00
Marcel Moolenaar
216e80c2ba
Move the prototypes of db_md_set_watchpoint(), db_md_clr_watchpoint()
...
and db_md_list_watchpoints() to ddb/ddb.h.
2005-09-10 03:01:25 +00:00
Alan Cox
ba8bca610c
Pass a value of type vm_prot_t to pmap_enter_quick() so that it determine
...
whether the mapping should permit execute access.
2005-09-03 18:20:20 +00:00
Stefan Farfeleder
a1f85d7f83
Move MINSIGSTKSZ from <machine/signal.h> to <machine/_limits.h> and rename
...
it to __MINSIGSTKSZ. Define MINSIGSTKSZ in <sys/signal.h>.
This is done in order to use MINSIGSTKSZ for the macro PTHREAD_STACK_MIN
in <pthread.h> (soon <limits.h>) without having to include the whole
<sys/signal.h> header.
Discussed with: bde
2005-08-20 16:44:41 +00:00
Jeff Roberson
8d511e2a05
- Add support for saving stack traces and displaying them via printf(9)
...
and KTR.
Contributed by: Antoine Brodin <antoine.brodin@laposte.net>
Concept code from: Neal Fachan <neal@isilon.com>
2005-08-03 04:27:40 +00:00
Warner Losh
95e4208ebf
msdosfs_conv.c references cmos_wall_clock and adjkerntz. Since these
...
are 0 for arm, define them as such to make msdosfs_conv.c compile
again on arm.
2005-07-27 21:19:28 +00:00
John Baldwin
d9610574a2
Add extra constraints to tell the compiler that the memory be modified
...
in the arm __swp() and sparc64 casa() and casax() functions is actually
being used as an input and output and not just the value of the register
that points to the memory location. This was the underlying source of
the mbuf refcount problems on sparc64 a while back. For arm this should be
a nop because __swp() has a constraint to clobber all memory which can
probably be removed now.
Reviewed by: alc, cognet
MFC after: 1 week
2005-07-27 20:01:45 +00:00
John Baldwin
e11fe02dfb
Use a + constraint modifier for a register arg in __bswap16_var().
...
Reviewed by: cognet
2005-07-27 19:59:21 +00:00
John Baldwin
122eceef61
Convert the atomic_ptr() operations over to operating on uintptr_t
...
variables rather than void * variables. This makes it easier and simpler
to get asm constraints and volatile keywords correct.
MFC after: 3 days
Tested on: i386, alpha, sparc64
Compiled on: ia64, powerpc, amd64
Kernel toolchain busted on: arm
2005-07-15 18:17:59 +00:00
David Xu
740fd64d65
Validate if the value written into {FS,GS}.base is a canonical
...
address, writting non-canonical address can cause kernel a panic,
by restricting base values to 0..VM_MAXUSER_ADDRESS, ensuring
only canonical values get written to the registers.
Reviewed by: peter, Josepha Koshy < joseph.koshy at gmail dot com >
Approved by: re (scottl)
2005-07-10 23:31:11 +00:00
Olivier Houchard
758c41b8cc
- Use a TAILQ instead of parsing the array to find a free dmamap.
...
- Inline busdma_alloc_dmamap, busdma_free_dmamap and bus_dmamap_sync_buf.
Approved by: re (blanket)
2005-06-24 23:57:27 +00:00
John Baldwin
dc802c0628
Fix a typo.
...
Approved by: re (scottl)
2005-06-23 21:54:17 +00:00
Olivier Houchard
3ed670fe01
Remove the va == pa mapping.
...
Approved by: re (blanket)
2005-06-23 11:40:45 +00:00
Olivier Houchard
00b931ab2f
Call kdb_trap() on fatal abort.
...
Approved by: re (blanket)
2005-06-23 11:39:18 +00:00
Olivier Houchard
31897fe80e
Implement db_frame() and use it to obtain the registers value.
...
Approved by: re (blanket)
2005-06-23 11:38:47 +00:00
Olivier Houchard
a95e819956
Don't abuse UMA_SLAB_KMEM.
...
Approved by: re (blanket)
2005-06-23 11:37:41 +00:00
David E. O'Brien
c3e0dfa1f8
Add .cvsignore files just like in sys/<arch>/compiled, this keeps CVS from
...
questing kernel config files not in CVS.
Approved by: re(kensmith)
2005-06-20 16:52:59 +00:00
Olivier Houchard
acc48b2a89
Try harder to detect if the allocated memory for L2 PTP comes from a 1MB
...
section or not.
Approved by: re (blanket)
2005-06-16 13:23:39 +00:00
Olivier Houchard
a56da6d0d2
Don't pass the kernel_pmap to pmap_fault_fixup() if the fault comes from
...
kernel mode, always use the curthread pmap instead. There are valid cases
were we can fault on a user address from the kernel without pcb_onfault
being set.
Approved by: re (blanket)
2005-06-16 13:21:52 +00:00
Olivier Houchard
8f47151b3b
Remove the last use of pmap_initialized.
2005-06-10 13:31:30 +00:00
Alan Cox
1c245ae7d1
Introduce a procedure, pmap_page_init(), that initializes the
...
vm_page's machine-dependent fields. Use this function in
vm_pageq_add_new_page() so that the vm_page's machine-dependent and
machine-independent fields are initialized at the same time.
Remove code from pmap_init() for initializing the vm_page's
machine-dependent fields.
Remove stale comments from pmap_init().
Eliminate the Boolean variable pmap_initialized from the alpha, amd64,
i386, and ia64 pmap implementations. Its use is no longer required
because of the above changes and earlier changes that result in physical
memory that is being mapped at initialization time being mapped without
pv entries.
Tested by: cognet, kensmith, marcel
2005-06-10 03:33:36 +00:00
Joseph Koshy
f263522a45
MFP4:
...
- Implement sampling modes and logging support in hwpmc(4).
- Separate MI and MD parts of hwpmc(4) and allow sharing of
PMC implementations across different architectures.
Add support for P4 (EMT64) style PMCs to the amd64 code.
- New pmcstat(8) options: -E (exit time counts) -W (counts
every context switch), -R (print log file).
- pmc(3) API changes, improve our ability to keep ABI compatibility
in the future. Add more 'alias' names for commonly used events.
- bug fixes & documentation.
2005-06-09 19:45:09 +00:00
Olivier Houchard
7fde88ae25
Use tabs, not spaces.
...
Reported by: ru
2005-06-09 15:05:09 +00:00
Olivier Houchard
d9948bbcbf
Add ata stuff.
2005-06-09 12:32:15 +00:00
Olivier Houchard
f60e923b23
- MFp4: modify slightly the arm intr API, there's arm CPUs with more than 32
...
interrupts.
- Implement teardown methods where appropriate.
2005-06-09 12:26:20 +00:00
Olivier Houchard
56e472e2b5
Add a new arm-specific option, ARM_USE_SMALL_ALLOC. If defined, it provides
...
an implementation of uma_small_alloc() which tries to preallocate memory
1MB per 1MB, and maps it into a section mapping.
2005-06-07 23:04:24 +00:00
Olivier Houchard
094df9739b
Bring in bits I forgot while importing write back support for arm9.
2005-06-03 19:49:53 +00:00
Olivier Houchard
c8a2d8f19c
Remove a useless printf.
2005-06-03 15:15:26 +00:00
Marcel Moolenaar
470cd51ee6
Create nexus in configure_first() instead of in configure(). This
...
makes sure that sysinit tasks that run after configure_first(),
but before configure() have a nexus to hang devices off.
2005-05-29 23:44:22 +00:00
Marcel Moolenaar
e085487fe8
Call cninit_finish() and set cold to 0 in configure_final() instead
...
of in configure(). Call cninit_finish() before setting cold to 0.
This is how it's done for other platforms. Be alike to avoid problems.
2005-05-29 22:45:36 +00:00
Yoshihiro Takahashi
d4fcf3cba5
Remove bus_{mem,p}io.h and related code for a micro-optimization on i386
...
and amd64. The optimization is a trivial on recent machines.
Reviewed by: -arch (imp, marcel, dfr)
2005-05-29 04:42:30 +00:00
Olivier Houchard
2e2955f6f6
Remove pmap_deactivate(), we do not use it.
2005-05-27 00:45:39 +00:00
Olivier Houchard
e59bc6b04e
s/_KLD_MODULE/KLD_MODULE/
2005-05-26 16:05:22 +00:00
Olivier Houchard
c6ec1ba390
Don't enable interrupts in the dispatcher, there's no need to do so.
2005-05-26 15:02:47 +00:00
Olivier Houchard
9aeb6688ad
Don't call vm_page_dirty() in pmap_nuke_pv(), it's not the place to do so, and
...
it leads to funny things, such as pmap_remove_all() marking the page as dirty.
2005-05-26 15:01:13 +00:00
Olivier Houchard
08a94fbcf9
Remove bits specific to CPUs we won't support (< armv4).
2005-05-25 13:46:32 +00:00
Olivier Houchard
a0e94dd924
Increase the refresh rate.
2005-05-25 13:44:55 +00:00
Olivier Houchard
5b45c9f2a1
MFp4: Setup arm9 to write back by default.
...
Obtained from: NetBSD
2005-05-24 23:57:22 +00:00
Olivier Houchard
ef6f667f2e
Remove kcopy(), we don't use it.
2005-05-24 23:55:09 +00:00
Olivier Houchard
ad0557149f
We need to decrease p->p_lock after vm_fault() has been called.
2005-05-24 23:06:02 +00:00
Olivier Houchard
47b3d09bb0
Correctly setup the UND stack in cpu_set_upcall(), and the trapframe in
...
cpu_thread_setup(), as done in cpu_fork().
2005-05-24 23:05:26 +00:00
Olivier Houchard
15ba408fd7
- Try to avoid calling malloc() in bus_dmamap_create() and bus_dmamem_alloc()
...
for the dmamap by using static dmamaps.
- Don't do anything for BUS_DMASYNC_PREREAD and BUS_DMASYNC_POSTWRITE in
bus_dmamap_sync(), it's not needed anymore.
2005-05-24 22:10:35 +00:00
Olivier Houchard
f1f49518d4
Write back affected pages in pmap_qremove() as well. This removes the need
...
to change the DACR when switching to a kernel thread, thus making
userland thread => kernel thread => same userland thread switch cheaper by
totally avoiding data cache and TLB invalidation.
2005-05-24 21:47:10 +00:00
Olivier Houchard
04e48248ca
Use a more sane value for HZ.
2005-05-24 21:45:26 +00:00
Olivier Houchard
0f18d3256d
Use asm versions of in_cksum() and friends.
2005-05-24 21:44:34 +00:00
Olivier Houchard
fdc05f7913
Asm version of bswap16().
...
Obtained from: NetBSD
2005-05-24 21:43:16 +00:00
Olivier Houchard
fa7e20fdd4
Make sure we clean the RAS start address once we're done.
...
This fixes the random segfaults which occurs at high interrupts rate.
2005-05-24 21:42:31 +00:00
Olivier Houchard
e85d3fc3c8
Don't forget to copy the TP when forking, or bad things will happen to the
...
child process if it tries to use threads.
2005-05-11 21:20:42 +00:00
Olivier Houchard
a74efe926c
Allocating the memory for the kernel stack one time is enough.
2005-04-27 13:29:54 +00:00
Olivier Houchard
42722183bf
Don't use fusufault in casuptr(), as it assumes the current PCB will be
...
stored in r2, which can't be easily done with casuptr(). Introduce
casuptrfault instead.
2005-04-23 16:45:04 +00:00
David Xu
21fc316430
Change cpu_set_kse_upcall to more generic style, so we can reuse it
...
in other codes. Add cpu_set_user_tls, use it to tweak user register
and setup user TLS. I ever wanted to merge it into cpu_set_kse_upcall,
but since cpu_set_kse_upcall is also used by M:N threads which may
not need this feature, so I wrote a separated cpu_set_user_tls.
2005-04-23 02:32:32 +00:00
Marcel Moolenaar
ff7125a623
Add empty header (except of the multiple-inclusion protection) to
...
get hwpmc(4) to compile on this platform.
2005-04-20 18:44:53 +00:00
Warner Losh
06db52b609
Break out the definition of bus_space_{tag,handle}_t and a few other types
...
into _bus.h to help with name space polution from including all of bus.h.
In a few days, I'll commit changes to the MI code to take advantage of thse
sepration (after I've made sure that these changes don't break anything in
the main tree, I've tested in my trees, but you never know...).
Suggested by: bde (in 2002 or 2003 I think)
Reviewed in principle by: jhb
2005-04-18 21:45:34 +00:00
Olivier Houchard
758e4f6878
Unbreak the vector_page == 0x00000000 case. Map the vector page L1PT into the
...
kernel domain for each pmap, as we don't update the page table when we're
switching to a kernel thread, but we do however update the DACR.
2005-04-14 14:32:32 +00:00
Olivier Houchard
f5c4c316eb
pmap_update() is gone.
2005-04-13 16:02:03 +00:00
John Baldwin
aa9aa68d2f
Use PCPU_LAZY_INC() for cnt.v_{intr,trap,syscalls} rather than atomic
...
operations in some places and simple non-per CPU math in others.
2005-04-12 23:18:54 +00:00
Olivier Houchard
ec2b39b483
We have an asm version of bcmp(), so we could use it as well.
2005-04-12 22:46:09 +00:00
Olivier Houchard
ebc58b7dbc
Don't announce the range SDRAM_START-freemempos until I figure out what's
...
going on, it produces random memory corruption.
2005-04-07 22:04:18 +00:00
Olivier Houchard
d4d0079826
pmap_update() is gone.
2005-04-07 22:03:34 +00:00
Olivier Houchard
2d93998b00
Import a basic implementation of the restartable atomic sequences to provide
...
atomic operations to userland (this is OK for UP only, but SMP is still so
far away).
2005-04-07 22:03:04 +00:00
Olivier Houchard
139e3f7c33
- Try harder to report dirty page.
...
- Garbage-collect pmap_update(), it became quite useless.
2005-04-07 22:01:53 +00:00
John Baldwin
c6a37e8413
Divorce critical sections from spinlocks. Critical sections as denoted by
...
critical_enter() and critical_exit() are now solely a mechanism for
deferring kernel preemptions. They no longer have any affect on
interrupts. This means that standalone critical sections are now very
cheap as they are simply unlocked integer increments and decrements for the
common case.
Spin mutexes now use a separate KPI implemented in MD code: spinlock_enter()
and spinlock_exit(). This KPI is responsible for providing whatever MD
guarantees are needed to ensure that a thread holding a spin lock won't
be preempted by any other code that will try to lock the same lock. For
now all archs continue to block interrupts in a "spinlock section" as they
did formerly in all critical sections. Note that I've also taken this
opportunity to push a few things into MD code rather than MI. For example,
critical_fork_exit() no longer exists. Instead, MD code ensures that new
threads have the correct state when they are created. Also, we no longer
try to fixup the idlethreads for APs in MI code. Instead, each arch sets
the initial curthread and adjusts the state of the idle thread it borrows
in order to perform the initial context switch.
This change is largely a big NOP, but the cleaner separation it provides
will allow for more efficient alternative locking schemes in other parts
of the kernel (bare critical sections rather than per-CPU spin mutexes
for per-CPU data for example).
Reviewed by: grehan, cognet, arch@, others
Tested on: i386, alpha, sparc64, powerpc, arm, possibly more
2005-04-04 21:53:56 +00:00
Olivier Houchard
7fc53c7b12
Bring in a version of float.h more correct for softfloat.
2005-03-20 00:34:24 +00:00
Olivier Houchard
3ea9d07445
Bring back some of the cleanups and fixes jmg did in the TS7200 port.
2005-03-17 23:01:15 +00:00
Olivier Houchard
4290208c24
Use PCIR_BARS instead of PCIR_MAPS.
2005-03-17 00:43:57 +00:00
Olivier Houchard
2eeafe13a6
Introduce a new function, pmap_wb_page(), which check all userland mappings for
...
a given page and, if the pmap is the current pmap, write back the associated
cache line.
Use pmap_wb_page in pmap_qenter() instead of inconditionally
write back/invalidating the data cache.
2005-03-16 23:56:29 +00:00
John-Mark Gurney
98c8f18cf0
MFp4: add in making fiq's work by coping to the correct page incase we have
...
the vectors relocated high..
2005-03-16 07:56:21 +00:00
John-Mark Gurney
c28a40615d
fix up white space, I had a simple comment fix, but I might as well do the
...
rest while I'm here...
2005-03-16 07:53:02 +00:00
John-Mark Gurney
de71467ca7
make bus_dmamem_alloc always allocate a new map like we are suppose to..
...
This was found when I tried to run the usb code on my arm board...
Approved by: cognet
2005-03-16 00:35:59 +00:00
John-Mark Gurney
19015c15ed
fix arm wrt to busdma...
...
also wrap the two macros that have bare if's w/ do {} while(0) so that
my epe driver doesn't get a warning about braces around confused else...
2005-03-15 14:57:30 +00:00
Scott Long
5974e5c71c
Refactor the bus_dma header files so that the interface is described in
...
sys/bus_dma.h instead of being copied in every single arch. This slightly
reorders a flag that was specific to AXP and thus changes the ABI there.
The interface still relies on bus_space definitions found in <machine/bus.h>
so it cannot be included on its own yet, but that will be fixed at a later
date. Add an MD <machine/bus_dma.h> for ever arch for consistency and to
allow for future MD augmentation of the API. sparc64 makes heavy use of
this right now due to its different bus_dma implemenation.
2005-03-14 16:46:28 +00:00
Maxime Henrion
68d9d1e64e
Fixup KTR traces.
2005-03-08 14:49:05 +00:00
Maxime Henrion
5d18cf7825
Use __func__ in the KTR_BUSDMA traces. This avoids copy and paste
...
errors like in the bus_dmamap_load_mbuf_sg() case where we were wrongly
displaying the function name as bus_dmamap_load_mbuf.
2005-03-08 11:18:14 +00:00
Maxime Henrion
cebf474d0d
Fix typo.
2005-03-07 00:24:52 +00:00
Olivier Houchard
7a7e7cf91e
Use [ldr|str]t instead of [ldr|str] when accessing ARM_TP_ADDRESS.
2005-03-06 21:12:03 +00:00
Olivier Houchard
da53588551
Make sure ARM_TP_ADDRESS is accessible right now by calling pmap_fault_fixup,
...
as we can't rely on a trap happening, as it is done normally.
While I'm there, uncomment the call to cpu_dcache_wbinv_range() in
pmap_kenter_internal, as we don't call cpu_dcache_wbinv_all() there anymore.
2005-03-06 21:10:31 +00:00
Olivier Houchard
2ba823e954
Unlike NetBSD's bcopy(), our bcopy allows the two strings to overlap, even in
...
kernel. So bring in the userland version, instead of just calling memcpy.
2005-03-06 13:11:32 +00:00
Olivier Houchard
f18b179cc9
Handle endianness correctly.
...
Spotted out by: jmg
2005-03-03 23:27:09 +00:00
Joerg Wunsch
a5f50ef9e4
netchild's mega-patch to isolate compiler dependencies into a central
...
place.
This moves the dependency on GCC's and other compiler's features into
the central sys/cdefs.h file, while the individual source files can
then refer to #ifdef __COMPILER_FEATURE_FOO where they by now used to
refer to #if __GNUC__ > 3.1415 && __BARC__ <= 42.
By now, GCC and ICC (the Intel compiler) have been actively tested on
IA32 platforms by netchild. Extension to other compilers is supposed
to be possible, of course.
Submitted by: netchild
Reviewed by: various developers on arch@, some time ago
2005-03-02 21:33:29 +00:00
Olivier Houchard
35e75c686f
In cpu_throw(), correctly calculate td->td_md.md_tp.
...
In cpu_switch(), set the DACR even if we're switching to a kernel thread.
2005-03-01 20:51:37 +00:00
Olivier Houchard
c598a8a25c
Introduce realmem.
2005-03-01 20:12:52 +00:00
Olivier Houchard
f4c01f1508
Instead of using sysarch() to store-retrieve the tp, add a magic address,
...
ARM_TP_ADDRESS, where the tp will be stored. On CPUs that support it, a cache
line will be allocated and locked for this address, so that it will never go
to RAM. On CPUs that does not, a page is allocated for it (it will be a bit
slower, and is wrong for SMP, but should be fine for UP).
The tp is still stored in the mdthread struct, and at each context switch,
ARM_TP_ADDRESS gets updated.
Suggested by: davidxu
2005-02-26 18:59:01 +00:00
Olivier Houchard
b6e4194946
Add the field in the md part of the struct thread required by ARM_[GET|SET]_TP.
2005-02-26 00:02:14 +00:00
Olivier Houchard
a74985cdd4
Implement two new sysarch for arm, ARM_GET_TP and ARM_SET_TP, to work around
...
the lack of tls on arm.
2005-02-25 22:56:16 +00:00
Olivier Houchard
38e285f83a
Make sure casuptr() reset pcb->pcb_onfault when returning.
2005-02-25 22:54:56 +00:00
Olivier Houchard
6d4b3b4cb5
MFp4: get the code that set the pc correctly to work, remove a few IQ31244
...
specific mappings from locore.S, re-organize iq31244_machdep.c to work with
the new locore.S
Spotted out by: jmg
2005-02-20 21:34:59 +00:00
Olivier Houchard
2f5f750d3c
Removing the #endif as well sounds like a good idea.
2005-02-20 01:26:01 +00:00
Olivier Houchard
8c06401dab
In cpufunc_control, uncomment the code responsible for returning the old
...
state of the control register.
2005-02-20 01:24:46 +00:00
Ruslan Ermilov
3971d2cf5e
Use a common multi-inclusion protection, and add such a
...
protection to alpha/include/exec.h.
2005-02-19 21:16:48 +00:00
Olivier Houchard
1a34245881
Support high vectors for arm9.
...
Obtained from: NetBSD
2005-02-18 17:29:12 +00:00
Olivier Houchard
31d0686d2d
Define NIRQ to 64 for CPU_ARM9, because Cirrus Logic EP93XX cores provides
...
64 irqs.
This should be re-thought later.
2005-02-13 18:26:31 +00:00
Olivier Houchard
014ef5788e
Remove unused prototype.
2005-02-13 18:20:39 +00:00
Olivier Houchard
b4274227d1
Remove redondant includes.
2005-02-13 18:05:36 +00:00
Olivier Houchard
52bd27f431
Don't prototype pmap_kenter().
2005-02-13 17:18:20 +00:00
John-Mark Gurney
9c21341304
move pmap.h after vm.h include... some of the headers from pmap.h depend
...
upon vm.h
2005-02-09 00:10:17 +00:00
Nate Lawson
3888a87205
Finish the job of sorting all includes and fix the build by including
...
malloc.h before proc.h on sparc64. Noticed by das@
Compiled on: alpha, amd64, i386, pc98, sparc64
2005-02-06 01:55:08 +00:00
Nate Lawson
a287c0ffaf
Sort includes a little so that bus.h comes before cpu.h (for device_t).
2005-02-04 06:58:09 +00:00
Nate Lawson
4c4381e288
Add an implementation of cpu_est_clockrate(9). This function estimates the
...
current clock frequency for the given CPU id in units of Hz.
2005-02-04 05:32:56 +00:00
Nate Lawson
3d7d8f614b
Sort functions.
2005-02-01 06:36:27 +00:00
Olivier Houchard
4b62274965
Make sure we can boot both with and without MMU enabled.
2005-01-23 22:08:31 +00:00
Olivier Houchard
356607e0c6
Define bus_dmamap_load_buffer before bus_dmamap_load to make gcc happy.
2005-01-23 22:07:33 +00:00
Olivier Houchard
3382533d46
Fix compile for !KTR.
2005-01-23 21:39:23 +00:00
Olivier Houchard
a881074e10
Remove references to non-existing symbols DO_corb and got_mmu.
...
While I'm there, remove dead code.
2005-01-20 22:23:26 +00:00
Olivier Houchard
3d8e3adb3e
Fix compile for __ARMEB__.
2005-01-19 16:22:20 +00:00
Olivier Houchard
1f6c8bc54b
MFpowerpc: Work around the problem of returning a 32 bits value from
...
__syscall() on a 32 bits big-endian arch.
Spotted out by: grehan
2005-01-19 00:37:03 +00:00
Olivier Houchard
12a58da422
Start to support the big endian case as well.
2005-01-18 15:51:50 +00:00
Olivier Houchard
a9357c744c
Add a new sysctl, hw.sevenseg.freq, to control the update frequency.
2005-01-16 13:18:52 +00:00
Olivier Houchard
fde8140fde
Erm, don't forget to store the mbuf in the dmamap in bus_dmamap_load_mbuf_sg(),
...
so that bus_dmamap_sync() knows what to invalidate. This makes em(4) work again.
While I'm there, remove the unused "first" variable.
2005-01-16 13:15:16 +00:00
Olivier Houchard
de76196323
Add support for KTR_BUSDMA.
2005-01-15 19:42:28 +00:00
Olivier Houchard
34c8913825
Add the prototype for bus_dmamap_load_mbuf_sg().
...
Spotted out by: scottl
2005-01-15 19:31:08 +00:00
Olivier Houchard
5134102b9d
MFi386: add bus_dmamap_load_mbuf_sg().
2005-01-15 19:07:23 +00:00
Olivier Houchard
6728fc65cc
Add the 7 seg display.
2005-01-15 18:55:40 +00:00
Olivier Houchard
4801ad2f3c
Add support for the IQ31244 7 seg display.
...
Obtained from: NetBSD
2005-01-15 18:55:22 +00:00
Olivier Houchard
7c1658d122
Start the license statement with /*-
2005-01-15 18:38:10 +00:00
Olivier Houchard
70861d0ddd
Use device_set_desc().
2005-01-15 16:57:00 +00:00
Olivier Houchard
d29e12242c
Add the i80321 watchdog.
2005-01-15 16:56:22 +00:00
Olivier Houchard
c1729ff0d5
Add a driver for the i80321 watchdog.
...
Obtained from: NetBSD
2005-01-15 16:54:35 +00:00
Olivier Houchard
9026d36c6e
Add support for ptrace() and gdb breakpoints.
2005-01-10 22:43:16 +00:00
Olivier Houchard
8b64f2f5ad
Don't assume pmap_update() will cpwait for us, pmap_update will disappear soon.
2005-01-10 22:41:08 +00:00
Warner Losh
d8315c79d9
Start all license statements with /*-
2005-01-05 21:58:49 +00:00
Alan Cox
1f70d62298
Modify pmap_enter_quick() so that it expects the page queues to be locked
...
on entry and it assumes the responsibility for releasing the page queues
lock if it must sleep.
Remove a bogus comment from pmap_enter_quick().
Using the first change, modify vm_map_pmap_enter() so that the page queues
lock is acquired and released once, rather than each time that a page
is mapped.
2004-12-23 20:16:11 +00:00
Olivier Houchard
e1e6b9d3c6
- The IQ80321 has a jumper which changes the PCI device id from 4 to 8 for the
...
GigE controller, so handle this.
- Use the outbound window 0 if the PCI mem requested is in its range, instead
of inconditionally use the outbound window 1.
This should be enough to get FreeBSD/arm to work on the IQ80321 board as well.
Reported and tested by: Jia-Shiun Li <jiashiun at gmail dot com>
2004-12-21 11:36:09 +00:00
Olivier Houchard
885dabe5f7
Update the StrongArm port to match the current code.
...
- Implement arm_mask_irqs and arm_unmask_irqs
- Provide the available physical address range after pmap_bootstrap allocated
things, instead or before, or bad things happen.
2004-12-18 17:58:49 +00:00
Olivier Houchard
31e3e209b1
Make sure gcc doesn't generate something such as swp r3, r4, [r3] for __swp,
...
as it has unpredictable results.
2004-12-18 17:43:01 +00:00
Alan Cox
85f5b24573
In the common case, pmap_enter_quick() completes without sleeping.
...
In such cases, the busying of the page and the unlocking of the
containing object by vm_map_pmap_enter() and vm_fault_prefault() is
unnecessary overhead. To eliminate this overhead, this change
modifies pmap_enter_quick() so that it expects the object to be locked
on entry and it assumes the responsibility for busying the page and
unlocking the object if it must sleep. Note: alpha, amd64, i386 and
ia64 are the only implementations optimized by this change; arm,
powerpc, and sparc64 still conservatively busy the page and unlock the
object within every pmap_enter_quick() call.
Additionally, this change is the first case where we synchronize
access to the page's PG_BUSY flag and busy field using the containing
object's lock rather than the global page queues lock. (Modifications
to the page's PG_BUSY flag and busy field have asserted both locks for
several weeks, enabling an incremental transition.)
2004-12-15 19:55:05 +00:00
Olivier Houchard
44dd466610
Enable interrupts once the active ones have been masked.
2004-12-14 18:57:21 +00:00
Olivier Houchard
353d54aa83
Update the sp after popping the regs.
...
This is a good candidate for the golden pointy hat awards.
2004-12-14 18:45:05 +00:00
Olivier Houchard
eb64032876
Save a few more cycles in cpu_switch() and cpu_throw().
2004-12-12 19:21:58 +00:00
Olivier Houchard
cb13ab5bd1
Fix style.
2004-12-11 23:56:03 +00:00
Olivier Houchard
6cf1dd4f37
Add entries to trace syscalls with KTR.
2004-12-11 23:54:03 +00:00
Olivier Houchard
fd4d461166
Fix compilation with INVARIANTS.
2004-12-11 14:46:52 +00:00
Olivier Houchard
84b30e2247
s/RETEQ/RETeq/.
2004-12-10 16:49:08 +00:00
Olivier Houchard
f4427f30f7
Include <sys/signalvar.h> for trapsignal().
2004-12-07 17:39:42 +00:00
Olivier Houchard
79f40e185d
Make sure to map the whole kernel into 1MB pages. Try to use the remaining
...
memory for things such as the kernel stack.
2004-12-05 22:48:04 +00:00
Olivier Houchard
f4deb15f08
Reactivate the use of the minidata cache.
2004-12-05 22:47:25 +00:00
Olivier Houchard
4090854334
Do not change the page directory and do not flush the TLB when switching to
...
a kernel thread.
2004-12-05 22:46:59 +00:00
Olivier Houchard
b62e66eb1f
Remove an unused field from the struct pv_entry.
...
While I'm there, fix style.
2004-12-05 22:46:30 +00:00
Olivier Houchard
28ec399c5a
Include <sys/signalvar.h> for trapsignal().
2004-12-02 23:31:48 +00:00
David Schultz
6004362e66
Don't include sys/user.h merely for its side-effect of recursively
...
including other headers.
2004-11-27 06:51:39 +00:00
Olivier Houchard
a27952c1a9
Enable interrupts as soon as the pending interrupts have been masked.
2004-11-23 16:31:16 +00:00
Olivier Houchard
6054abc495
Use ns8250.
2004-11-23 16:30:50 +00:00
Olivier Houchard
b1ff74ebb3
Cleanup.
2004-11-21 19:41:27 +00:00
Olivier Houchard
7fc1bf0371
Set the frame pointer to 0 in fork_trampoline().
2004-11-21 19:33:47 +00:00
Olivier Houchard
9ebe15a1d7
Implement breakpoints and single stepping on arm.
...
Obtained from: NetBSD
2004-11-21 18:11:39 +00:00
Olivier Houchard
7b90b2998e
Remove useless code.
2004-11-20 16:52:30 +00:00
Olivier Houchard
3488a2f7d9
Implement enough to be able to enter and leave DDB.
2004-11-20 16:52:10 +00:00
Olivier Houchard
579d53f4cf
Get the kernel stack right now that the u-area is gone.
2004-11-20 16:51:32 +00:00
David Schultz
d305a6da98
Remove UAREA_PAGES and USPACE definitions. The definitions of
...
USPACE_SVC_STACK_TOP, USPACE_SVC_STACK_BOTTOM, USPACE_UNDEF_STACK_TOP,
and USPACE_UNDEF_STACK_BOTTOM look wrong to me, so I'm leaving them
alone.
Reviewed by: arch@
2004-11-20 02:31:37 +00:00
David Schultz
837f4b104e
Remove some references to U area here while trying not to break
...
anything. Someone with ARM hardware could do a lot more to untangle
this code.
Reviewed by: arch@
2004-11-20 02:31:23 +00:00
David Schultz
6484fde022
Remove references to U area and garbage collect includes.
...
Reviewed by: arch@
2004-11-20 02:30:59 +00:00
David Schultz
11111b709f
U areas are going away, so don't allocate one for process 0.
...
Reviewed by: arch@
2004-11-20 02:29:25 +00:00
Olivier Houchard
a8a2a16a08
Increase cnt.v_syscall and cnt.v_trap when needed.
2004-11-20 00:55:57 +00:00
Olivier Houchard
0e425b6c47
Move KERNPHYSADDR and KERNVIRTADDR from std.i80321 to std.iq31244.
...
Use the correct KERNPHYSADDR.
2004-11-18 00:05:09 +00:00
Olivier Houchard
826a7f03c5
Simplify a bit bus_dmamap_load_buffer by removing the "first" parameter, use
...
nseg == -1 instead.
Obtained from: NetBSD
2004-11-16 00:57:44 +00:00
Olivier Houchard
1101dd6d06
MFi386:
...
- inlina bus_dmamap_load_buffer
- Directly pass the pmap to bus_dmamap_load_buffer, instead of the struct thread
2004-11-15 23:59:28 +00:00
Olivier Houchard
5918fe42a0
Remove debugging printf.
2004-11-13 15:12:26 +00:00
Olivier Houchard
24c6f4b32a
Don't forget to clear the PG_WRITEABLE flag when appropriate.
2004-11-13 14:54:31 +00:00
Olivier Houchard
4c44e1ec63
Use uma_prealloc() on the l2table_zone to prevent a LOR at startup.
2004-11-13 14:41:27 +00:00
Olivier Houchard
8e10380a9f
Implement interrupt counting, so that vmstat -i work.
2004-11-12 21:49:05 +00:00
Olivier Houchard
ef7d17237a
Don't forget to include opt_vm.h.
2004-11-10 22:11:08 +00:00
Olivier Houchard
9aeab9eabe
Convert the IQ31244 code to use ARM32_NEW_VM_LAYOUT.
2004-11-10 22:09:39 +00:00
Olivier Houchard
b599237edb
Invalidate the data cache in pmap_qremove() instead of in pmap_kenter(),
...
and in pmap_enter_quick() instead of pmap_enter().
2004-11-10 21:46:04 +00:00
Tom Rhodes
adcb844412
Remove __P here too.
...
Ok'ed by: cognet
2004-11-10 01:33:42 +00:00
Olivier Houchard
2fd21813b0
Use the RET macro.
2004-11-09 16:47:47 +00:00
Olivier Houchard
5f2c6402db
Import a RET macro, that will use bx if the arch supports it.
...
Obtained from: NetBSD
2004-11-09 16:45:55 +00:00
Alan Cox
d3cb0d99e0
Introduce two new options, "CPU private" and "no wait", to sf_buf_alloc().
...
Change the spelling of the "catch" option to be consistent with the new
options. Implement the "no wait" option. An implementation of the "CPU
private" for i386 will be committed at a later date.
2004-11-08 00:43:46 +00:00
Olivier Houchard
b720bb34f3
Add device mem in config files.
2004-11-07 23:02:15 +00:00
Olivier Houchard
e099742e25
Import md bits for mem(4) on arm.
...
While I'm there, cleanup a bit pmap.h.
2004-11-07 23:01:36 +00:00
Olivier Houchard
1b135a7e11
Remove useless code.
2004-11-07 16:51:33 +00:00
Olivier Houchard
432f5e3ab9
Disable interrupts for atomic_cmpset_32, this one is just not atomic.
...
Don't export it to userland.
2004-11-05 23:48:12 +00:00
Olivier Houchard
bd366a3cd4
Copy the syscall args in a tmp variable instead of directly using the
...
trapframe, as it can be modified in the syscall.
Call thread_user_enter() when appropriate.
2004-11-05 19:57:10 +00:00
Olivier Houchard
8ecf6f65d9
Save a few cycles in context switch.
...
Update comments to reflect reality.
2004-11-05 19:54:13 +00:00
Olivier Houchard
90f794aaaf
If we're still running at the physical address, jump to the virtual address
...
instead before calling initarm().
This removes the need to map virtual == physical in initarm().
2004-11-05 19:52:55 +00:00
Olivier Houchard
321c47170e
Be more verbose about cache capacities.
2004-11-05 19:51:23 +00:00
Olivier Houchard
d20a408be7
Implement casuptr.
2004-11-05 19:50:48 +00:00
Olivier Houchard
1214c18d4e
Call pmap_pte_init_arm9 instead of pmap_pte_init_generic if
...
ARM9_CACHE_WRITE_THROUGH is defined.
2004-11-05 19:48:40 +00:00
Olivier Houchard
bd245b9bd4
In cpu_critical_fork_exit(), make sure to set td_md.md_critnest so that
...
interrupts will be enabled.
Spotted out by: jhb
2004-11-05 18:29:45 +00:00
Olivier Houchard
6e91e74e11
Protect the function declarations with #ifdef _KERNEL.
2004-11-04 19:20:54 +00:00
Olivier Houchard
56c6c84155
Directly use __pcpu for PCPU_* instead of pcpup.
2004-11-04 19:19:44 +00:00
Olivier Houchard
27d97a6c49
Decrease KSTACK_PAGES and UAREA_PAGES.
2004-11-04 19:19:21 +00:00
Olivier Houchard
24e01b0c59
Use interrupts_disable() and interrupts_restore() as intr_disable() and
...
intr_restore() instead of re-implement it.
2004-11-04 19:18:50 +00:00
Olivier Houchard
dba13dd1d3
Don't barf if no CPU type is defined while compiling kernel modules.
2004-11-04 19:16:31 +00:00
Olivier Houchard
3ce6572f9f
Implement get_cyclecount().
2004-11-04 19:15:43 +00:00
Olivier Houchard
a61369085e
Try to implement atomic operations using swp, instead of disabling interrupts.
2004-11-04 19:14:50 +00:00
Olivier Houchard
eeaa69102a
Use casts to enforce the return type of bswap16() and bswap32().
2004-11-04 19:07:28 +00:00
Olivier Houchard
4cc4c8f7fe
Implement cpu_thread_siginfo() and set_mcontext().
...
Nuke getframe(), and choose which stack to use directly in sendsig().
2004-11-04 19:04:30 +00:00
Olivier Houchard
b0db6a81d2
Implement cpu_set_upcall and cpu_set_upcall_kse.
...
Calculate td_frame and td_pcb the right way in cpu_thread_setup.
2004-11-04 18:59:02 +00:00
Olivier Houchard
8d0e9a52c6
Get kernel modules to work.
2004-11-04 18:48:52 +00:00
Andre Oppermann
32672ba88d
Reduce annoying SCSI probing delay from 15 to 5 seconds in all GENRIC kernels.
...
Discussed on: -current
2004-11-02 20:57:20 +00:00
John Baldwin
d39d4a6e64
- Change the ddb paging "support" to use a variable (db_lines_per_page) to
...
control the number of lines per page rather than a constant. The variable
can be examined and changed in ddb as '$lines'. Setting the variable to
0 will effectively turn off paging.
- Change db_putchar() to force out pending whitespace before outputting
newlines and carriage returns so that one can rub out content on the
current line via '\r \r' type strings.
- Change the simple pager to rub out the --More-- prompt explicitly when
the routine exits.
- Add some aliases to the simple pager to make it more compatible with
more(1): 'e' and 'j' do a single line. 'd' does half a page, and
'f' does a full page.
MFC after: 1 month
Inspired by: kris
2004-11-01 22:15:15 +00:00
Olivier Houchard
99cf590376
We want to ignore BUS_DMASYNC_POSTWRITE, not BUS_DMASYNC_POSTREAD.
...
Spotted out by: mux
Pointy hat to: cognet
2004-10-21 11:59:33 +00:00
Olivier Houchard
9c2ac80375
Use a default MD_ROOT_SIZE of 65535.
2004-10-11 14:42:06 +00:00
Olivier Houchard
ed4dc69883
Use MD_ROOT_SIZE, instead of our own macro.
2004-10-11 14:41:38 +00:00
Olivier Houchard
74e9b5ed3b
Add optimized version of the bswap macroes for constants if __OPTIMIZED__ is
...
defined.
2004-10-01 16:55:59 +00:00
Olivier Houchard
d60ea0a816
There's no need to turn on MALLOC_PROFILE by default.
2004-10-01 16:51:37 +00:00
Olivier Houchard
77ee40aac5
Calling fuword from fuword32 with bl and without returning after is really a bad
...
idea.
Any way I get a customized CVS template with "Pointy hat to: cognet"
pre-filled ?
2004-09-28 14:39:26 +00:00
Olivier Houchard
022fb84224
Always invalidate the whole data cache in pmap_enter() for now.
...
It should not be needed.
2004-09-28 14:38:14 +00:00
Olivier Houchard
e462e1ba03
Remove dead code.
2004-09-28 14:37:39 +00:00
Olivier Houchard
4b7d15c6dc
Add the config file for the IQ31244 board.
2004-09-23 22:55:00 +00:00
Olivier Houchard
f67baa4d6b
Use the new KERNVIRTADDR and PHYSADDR options.
...
Add KDB.
2004-09-23 22:53:50 +00:00
Olivier Houchard
6052fa47a9
Import partial support for the IQ31244 eval board (i80321 CPU). IQ80321 might
...
work out of the box too, but I have no hardware to test.
It works well enough to go multiuser. Network works, SATA does not, as I have
no drive to test.
Thanks to Intel for sending such a board.
Obtained from: NetBSD
2004-09-23 22:45:36 +00:00
Olivier Houchard
3ce77c124e
Add Xscale common headers.
2004-09-23 22:36:13 +00:00
Olivier Houchard
906ce37658
Big cleanup: get ride of the whole spl level logic, as FreeBSD doesn't use
...
it anymore.
2004-09-23 22:33:38 +00:00
Olivier Houchard
8413603da8
Now that we have pmap_growkernel(), use more KVA.
2004-09-23 22:32:33 +00:00
Olivier Houchard
1f5f31b4ec
Remove the empty definition of struct osigcontext, as it will never be used.
2004-09-23 22:31:49 +00:00
Olivier Houchard
7ea7271711
Remove the pcb32_cstate field of struct pcb.
2004-09-23 22:31:08 +00:00
Olivier Houchard
f04d49ad11
Declare sigcode and szsigcode.
2004-09-23 22:30:05 +00:00
Olivier Houchard
9f0f6bf453
Define VM_PROT_READ_IS_EXEC.
2004-09-23 22:29:43 +00:00
Olivier Houchard
ffa589bf15
Implement _mcount().
...
Obtained from: NetBSD
2004-09-23 22:29:18 +00:00
Olivier Houchard
c038ee8196
Define STACKALIGNBYTES and STACKALIGN.
2004-09-23 22:27:42 +00:00
Olivier Houchard
a40d2bb653
We are using _mcount, not __mcount.
...
Remove the !__ELF__ case.
2004-09-23 22:26:29 +00:00
Olivier Houchard
8476fd9ff7
Use sf_bufs for uiomove_fromphys().
2004-09-23 22:25:20 +00:00
Olivier Houchard
04aebdab36
On Xscale, use the minicache for the kernel stack.
2004-09-23 22:24:12 +00:00
Olivier Houchard
9979f39280
Make sure to call cred_update_thread() if needed.
...
Add partial support for KTRACE.
2004-09-23 22:22:33 +00:00
Olivier Houchard
8be9ab9730
Implement cpu_throw().
...
Obtained from: NetBSD
2004-09-23 22:20:59 +00:00
Olivier Houchard
01997784aa
Remove unused macroes.
...
Add user, btrap, etrap, bintr and eintrt in the GPROF case.
2004-09-23 22:18:56 +00:00
Olivier Houchard
0627741cbf
Implement sigreturn().
2004-09-23 22:12:28 +00:00
Olivier Houchard
f0c85e996a
Add the hw.machine sysctl.
2004-09-23 22:11:43 +00:00
Olivier Houchard
a7e3e43349
Remove definitions related to the pmap cache state, and add TDF_NEEDRESCHED.
2004-09-23 22:11:06 +00:00
Olivier Houchard
7c320e5bfb
Add new functions to know which irqs are pending, and to mask and unmask
...
interrupts, as these are CPU specific.
If the interrupt handler is not marked as INTR_FAST, don't unmask the
interrupt until it as been serviced.
2004-09-23 22:09:57 +00:00
Olivier Houchard
1e82631893
Rename macroes, as we don't need to mess with alignment faults.
...
Call ast() if TDF_NEEDRESCHED is set too, not just TDF_ASTPENDING.
2004-09-23 22:05:40 +00:00
Olivier Houchard
289d61042d
Use sigcode.
2004-09-23 22:03:25 +00:00
Olivier Houchard
282c3a6588
In db_stack_trace_cmd, remove the "pc" variable, we don't need it.
2004-09-23 22:02:59 +00:00
Olivier Houchard
3f0cbe0ef6
Use the right path for xscale files.
2004-09-23 21:59:43 +00:00
Olivier Houchard
a5bb1c8501
Remove bus_space_vaddr(), it does not exists in FreeBSD.
2004-09-23 21:59:14 +00:00
Olivier Houchard
4637f47217
Don't attempt to manage our own segment list, and just remember the buffers
...
provided.
Obtained from: NetBSD
2004-09-23 21:57:47 +00:00
Olivier Houchard
f68fab42ef
Use the right path for the bcopyinout_xscale.S file.
2004-09-23 21:56:36 +00:00
Olivier Houchard
371853e562
Add MD syscalls to sync the icache and to drain the write buffer.
...
Obtained from: NetBSD
2004-09-23 21:56:01 +00:00