akaros.git
20 months agosched: When disabling SMT, turn off the odd cores
Barret Rhoden [Wed, 13 Dec 2017 18:02:28 +0000 (13:02 -0500)]
sched: When disabling SMT, turn off the odd cores

Previously, we were turning off the even cores, but that gave out core 1,
which was hyperthreaded with core 0.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agosched: Fix packed initialization
Barret Rhoden [Wed, 13 Dec 2017 17:57:11 +0000 (12:57 -0500)]
sched: Fix packed initialization

Setting alloc_proc = -1 blows up a few things, at least prov -s.  There's
probably other / future issues with it.

The new way a lot clearer too - one pass, make our decision, and move on.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agosched: Remove the idle core interface
Barret Rhoden [Wed, 13 Dec 2017 17:48:58 +0000 (12:48 -0500)]
sched: Remove the idle core interface

It's only used by ARSC code, which no one uses and probably needs a better
approach.

The code for the packed scheduler is buggy as hell:
- __get_any_idle_core doesn't return once it finds an item
- __get_any_idle_core uses uninitialized *spc
- There's no refcounting or interaction with the idle list.
- The UNNAMED_PROC is a problem too (prov -s crashes)

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoAdd implementation of packed core alloc strategy
Kevin Klues [Tue, 6 Oct 2015 02:42:22 +0000 (19:42 -0700)]
Add implementation of packed core alloc strategy

This core allocation strategy attempts to hand out cores to a process
based on the underlying topology of the machine. It's strategy is based
on trying to pack cores as tightly as possible when handing out cores to
a process.

The first time a process requests a core, the algorithm will try to find
an idle core as far away as possible from all other allocated cores on
the machine. Once the first core is established, subsequent requests
will try and pack cores as tightly as possible to cores it already owns.
Cores from a proc's list of provisioned cores are preferentially chosen,
followed by the remaining idle cores in the system.

The core allocation strategy to use can be chosen as a makeconfig
variable.

Signed-off-by: Kevin Klues <klueska@cs.berkeley.edu>
Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agox86: Fix topology detection
Barret Rhoden [Wed, 13 Dec 2017 17:02:50 +0000 (12:02 -0500)]
x86: Fix topology detection

The main thing is that we were off by one - the is_unique check would
compare us to ourselves, which will always fail.

The end result was that the number of numa nodes was always 0, which turns
off all of the other topology information.  I'm not sure how this ever
worked.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmx: Squelch per-core startup messages
Barret Rhoden [Wed, 13 Dec 2017 17:48:29 +0000 (12:48 -0500)]
vmx: Squelch per-core startup messages

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Provide a fast-path for IPIs in the kernel
Barret Rhoden [Tue, 12 Dec 2017 18:27:55 +0000 (13:27 -0500)]
vmm: Provide a fast-path for IPIs in the kernel

Handling the IPI in userspace takes a couple usec.  If the target guest
pcore is loaded and running, such as when in greedy mode or under load, the
kernel can inject the IPI.

This helped perf bench pipe sched on tinycore in greedy mode, where the
guest was sending IPIs every 8-10 usec.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Check VPPR and interrupt-window-blocking with RVI
Barret Rhoden [Tue, 12 Dec 2017 18:24:02 +0000 (13:24 -0500)]
vmm: Check VPPR and interrupt-window-blocking with RVI

We had been checking just the full byte of RVI.  However, that is not what
the hardware will treat as a condition to trigger an interrupt in the
guest.

I didn't have a specific problem with this, but it popped up as a potential
issue when I was working on IPIs.

Note that vectors less than 16 in RVI won't trigger a wakeup, which is in
accordance with the SDM's algorithm.  The only time I've seen the RVI field
less than 16 so far is during an INIT/SIPI.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Add mmio helper functions
Barret Rhoden [Tue, 12 Dec 2017 18:22:00 +0000 (13:22 -0500)]
vmm: Add mmio helper functions

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoFix Linux timers, jiffies, and HZ
Barret Rhoden [Mon, 4 Dec 2017 23:16:34 +0000 (18:16 -0500)]
Fix Linux timers, jiffies, and HZ

Since commit 2a991d374670 ("Treat jiffies as msec since boot"), we've been
waiting ten times longer than we should.  For Linux code, jiffies are one
msec, and HZ = 1000.

Similarly, some mlx4 code was using mod_timer() for relative changes.  Once
we started treating jiffies as non-zero, these timers broke.

This fixes some nastiness with mod_timer - there never should have been
'delay', since all callers expect to use absolute time.  We should have
just had jiffies == msec or whatever from the beginning.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoparlib: Fix signature for trace_printf()
Barret Rhoden [Fri, 1 Dec 2017 20:23:47 +0000 (15:23 -0500)]
parlib: Fix signature for trace_printf()

Commit 248d1a835700 ("Add printx to userspace (XCC)") moved the void
trace_printf() from one header to another.  But it turns out that 'void'
was wrong.  It conflicted with glibc's parlib-compat helper, which expected
an int.  The old code didn't notice since parlib/ros_debug.h wasn't
included by glibc's parlib-compat.c, but parlib/stdio.h is.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Export the TSC freq via a vmcall (XCC)
Barret Rhoden [Wed, 22 Nov 2017 16:44:23 +0000 (11:44 -0500)]
vmm: Export the TSC freq via a vmcall (XCC)

This reduces the changes we make to the guest outside of akaros.c and
simplifies the commandline processing on our end.

