Commit Graph

272951 Commits

Author SHA1 Message Date
macallan
627d9cb448 if we have more than one i2c-bus node, look for children on both
now we find the light sensor in my shiny new toy
2020-01-09 18:47:46 +00:00
martin
c604f98ede Instead of a (bogus) attempt to query the model via ofctl, use the (now
fixed) sysctl hw.model instead.
2020-01-09 17:06:46 +00:00
ad
c5b060977a - Many small tweaks to the SMT awareness in the scheduler. It does a much
better job now at keeping all physical CPUs busy, while using the extra
  threads to help out.  In particular, during preempt() if we're using SMT,
  try to find a better CPU to run on and teleport curlwp there.

- Change the CPU topology stuff so it can work on asymmetric systems.  This
  mainly entails rearranging one of the CPU lists so it makes sense in all
  configurations.

- Add a parameter to cpu_topology_set() to note that a CPU is "slow", for
  where there are fast CPUs and slow CPUs, like with the Rockwell RK3399.
  Extend the SMT awareness to try and handle that situation too (keep fast
  CPUs busy, use slow CPUs as helpers).
2020-01-09 16:35:03 +00:00
maxv
f0ac038b23 Registering the host's CR0 is done outside of the VCPU loop, so it must be
cleared because it is also cleared inside the loop.

Not clearing it could trigger DNAs on VMEXITs, because STTS/CLTS are still
here as part of debugging since my FPU overhaul.
2020-01-09 16:27:57 +00:00
martin
2fac6cb259 When attaching the first fdtbus, use the root "comptabile" (or failing that:
"model") property to set the cpu model (in userland aka sysctl hw.model).
When attaching the first cpu, do not overwrite a cpu model if it already
had been set.
2020-01-09 16:23:41 +00:00
maxv
3cae8f6437 Mmh, as noted in PR/54847, this should be uint64_t, not uint16_t. Harmless
because we use only the two lowest bits anyway.

I believe this could be caught by KUBSAN; time to do another round of
NVMM+K_SAN testing.
2020-01-09 16:20:12 +00:00
ad
56f477e67b Add a recommendation for SMT to not split threads. XXX This should report
topo info to help the decision.
2020-01-09 15:50:16 +00:00
martin
abce8cb394 Finish conversion of extended partitioning parts to new abstract
backend interface. XXX still could use a lot of polishing.
2020-01-09 13:22:30 +00:00
msaitoh
82b4e8d166 Acquire/release host semaphore to share SMBus between the host and
the embedded controller (IMC).

 Without this change, "shutdown -r" does power off and not boot on ECS HDC-I2.
This change fixes the problem.
2020-01-09 12:49:12 +00:00
msaitoh
cc226cbe2a Reduce diff against OpenBSD. No functional change.
- USE CSR_{READ,WRITE}_*() macro.
- Move some macros from if_stge.c to if_stgereg.h
2020-01-09 10:54:16 +00:00
kamil
576cdd6361 Add missing compat define of PT32_GETXSTATE
Fixes i386 build.

Reviewed by <mgorny>
2020-01-09 10:46:31 +00:00
ad
fc833de53f Use __SHIFTIN()/__SHIFTOUT(). Suggested by riastradh@. 2020-01-09 10:43:45 +00:00
yamaguchi
edcbb7646e Make some parametes in ixl(4) be able to change when loading
for debugging

- nomsix(boolean)
   - disable msix support
- stats_interval(signed integer)
   - change interval for collecting statistic counters
- nqps_limit(signed integer)
   - limitation for the number of queue pairs
- {tx,rx}_ndescs(unsigned integer)
   - the number of discriptors in txqueue or rxqueue
2020-01-09 08:54:05 +00:00
thorpej
a7ebfbc5bb Re-enable the intr / mask / softint / unmask dance now that the x86
interrupt issue is fixed.  Verified working by ryoon@ (thanks!).
2020-01-09 04:04:01 +00:00
yamaguchi
ac53db4aac ixl(4) supports in-chip statistic counters per VSI 2020-01-09 02:55:41 +00:00
yamaguchi
6cade11055 ixl(4) supports in-chip statistic counters per port 2020-01-09 02:43:45 +00:00
ryo
6c4b616d74 fix behaviour mmap()/mprotect() when passed only PROT_EXEC.
when mmap()/mprotect() with only PROT_EXEC, syscall will be successful,
but the page actually hadn't been mapped.
it should be mapped with PROT_READ|PROT_EXEC implicitly. (r-x)
2020-01-09 01:38:34 +00:00
manu
aadbe7d326 Rollback multiboot2 for amd64, as requested by core 2020-01-09 00:42:24 +00:00
macallan
ed787f4d25 send PMF events for volume and brightness control keys on Apple keyboards 2020-01-08 23:28:56 +00:00
christos
0fb78fffb4 Back out previous. This has no chance to work unless the make variable parsing
is not changed do that instead of scanning for a single character delim ':',
it scans for "?:". This is because !empty(COMPILE.c:M*-pg*) contains a ':'.
2020-01-08 22:04:24 +00:00
skrll
c88f2c1a4e oldlwp is always non-NULL in cpu_switchto so remove the test for NULL. 2020-01-08 20:59:18 +00:00
skrll
cb88287373 Use fat16 as the partition is too small for fat32. from Harold Gutch 2020-01-08 20:49:22 +00:00
jmcneill
6372dd6bcf cpu_hatch is too late to report AP topology, do it at attach time instead 2020-01-08 18:47:43 +00:00
ad
2ddceed1d9 Hopefully fix some problems seen with MP support on non-x86, in particular
where curcpu() is defined as curlwp->l_cpu:

