Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 10 Feb 2008 22:42:47 +0000
From:      John Birrell <jb@what-creek.com>
To:        current@freebsd.org
Subject:   New DTrace source snapshot
Message-ID:  <20080210224247.GA70317@what-creek.com>

next in thread | raw e-mail | index | archive | help
This one fixes problems with the previous one:

- buildkernel would fail because NO_CTF=1 was not set when
  building the lone kernel build tool.
- A number of things were missing from the dtrace kernel 
  module on i386.
- Missing syscall names in the kernel without witness have
  been resolved so this snapshot should build with and without
  witness, invariants, smp etc.

<http://people.freebsd.org/~jb/dtrace/dtrace-20080211.tar.bz>;

Known problems:
- This is a snapshot of current which contains lock order
  reversal warnings. These are not related to the DTrace-specific
  code.
- ustack() as reported by Drew hasn't been ported yet, so don't
  expect it to do anything.
- On i386 mp_maxid in the kernel doesn't behave the same way that
  it does on amd64. Work-around code exists for this, but it is
  less than optimal.
- A few of the tests that pass on amd64 don't work on i386. The
  causes are under investigation. The worst one is the tailcall
  test which causes the machine to reboot. Ugh.

Note:
- This snapshot should build cleanly on either a CURRENT or a
  RELENG_7 system. If not, please tell me. RELENG_6 users should
  upgrade to RELENG_7 first or contact me. The tool bootstrap
  will fail to build when hosted on RELENG_6.
- It should be ABI compatible with CURRENT and RELENG_7. If
  not, please tell me.
- This snapshot extends the basic OpenSolaris DTrace functionality
  to support:

  printm(const size_t bufrsize, uintptr_t *memref);

  where:

  'memref' is an an array of 2 uintptr_t entries -- address and
  size.

  Usage example:

  printm(500, memref(mypointer, mysize));

  reserves buffer space of 500 bytes to trace memory at address
  'mypointer' with size 'mysize'. Both 'mypointer' and 'mysize'
  can be variables in the D script.

  By contrast, OpenSolaris only supports tracemem(ptr, const size)
  where 'size' is fixed at compile time. This is not terribly
  useful when tracing protocols or variable read sizes where the
  data indicates how long the memory object is.

Target audience:

  I'd like to get more people involved with running this code.
  If you just like to follow FreeBSD current and don't even try
  to contribute stuff back... this snapshot is something you
  could try. I need some feeback from people who just use
  FreeBSD-CURRENT.

--
John Birrell



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080210224247.GA70317>