Reinstall your kernel headers.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Remove lapic_timer_frequency from the cmd line
Barret Rhoden [Wed, 22 Nov 2017 15:17:50 +0000 (10:17 -0500)]
vmm: Remove lapic_timer_frequency from the cmd line

Linux's lapic_timer_frequency isn't in raw Hz.  It's actually the lapic
freq divided by HZ, the Linux variable, e.g. 250 or 1000.

Linux's akaros.c will take care of this.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Halt vcore 0 instead of spinning
Barret Rhoden [Mon, 20 Nov 2017 20:09:52 +0000 (15:09 -0500)]
vmm: Halt vcore 0 instead of spinning

Spinning limits the sibling core's performance and limits the turbo mode
potential of the rest of the machine.

Instead, we'll mwait on notif_pending or an IPI.  Our ev_qs are already set
up to send IPIs with the notification, so things like syscalls and timers
will work fine.  If the 2LS enqueues a task thread - which are handled by
VC 0 - it'll make sure the vcore wakes up.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoAllow sys_halt_core() to monitor notif_pending
Barret Rhoden [Mon, 20 Nov 2017 19:20:08 +0000 (14:20 -0500)]
Allow sys_halt_core() to monitor notif_pending

This lets the 2LS halt the core and wait for someone to touch
notif_pending, which is touched for any event delivery to the vcore.

2LSs that want to wake vcores without sending a full event will need to use
wake_vcore().  The force_ipi is to help them break out of spinning
uthreads.  We'll see if that's needed or not.  Some of this ties into the
long range 2LS changes I've been planning.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoMake cpu_halt() return with IRQs disabled
Barret Rhoden [Mon, 20 Nov 2017 19:12:47 +0000 (14:12 -0500)]
Make cpu_halt() return with IRQs disabled

And don't assume we woke from an IRQ that changed the kernel pcpui state.
Although that is always the case, it won't be if we woke due to an mwait.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agovmm: Let the VMM control mwait vmexits (XCC)
Barret Rhoden [Fri, 17 Nov 2017 15:59:27 +0000 (10:59 -0500)]
vmm: Let the VMM control mwait vmexits (XCC)

We can handle mwaits in software, but only for power management halts - the
monitor won't work.  We tell the guest (via cpuid) that monitor/mwait is
not supported, so the only VMs that should be making mwait calls are
paravirtualized guests.

The greedy 2LS sets mwait exiting in the same way that it controls whether
or not halts trigger a vmexit.

The end result should be that guests can mwait at whatever sleep state they
want - preferably at least C2 (mwait 0x10), which would allow other
physical cores to reach a higher turbo mode setting.

Reinstall your kernel headers.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agox86: Remove UNUSED_ARG #define
Barret Rhoden [Fri, 17 Nov 2017 17:35:07 +0000 (12:35 -0500)]
x86: Remove UNUSED_ARG #define

We aren't using it, and if we need it, we can put it in compiler.h.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoAdd printx to userspace (XCC)
Barret Rhoden [Wed, 22 Nov 2017 16:15:11 +0000 (11:15 -0500)]
Add printx to userspace (XCC)

Userspace now has printx (to stderr) and trace_printx (to dmesg).  We also
have all the variants of I_AM_HERE (_x, _t, _tx).

Reinstall your kernel headers.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agoRemove i386 from glibc (XCC)
Barret Rhoden [Wed, 22 Nov 2017 15:45:12 +0000 (10:45 -0500)]
Remove i386 from glibc (XCC)

I plan to add a bool to procdata and noticed the unused ldt variable.  By
removing it and putting in padding, I can make that space and keep people
from needing a rebuild.

If you have weird problems, rebuild the world.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
20 months agonet: tcp: Handle reseqs of length 0
Barret Rhoden [Tue, 21 Nov 2017 20:24:13 +0000 (15:24 -0500)]
net: tcp: Handle reseqs of length 0

The SACK code was panicking, but it is possible to have length = 0 (on a
SYN or FIN).  We can just ignore any potential SACK updates in those
cases.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agomlx4: Use netif_stats for ifstat
Barret Rhoden [Thu, 16 Nov 2017 16:09:57 +0000 (11:09 -0500)]
mlx4: Use netif_stats for ifstat

Linux drivers have a way of exporting their stats to a struct netif_stats.
We have a way to parse netif_stats when we cat ether/ifstats.  Put those
together and you have a simple way to get stats from any Linux driver.

For mlx4, I had to turn on a few bits of code that we had commented out.
There were minor issues with the MAC address changing, but I think we can
ignore that for now.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoTreat jiffies as msec since boot
Barret Rhoden [Thu, 16 Nov 2017 17:17:56 +0000 (12:17 -0500)]
Treat jiffies as msec since boot

We had been treating jiffies as 0, and then using relative time in
mod_timer.  This is nasty, and breaks things that want to use jiffies for
other stuff, like mlx4 stats.

Instead, we'll pretend like we're a Linux machine with HZ = 1000 and a
jiffie being a millisecond.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoFix ttcp rate output string
Barret Rhoden [Thu, 16 Nov 2017 15:52:52 +0000 (10:52 -0500)]
Fix ttcp rate output string

Previously, we'd have output like:

ttcp-t: X bytes in Y real seconds = Z (null)/sec

Now it is:

ttcp-t: X bytes in Y real seconds = Z KB/sec

'unit' wasn't set.  It gets set as a byproduct of calling rate().  The old
code was assuming that the arguments to fprintf were processed in order.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Remove 9ns's rtl8169 driver
Barret Rhoden [Wed, 15 Nov 2017 18:55:16 +0000 (13:55 -0500)]
net: Remove 9ns's rtl8169 driver