- mi_switch(): undo the ~2007ish optimisation to unlock curlwp before
  calling cpu_switchto().  It's not safe to let other actors mess with the
  LWP (in particular l->l_cpu) while it's still context switching.  This
  removes l->l_ctxswtch.

- Move the LP_RUNNING flag into l->l_flag and rename to LW_RUNNING since
  it's now covered by the LWP's lock.

- Ditch lwp_exit_switchaway() and just call mi_switch() instead.  Everything
  is in cache anyway so it wasn't buying much by trying to avoid saving old
  state.  This means cpu_switchto() will never be called with prevlwp ==
  NULL.

- Remove some KERNEL_LOCK handling which hasn't been needed for years.
2020-01-08 17:38:41 +00:00
mgorny
b4d38fb000 Add tests for reading registers from x86 core dumps 2020-01-08 17:23:34 +00:00
mgorny
7d1a2cdc58 Combine x86 register tests into unified test function
Reduce the code duplication and improve maintainability of x86 register
tests by combining all of them to a single base function.
2020-01-08 17:23:15 +00:00
mgorny
adb864df5e Fix alignment when reading core notes
Both desc and note header needs to be aligned.  Therefore, we need
to realign after skipping past desc as well.

While at it, fix the other alignment fix to use roundup() macro.
2020-01-08 17:22:40 +00:00
mgorny
77791248de Include XSTATE note in x86 core dumps
Introduce a simple COREDUMP_MACHDEP_LWP_NOTES logic to provide machdep
API for injecting per-LWP notes into coredumps, and use it to append
PT_GETXSTATE note.

Since the XSTATE block uses the same format on i386 and amd64, the code
does not have to conditionalize between 32-bit and 64-bit ELF format
on that.  However, it does need to distinguish between 32-bit and 64-bit
PT_* values.  In order to do that, it reuses PT32_* constant already
present for ptrace(), and adds a matching PT64_GETXSTATE to satisfy
the cpp logic.
2020-01-08 17:21:38 +00:00
ad
41a8f863b8 lockdebug_barrier(): allow the one permitted lock to be a sleep lock too. 2020-01-08 16:21:34 +00:00
ad
bf76aaa957 Make "mach cpu" in ddb show the IPL for each cpu. 2020-01-08 15:47:50 +00:00
macallan
df3da34f6a add lmtemp, found in some late powerbooks 2020-01-08 14:21:12 +00:00
ad
82106a470c NetBSD 9.99.35 - namecache changes 2020-01-08 14:04:06 +00:00
joerg
314289ac5a Format string annotation for cmdq_insert_hook. 2020-01-08 13:45:21 +00:00
isaki
3b9c5d089b Fix an resource leak on audiobell close.
audioclose() freed audio_file_t structure, but only audiobellclose
didn't pass there.  I change that all of freeing audio_file_t is done
by each *_close().
2020-01-08 13:30:15 +00:00
macallan
4d15c1eb43 add makphy, found in late(ish) PowerBooks 2020-01-08 13:28:14 +00:00
isaki
b01e228efb Remove obsoleted comment. 2020-01-08 13:05:02 +00:00
ad
afb661980d Regen. 2020-01-08 12:06:09 +00:00
ad
9e93be3837 - options NAMECACHE_ENTER_REVERSE is no more.
- Partially sort the list of per-vnode namecache entries by using a TAILQ.
  Put the real name to the head, and put dot and dotdot to the tail so that
  cache_lookup_reverse() doesn't have to consider them.
2020-01-08 12:04:56 +00:00
ad
51ce3a6397 Show reverse misses too. 2020-01-08 11:58:02 +00:00
ad
adae1b1608 Add ad-namecache. 2020-01-08 11:05:39 +00:00
yamaguchi
479915944e Not stop kpreempt if unnecessary, ixl(4) 2020-01-08 09:12:11 +00:00
isaki
ab1308759b Move mutex_exit() correct place to protect sc_async_mixer.
Thanks maxv@!
2020-01-08 08:10:15 +00:00
ryo
68eed2cb9c fix panic when modload.
>panic: kernel diagnostic assertion "!pmap_extract(pmap_kernel(), loopva, NULL)" failed: file "../../../../uvm/uvm_km.c", line 674 loopva=0xffffffc001000000'

The space allocated by bootpage_alloc() is only used as a physical page
for pagetable pages, so there is no need to map it with KVA.
And kernend_extra should not have consumed any KVA space.
2020-01-08 05:41:07 +00:00
nonaka
866b8f41d8 Added some RNDIS status definitions from FreeBSD. 2020-01-08 04:53:38 +00:00
christos
42506d4e49 tweak the DBG rule that -fomit-frame-pointer for aarch64 when profiling
(because the compiler complains), to use a match with the compile flags
and *pg*, instead of using a match to a target suffix (which is NetBSD
build-specific). Pointed out by phone@.
2020-01-08 04:15:45 +00:00
msaitoh
0d3a42e824 - Fix SFF_SFP_ETH_FLAGS_100FX. It's not 0x10 but 0x20.
- Define SFF_SFP_ETH_FLAGS_100LX with 0x10.
2020-01-08 03:51:37 +00:00
rillig
f5872e2e0d usr.bin/make: document probabilities for random test failures
Side node: this test will never fail between 2024-04-15 and 2024-07-06.
2020-01-07 22:42:14 +00:00
rillig
0bcf77e1f6 usr.bin/make: remove dead code
The preprocessor conditions contradicted each other: __hpux__ or __hpux
would need to be defined, and at the same time none of them would need to
be defined.
2020-01-07 21:24:16 +00:00
ad
58ff591993 pmap_ept_enter(): PTE -> EPT in two places. 2020-01-07 21:18:24 +00:00
rillig
4ef4eb355f usr.bin/make: fix typos in comment 2020-01-07 20:50:12 +00:00