It barely worked for a couple models.  The half-baked Linux driver is
better.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agor8169: Port the driver
Barret Rhoden [Wed, 15 Nov 2017 18:50:24 +0000 (13:50 -0500)]
r8169: Port the driver

It's better than bnx2x and mlx4, but there's still more for us to do to
properly port Linux drivers.  Here's a few things:

- Backpressure is sorted out with pokes and whatnot.  Linux's
  netif_stop/start might be a better way - handled at a higher layer in the
stack.

- Shutdown/detach/power management is pretty much unsupported.

- Multicast is missing.  Again, there's more support at higher levels of
  the stack than 9ns has.

- Our PCI MSI(X) support doesn't let the driver have a say in whether or
  not MSI is used.

Til next time...

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agor8169: Make the driver compile
Barret Rhoden [Thu, 2 Nov 2017 18:14:21 +0000 (14:14 -0400)]
r8169: Make the driver compile

I permanently commented out (AKAROS_PORT) things related to ethtool, ioctl,
and vlan.

I commented out and panicked (AKAROS_ROOT_TODO) things that will need to be
ported manually.  These things involve SKBs and NAPI.  For the most part,
they work, but they'll need some massaging.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agor8169: Spatch the driver
Barret Rhoden [Tue, 31 Oct 2017 19:36:39 +0000 (15:36 -0400)]
r8169: Spatch the driver

Ran the scripts/spatch/linux/*.cocci files.  I had to do the u64s and
{read,write}{b/l/w} manually, due to errors like:

 try to delete an expanded token: writeb

It has something to do with weird usages of macros.

Did a bunch of other spatches separately as I changed the coccis, such as
pci_dev->dev => pci_dev->device.

A bunch of u32, u16, and u8s also failed silently.  Some worked, some
didn't.

Same with BUG_ON.

And a couple of struct net_device.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agor8169: Add Linux's RTL 8169 driver
Barret Rhoden [Tue, 31 Oct 2017 19:14:10 +0000 (15:14 -0400)]
r8169: Add Linux's RTL 8169 driver

From commit 569dbb88e80d ("Linux 4.13").

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Add rx_mode to ether/netif
Barret Rhoden [Wed, 15 Nov 2017 18:08:53 +0000 (13:08 -0500)]
net: Add rx_mode to ether/netif

It's only used in a Linux driver.  It simplifies the driver a bit, and is
likely to help all other Linux drivers.  It's the way of the future!

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Remove mbps from ipifc
Barret Rhoden [Wed, 15 Nov 2017 17:24:50 +0000 (12:24 -0500)]
net: Remove mbps from ipifc

Unused.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Delay etherbind until the link is up
Barret Rhoden [Tue, 14 Nov 2017 19:26:20 +0000 (14:26 -0500)]
net: Delay etherbind until the link is up

On some drivers, at least r8169, the link auto-negotiation takes a few
seconds.  It starts during attach(), but we can't wait there.  Lots of NICs
get attached, including ones that will never have a link.  Note that
attach() happens when you try to cat \#ether.0/ether0/addr.

We can't wait at attach.  If we try to error out during transmit, that
actually breaks (error at ipifc.c L444).  The IP stack will try to send
packets.

So we have two choices: on every transmit, do a netif_wait_for_carrier(),
or catch it after attach, but before Ipifc initialization.  It turns out
that during etherbind() we can wait.  This is when we try to prepare the
NIC to use IPv4, v6, and ARP.

Note this means all 9ns drivers need to tell the rest of the stack that
their links are up.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Add a helper to parse netif_stats
Barret Rhoden [Mon, 13 Nov 2017 19:59:48 +0000 (14:59 -0500)]
net: Add a helper to parse netif_stats

NIC drivers can use this for their ifstats function.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Split hw_features out from feat
Barret Rhoden [Mon, 13 Nov 2017 19:20:57 +0000 (14:20 -0500)]
net: Split hw_features out from feat

hw_features is what is possible; feat is what is turned on *or* other Plan
9 characteristics.  Notably, NETF_PADMIN is more of a signal that the NIC
will pad to the mintu.  It's not something the hardware will turn on or
off.

By #defining hw_features to feat, we were possibly turning on things that
shouldn't be on by default.  Likewise, an = (instead of |=) could clobber
values of feat.  It was all quite nasty.

Note that the name 'feat' is an ABI to some extent.  etherbind() looks for
that string when it decides which features get added to the Ipifc.  If we
have dynamic features and want them to actually take affect to IP stacks
bound to a NIC, then we'll need to propagate those changes to Ipifc.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Split up BCKSUM_FLAGS
Barret Rhoden [Fri, 10 Nov 2017 21:07:58 +0000 (16:07 -0500)]
net: Split up BCKSUM_FLAGS

Those flags were for more than block checksums - Btso was in there, which
isn't a checksum.

This clarifies the use of the block checksum flags, including being
explicit about when we are using the flag for transport layer checksum
offload.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoEncapsulate block metadata better
Barret Rhoden [Fri, 10 Nov 2017 17:44:52 +0000 (12:44 -0500)]
Encapsulate block metadata better

Everytime I add something, like network_offset, I had to update a few
places.  Well, two places.  This way, we're slightly more clear about what
we're doing, instead of adding minor hacks each time.

A couple points:
- We had been copying the metadata over only if certain flags were set.  We
  should be able to copy that data over no matter what.
- It was probably buggy to only copy network_offset and transport_offset
  based on a flag.
- If you muck with a block, like in padblock(), you still need to adjust
  any offsets.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Clarify transport checksum offload
Barret Rhoden [Fri, 10 Nov 2017 17:14:50 +0000 (12:14 -0500)]
net: Clarify transport checksum offload

It turns out that checksum_start (an offset) was always the same as
transport_offset.  That's how these transport xsum offloads work.

The asserts are for sanity checks.  We can take those out once we're sure
I'm right about all this.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Remove block->checksum
Barret Rhoden [Fri, 10 Nov 2017 16:53:49 +0000 (11:53 -0500)]
net: Remove block->checksum

This was used to report the checksum computed by the NIC.  However, the
rest of the stack wasn't using it for anything.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Add a field for the driver_name
Barret Rhoden [Thu, 9 Nov 2017 20:36:07 +0000 (15:36 -0500)]
ether: Add a field for the driver_name

For debugging and viewable in ether/stats.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Let ifconfig use NICs other than ether.0
Barret Rhoden [Thu, 9 Nov 2017 18:58:54 +0000 (13:58 -0500)]
net: Let ifconfig use NICs other than ether.0

To pick a different NIC, put its MAC address in a config block in
/etc/network/local.d/.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoqio: Don't make extra empty EBDs
Barret Rhoden [Thu, 9 Nov 2017 17:22:40 +0000 (12:22 -0500)]
qio: Don't make extra empty EBDs

We overestimated the number of extra data blocks in a couple of ways, and
this was triggering issues with SG in the NICs.

First, we were counting (and pointing to) the headers of blocks even when
the headers were empty.  Excessive work, no gain, extra ebds.

We were also counting the entire blist, even if we were only extracting a
small amount of data.  I had a few blocks that had 80 ebds, but only one
valid block.

We continue to assume that EBDs are all valid, and thus it is still an
overestimate.  It's not a bad one though, since I think the only time we
have empty EBDs are a result of pullups or other one-off operations.  Not
sure though.

It might be worth tracking the number of valid EBDs (base && len), but it
might be tricky.  Note that we have some EBDs with no len but with a
refcounted base.  So you'd have to be careful how you count 'valid.'

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Add an option for RX checksum offload
Barret Rhoden [Wed, 8 Nov 2017 20:49:49 +0000 (15:49 -0500)]
net: Add an option for RX checksum offload

Plan 9 drivers assume that this feature is always on, if available, and it
is unqueryable.

Linux drivers have a flag for this, and by setting that flag to zero, NICs
(e.g. r8169) turn off their feature since they think the user doesn't want
it.

It's likely this will turn on RX checksumming on bnx2x and mlx4.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: tcp: Fix TSO for incoming connections
Barret Rhoden [Wed, 8 Nov 2017 19:43:45 +0000 (14:43 -0500)]
net: tcp: Fix TSO for incoming connections

TSO was only being used on outbound connections.  The issue was that the
'flags' in tcpmtu for inbound connections was seg.flags, not tcb->flags.
So that bit we were setting was discarded.

The fix is to do the lookup (which requires the ifc) once we finally have
the tcb, which is after the conversation comes out of limbo.  Instead of
looking up the ifc twice, we can just store the uncounted ref.  We'll
probably have other uses for the ifc.

Note that the ifc->feat is not exactly the same as ether->netif->feat.  The
device's features are copied over to the IP interface during etherbind.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Add network_offset to blocks
Barret Rhoden [Wed, 8 Nov 2017 16:44:18 +0000 (11:44 -0500)]
net: Add network_offset to blocks

Similar to transport_offset, this is the offset from bp->rp to the
beginning of the network layer header, e.g. IP.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Change transport_header_end -> tranport_offset
Barret Rhoden [Mon, 6 Nov 2017 16:44:32 +0000 (11:44 -0500)]
net: Change transport_header_end -> tranport_offset

mlx4 wanted the size of a TCP packet, but other NICs want the start of the
TCP header.  We can go from "header start" -> "header end" easily, but not
the other way.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: tcp: Refactor the tcp header structs
Barret Rhoden [Mon, 6 Nov 2017 16:40:42 +0000 (11:40 -0500)]
net: tcp: Refactor the tcp header structs

v4 and v6 have the same TCP header (since it's the same protocol).  Plan 9
embeds them in TCP-IPv4 and TCP-IPv6 structs.  It behooves us to have a
common struct.  It could be used to clean up a bunch of tcp.c code, but for
now I just need it for a header helper.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoMove srch_linux_pci_tbl to linux_compat.h
Barret Rhoden [Thu, 2 Nov 2017 22:51:13 +0000 (18:51 -0400)]
Move srch_linux_pci_tbl to linux_compat.h

This was a helper used by bnx2x, but all users of Linux PCI tables can
use it.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agopci: Add a struct device field
Barret Rhoden [Wed, 1 Nov 2017 20:28:28 +0000 (16:28 -0400)]
pci: Add a struct device field

bnx2x has a lot of other places that are still using pcidev->dev, but it's
passing them to dont-care macros.  It's hokey, and spatch doesn't seem to
want to catch them all.  It's also a little hard to spatch after doing the
native conversion; some places have akaros_pcidev->dev, meaning the 'd' of
TBDF.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agopci: Update pci_regs.h
Barret Rhoden [Wed, 1 Nov 2017 18:41:29 +0000 (14:41 -0400)]
pci: Update pci_regs.h

This file was originally from Linux.  This is the updated version, from
commit 569dbb88e80d ("Linux 4.13").

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agopci: Add cacheline and MWI helpers from Linux
Barret Rhoden [Wed, 1 Nov 2017 18:09:09 +0000 (14:09 -0400)]
pci: Add cacheline and MWI helpers from Linux

These were copied and ported from commit 569dbb88e80d ("Linux 4.13").

They are simple enough that we can use them too.  We weren't doing anything
with memory-write-invalidate, but it's a performance helper.  Eventually,
we might end up porting all of Linux's PCI infrastructure.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Add Linux-compatible netif_stats
Barret Rhoden [Thu, 2 Nov 2017 16:34:23 +0000 (12:34 -0400)]
ether: Add Linux-compatible netif_stats

Instead of faking stat structs (like we did with mlx4) or completely
ignoring them (like bnx2x), we can just use the same struct and put it in
struct netif (anonymously in struct ether).  We can even have an ifstat()
function pointer that all the Linux drivers use to extract the info.

Given we probably won't have too many Plan 9 drivers, we might just yank
the Plan 9 stats and covert everyone to using netif_stats.

netif_stats is Linux's rtnl_link_stats64, from commit 569dbb88e80d ("Linux
4.13").

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Fix ETHERMAXTU calculations
Barret Rhoden [Wed, 1 Nov 2017 23:19:01 +0000 (19:19 -0400)]
ether: Fix ETHERMAXTU calculations

In commit f5e7ebb31ce7 ("Changes devether's Max Trans Unit to 1500")
I changed ETHERMAXTU to not account for the header size.  I changed places
that had maxmtu, but not places that directly used ETHERMAXMTU.

As a fun side note, I noticed the problem in devether, near the vlan case.
I was tempted to change it in a previous commit, but decided to do a
separate commit.  In doing so, I did a more thorough job and grepped for
ETHERMAXMTU and found the bugs in 8139 and 8169.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Fix MTU control variables
Barret Rhoden [Wed, 1 Nov 2017 23:08:45 +0000 (19:08 -0400)]
ether: Fix MTU control variables

Plan 9 had maxmtu, but it was pretty much used as 'what is the current
MTU", not "what is the highest MTU we can have."  I had been spatching
Linux drivers from mtu -> maxmtu.

Instead, let's name the MTU we're using 'mtu' (like Linux).  We'll have
max_mtu and min_mtu, which are the highest and lowest possible settings.

Mostly this is a revert of commit a73aedb3c118 ("BNX2X: spatch ether->mtu
-> ether->maxmtu"), manually changing the mlx4 driver, and all of the
renames.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Port the Linux MII code
Barret Rhoden [Wed, 1 Nov 2017 15:09:17 +0000 (11:09 -0400)]
ether: Port the Linux MII code

Unfortunately, I had to comment out most of the file: all ethtool and ioctl
stuff.

Maybe the next step will be to port the ethtool interfaces.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Spatch Linux MII files
Barret Rhoden [Wed, 1 Nov 2017 14:56:38 +0000 (10:56 -0400)]
ether: Spatch Linux MII files

$ for i in scripts/spatch/linux/*.cocci; do echo $i; spatch -sp-file $i
-in-place kern/drivers/net/linux_mii.c; done

Looks like these had no spatch complaints either (unlike r8169).  We'll
see.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoether: Add Linux's MII code
Barret Rhoden [Tue, 31 Oct 2017 21:12:07 +0000 (17:12 -0400)]
ether: Add Linux's MII code

From commit 569dbb88e80d ("Linux 4.13").

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoUpdate Linux compatibility shims/coccis
Barret Rhoden [Thu, 2 Nov 2017 18:02:00 +0000 (14:02 -0400)]
Update Linux compatibility shims/coccis

These were updates I made for the r8169.

There's also a potential bugfix in there for mlx4.  wait_for_completion()
should sleep, not busywait.  This pops up later in the patchset when we
make netif_carrier_ok() not just return true.  Incidentally, if we're going
to busywait, we should be using udelay.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agomlx4: bnx2x: Use pci_set_bus_master()
Barret Rhoden [Wed, 1 Nov 2017 19:26:07 +0000 (15:26 -0400)]
mlx4: bnx2x: Use pci_set_bus_master()

Instead of the #define.  There will be an spatch for this.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agox86: Rename VPD (XCC)
Barret Rhoden [Wed, 1 Nov 2017 15:14:15 +0000 (11:14 -0400)]
x86: Rename VPD (XCC)

Conflicts with some device stuff (Vital Product Data).

Reinstall your kernel headers (not manadatory).

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoAdd variants to I_AM_HERE
Barret Rhoden [Wed, 8 Nov 2017 16:24:45 +0000 (11:24 -0500)]
Add variants to I_AM_HERE

For trace printing (viewable with dmesg) and/or printxing.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoMove uninitialized_var() to compiler.h
Barret Rhoden [Thu, 2 Nov 2017 16:21:23 +0000 (12:21 -0400)]
Move uninitialized_var() to compiler.h

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoAdd IS_ERR_OR_NULL helper
Barret Rhoden [Wed, 1 Nov 2017 20:29:52 +0000 (16:29 -0400)]
Add IS_ERR_OR_NULL helper

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoPort Linux's math64 headers
Barret Rhoden [Fri, 21 Jul 2017 23:21:55 +0000 (19:21 -0400)]
Port Linux's math64 headers

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoAdd Linux's math64.h
Barret Rhoden [Fri, 21 Jul 2017 23:12:23 +0000 (19:12 -0400)]
Add Linux's math64.h

k/a/x/div64.h is a truncated version of asm-generic/div64.h, which is
all that Linux's x86_64 is.

From Linux's commit 921edf312a6a ("ide: avoid warning for timings
calculation").

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: tcp: Lowercase-ify struct names
Barret Rhoden [Fri, 21 Jul 2017 22:02:07 +0000 (18:02 -0400)]
net: tcp: Lowercase-ify struct names

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: tcp: Move TCP's headers into net/tcp.h
Barret Rhoden [Fri, 21 Jul 2017 19:22:37 +0000 (15:22 -0400)]
net: tcp: Move TCP's headers into net/tcp.h

We'll want these in their own file when we start using different
congestion avoidance modules.

This also makes most of the functions in tcp.c static, since they aren't
called from outside tcp.c.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: Move ip.h to net/ip.h
Barret Rhoden [Fri, 21 Jul 2017 19:00:18 +0000 (15:00 -0400)]
net: Move ip.h to net/ip.h

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agonet: tcp: Don't increment snd.nxt
Barret Rhoden [Thu, 16 Nov 2017 15:32:59 +0000 (10:32 -0500)]
net: tcp: Don't increment snd.nxt

Ever since commit 682b414ddb84 ("net: tcp: Support SACK"), we weren't
sending FINs when our connections were shutdown or closed.

For the sackless, normal case, that commit changed the from_seq from
snd.rtx to snd.nxt.  Those are supposed to be in sync for normal operation.
However, the old Plan 9 stack was incrementing snd.nxt whenever it wanted
to send a FIN.  It should *only* increment flgcnt, which is the weird
signal that means to send a FIN, since we end up trying to send one more
byte than we have bytes in the qio.  (And the extra byte is interpreted as
a FIN at some point).

Anyway, the old code, before the SACK overhaul, got away with it since it
was sending with from_seq being snd.rtx (the retrans point).  That's a
little messed up, but no one ever noticed since the old snd.rtx usually had
the value that snd.nxt *should* have had.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agolinuxemu: fix fcntl GETFL flags
Gan Shun Lim [Thu, 26 Oct 2017 07:19:49 +0000 (18:19 +1100)]
linuxemu: fix fcntl GETFL flags

GETFL returns the file flags, but akaros flags and linux flags are
different.

Change-Id: I7ecdf605e2548f2a120bbea3f2375b7715cca7b5
Signed-off-by: Gan Shun Lim <ganshun@google.com>
Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoAdd support for attempting returns from panic
Barret Rhoden [Mon, 30 Oct 2017 18:35:39 +0000 (14:35 -0400)]
Add support for attempting returns from panic

If you ever wanted to keep going after a panic, it just got a little
easier.  You can exit the monitor ('exit' or 'e'), like always.  This
commit cleans up a little so the core doesn't keep panicking.

This will rarely work well, since the system is toasted, but I've been able
to get back to userspace with it.  You might lose the core that panicked,
(e.g. MCP triggers a racy panic), but at least that core won't keep polling
the console in the monitor.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agopm: Catch issues with page map pages
Barret Rhoden [Mon, 30 Oct 2017 18:14:25 +0000 (14:14 -0400)]
pm: Catch issues with page map pages

We had bugs with PM reference counts and pages being freed with PG_ flags
still set.  The PM code needs to clean up after itself.

The various asserts are probably paranoia, but there might be similar bugs
out there still.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agomm: Don't free pages in the page cache
Barret Rhoden [Mon, 30 Oct 2017 17:48:39 +0000 (13:48 -0400)]
mm: Don't free pages in the page cache

map_page_at_addr() should have had !page_is_pagemap() (note the !).
Instead, we were actually freeing page cache pages under those rare
circumstances where map_page_at_addr() frees a page.

Specifically, we had a case where we'd have multiple PFs at once, and we
hit the benign race.  But we accidentally freed the page cache page and
then reused it.  Reusing the page, which was a binary text page, destroyed
the program (crazy faults).  Also, when we reused the page, its PG_PAGEMAP
flag was still set, which caused it to be PM-decreffed without a
corresponding incref.  That led to a negative refcnt, and an assertion
flipped out when it didn't have a positive ref.

Fixes brho/akaros#42.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agopm: Fix uninitialized struct page semaphore
Barret Rhoden [Sat, 28 Oct 2017 00:38:00 +0000 (20:38 -0400)]
pm: Fix uninitialized struct page semaphore

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agox86: Add get_actual_pstate()
Barret Rhoden [Tue, 24 Oct 2017 20:04:34 +0000 (16:04 -0400)]
x86: Add get_actual_pstate()

This is useful for seeing what p-state a core is actually running at.  For
instance:

$ m monitor 4

(entered monitor on 4)

> kfunc get_actual_pstate

That'll tell you the p-state, and other cores won't be active, which can
interfere with the p-state the core can actually run at.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agox86: Use MSRs and model info for timer freqs (XCC)
Barret Rhoden [Tue, 24 Oct 2017 20:00:32 +0000 (16:00 -0400)]
x86: Use MSRs and model info for timer freqs (XCC)

We should be able to know from cpuid family/model what the bus frequency
is.  It's a minor pain.

On some machine (notably not my Qemu), you can read MSR_PLATFORM_INFO and
get the invariant TSC freq.  With that and the bus freq, we can get an
exact TSC frequency.

This helps FTQ slightly.  With slight errors in the invariant TSC freq,
our measurements would drift.  FTQ has an override for get_tsc_freq(), but
we can do the right thing on Akaros.

Plus this speeds up everyone's boot times!

Reinstall your kernel header, though it shouldn't matter.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoperf: x86: Fix GPF with bad events
Barret Rhoden [Thu, 26 Oct 2017 18:29:43 +0000 (14:29 -0400)]
perf: x86: Fix GPF with bad events

Userspace could give us a bad 'event' parameter with reserved bits set.
That would blow up write_msr() with a GPF.

I noticed this by looking at the code, but it turns out you can recreate
the bug in qemu by trying to use 'anythread' with a non-fixed counter.
e.g.:

perf stat -e TLB_FLUSH:t hello

will die.  Using -e cycles won't do it, since fixed counters were checking
the 'any thread' bit.  Hacking up perf and writing bits to the upper half
of the event / MSR would also trigger the GPF.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoperf: Fix perf event attr config
Barret Rhoden [Thu, 19 Oct 2017 18:32:42 +0000 (14:32 -0400)]
perf: Fix perf event attr config

The mask is supposed to be shifted 8.  The PMEV_GET_MASK helper doesn't
just return the field in place, it masks and shifts the field down to bit
0.

This was causing certain raw and pfm events to be reported to perf
incorrectly.  For example, the HSW icache miss counter is 0x80 mask 0x2.
That was showing up as 0x82 instead of 0x280.  This didn't affect the
actual counter used - just the line from perf that says:

Samples: 6K of event 'raw 0x280:kuH'

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agoperf: Fix uninitialized core_set bug
Barret Rhoden [Thu, 19 Oct 2017 15:41:36 +0000 (11:41 -0400)]
perf: Fix uninitialized core_set bug

Depending on your machine, some bits in the core_set could be set already,
which would be treated as low-latency cores, and thus we wouldn't provision
them to the process.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
21 months agox86: Add a turbo mode helper
Barret Rhoden [Sat, 7 Oct 2017 18:59:58 +0000 (14:59 -0400)]
x86: Add a turbo mode helper

This commands disables or enables Turbo mode, or deals with the turbo
ratio.

The ratio of APERF/MPERF is the amount of turbo mode boosting a processor
received while *unhalted*.  Since we're doing the two MSR reads with a
large gap in between, this will only be accurate over a larger time scale.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoAdd a cpuid helper program
Barret Rhoden [Sat, 7 Oct 2017 18:58:57 +0000 (14:58 -0400)]
Add a cpuid helper program

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agofcntl: reduce noise on invalid arguments
Dmitry Vyukov [Tue, 17 Oct 2017 07:14:46 +0000 (09:14 +0200)]
fcntl: reduce noise on invalid arguments

Kernel generally should not print to console on every EINVAL.
This can produce lots of noise for programs intentionally
or unintentionally feeding garbage into kernel.
Don't print on invalid commands to fcntl syscall.

Change-Id: Ia921c588b670a61f6e647490875ad563ac8738e5
Signed-off-by: Dmitry Vyukov <dvyukov@google.com>
Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoFix dup() of 9ns FDs
Barret Rhoden [Mon, 16 Oct 2017 17:49:57 +0000 (13:49 -0400)]
Fix dup() of 9ns FDs

Glibc uses dup() to implement dup2(), by way of sysdeps/posix/dup2.c.  VFS
dup() was handling the low_fd argument, but 9ns wasn't.  The fix is to
propagate the low_fd (and must_use_low) down through newfd() to
insert_obj_fdt().

Note that fcntl's dup() doesn't force us to use the fd - it's a hint.  The
bigger issue is that glibc's implementation of dup2 might fail; a
concurrent thread could open newfd.  If this is an issue, we'll need an
in-kernel version of dup2().

Fixes brho/akaros#41.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoClose FDs in test_open_lots_and_spawn()
Barret Rhoden [Mon, 16 Oct 2017 17:48:09 +0000 (13:48 -0400)]
Close FDs in test_open_lots_and_spawn()

This allows the following tests to assume a reasonable number of FDs alread
open.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agopthread: Fix null attr for pthread_mutex_init()
Barret Rhoden [Mon, 16 Oct 2017 16:09:22 +0000 (12:09 -0400)]
pthread: Fix null attr for pthread_mutex_init()

Fixes brho/akaros#40.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoAdd an example jumbo page allocator
Barret Rhoden [Thu, 12 Oct 2017 18:23:10 +0000 (11:23 -0700)]
Add an example jumbo page allocator

For reference.  I had one before, but deleted it since it was so simple.
Though it took me longer than I liked to remember how to remake it.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agovmm: Silently accept another type of PIO out
Barret Rhoden [Thu, 5 Oct 2017 19:44:46 +0000 (15:44 -0400)]
vmm: Silently accept another type of PIO out

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agovmm: virtio-blk: Add sanity check
Barret Rhoden [Thu, 5 Oct 2017 18:26:46 +0000 (14:26 -0400)]
vmm: virtio-blk: Add sanity check

The comments says there must be three IOVs; let's assert it to avoid any
problems.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agovmm: virtio-net: Handle single IOVs
Barret Rhoden [Thu, 5 Oct 2017 18:25:29 +0000 (14:25 -0400)]
vmm: virtio-net: Handle single IOVs

Newer versions of Linux send only one IOV, not two.  I didn't see anything
in the spec that says the payload is in the second IOV.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agovmm: Attempt to backtrace the guest on error
Barret Rhoden [Thu, 5 Oct 2017 15:49:03 +0000 (11:49 -0400)]
vmm: Attempt to backtrace the guest on error

Build the guest with CONFIG_FRAME_POINTER.

You can backtrace it with the usual bt-akaros.sh.  You'll need to point
bt-akaros's BIN_PATH to your vmlinux.  Here's what I do:

BIN_PREFIX=PATH_TO_THE_REPO/linux-guest/ ~/scripts/bt-akaros.sh

e.g.

echo '#01 Addr 0xffffffff81480cda is in vmlinux at offset 0xffffffff81480cda
 #02 Addr 0xffffffff81480d0f is in vmlinux at offset 0xffffffff81480d0f
 #03 Addr 0xffffffff813f8e37 is in vmlinux at offset 0xffffffff813f8e37'
 | BIN_PREFIX=../linux-guest/ ~/scripts/bt-akaros.sh

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoAdd backtrace_current_ctx()
Barret Rhoden [Fri, 29 Sep 2017 14:36:31 +0000 (10:36 -0400)]
Add backtrace_current_ctx()

This is a convenience helper.  I'll use it for one-off tracing attempts.
For instance, in sys_openat(), you can do this:

if (!strcmp(path, "hello.txt"))
backtrace_current_ctx();

And then at runtime when catting hello.txt you'll see:

Backtrace of user context on Core 0:
Offsets only matter for shared libraries
 #01 Addr 0x00003000000d2cee is in libc-2.19.so at offset 0x00000000000d0cee
 #02 Addr 0x00003000000ca200 is in libc-2.19.so at offset 0x00000000000c8200
 #03 Addr 0x0000000000415f47 is in busybox at offset 0x0000000000015f47
 #04 Addr 0x002f3d4457500074 has no VMR

which you can pipe through scripts/bt-akaros.sh.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoTrack errno and errstr in the kthread
Barret Rhoden [Thu, 28 Sep 2017 21:50:23 +0000 (17:50 -0400)]
Track errno and errstr in the kthread

Using user memory was slightly dangerous.

First, there are some places in the kernel where we'd read errno/errstr
and make decisions based on it.  Userspace could influence those
decisions - often to their detriment, but perhaps to the kernel's.

The other issue is that the kernel could PF setting errno or errstr,
perhaps if userspace unmaps their syscall struct.  Now, the only places
where that can happen are controlled.  Since we'll want to call error()
(setting errno/errstr) from kernel PF contexts, we don't want to
possibly PF again.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoRefactor uses of finish_{current_,}syscall
Barret Rhoden [Thu, 28 Sep 2017 21:50:08 +0000 (17:50 -0400)]
Refactor uses of finish_{current_,}syscall

There are a few things that get done for every syscall, and the list is
growing: delete the save_str, finish the trace, finish the sysc, etc.
It gets a little nasty due to exec() and fork(), as always.  Yield is
pretty simple, by comparison.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoparlib: Fix devalarms on forks without exec
Barret Rhoden [Thu, 28 Sep 2017 14:54:06 +0000 (10:54 -0400)]
parlib: Fix devalarms on forks without exec

After the fork, the child would close the alarm FDs, which are the
parent's alarm FDs.  However, it wouldn't get its own alarms until exec,
during the ctor.  For processes that forked but never execed, they
wouldn't have the alarm service available.

I noticed this when the process's child was trying to close those -42
FDs when the process forked. (e.g. db -> db -> sh).

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoepoll: Fix leaked listen bug (XCC)
Barret Rhoden [Thu, 28 Sep 2017 01:40:03 +0000 (21:40 -0400)]
epoll: Fix leaked listen bug (XCC)

During the close callbacks for a data FD, the rock CB was called first.
That would close the listen FD (if it was open).  Then we'd call the
epoll CB, which would do an __epoll_ctl_del().  That would open the
listen FD.  However, at that point, the callback that would make sure
the listen FD was closed wouldn't run (it already ran).

The end result for dropbear was that listen FDs were getting leaked.
The DB parent would have the child's listen line open (e.g.
/net/tcp/1/listen, while the child had 1/data).  The child also had the
parent's 0/listen.  The latter had the effect of us never being able to
restart sshd while a client was connected, since someone would always be
listening on port 22.

Rebuild glibc and dropbear.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoAdd strace info for SYS_tap_fds
Barret Rhoden [Thu, 28 Sep 2017 01:03:52 +0000 (21:03 -0400)]
Add strace info for SYS_tap_fds

Now we can tell what sort of taps the user is attempting.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoUse the better hash multiplier for __generic_hash
Barret Rhoden [Wed, 27 Sep 2017 21:20:57 +0000 (17:20 -0400)]
Use the better hash multiplier for __generic_hash

I added Linux's hash.h a while back, but didn't update __generic_hash,
which was using the hardcoded GOLDEN_RATIO_PRIME_32.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoRemove old PER_CPU_THING
Barret Rhoden [Wed, 27 Sep 2017 21:03:38 +0000 (17:03 -0400)]
Remove old PER_CPU_THING

This might have been from Ivy.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoDiscard leading 'm ' from monitor commands
Barret Rhoden [Wed, 27 Sep 2017 20:59:45 +0000 (16:59 -0400)]
Discard leading 'm ' from monitor commands

If you use 'm' a lot, when you are actually in the kernel monitor, you
may type 'm COMMAND' out of habit.  This will ignore the 'm' and execute
the command.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoAdd monitor helpers for hexdump and pahexdump
Barret Rhoden [Wed, 27 Sep 2017 20:40:20 +0000 (16:40 -0400)]
Add monitor helpers for hexdump and pahexdump

Hexdump takes a PID.  Use 0 for the kernel or "don't care."

There are shortcuts too: 'hd' for hexdump and 'phd' for pahexdump.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
22 months agoFix leaked proc refcnt in showmapping
Barret Rhoden [Wed, 27 Sep 2017 20:38:10 +0000 (16:38 -0400)]
Fix leaked proc refcnt in showmapping

You'd only trigger this if you were using monitor functions.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>