summaryrefslogtreecommitdiff
path: root/performance-tests/Synch-Benchmarks/Perf_Test/README
blob: 28f1f160e8a6d2a34662e66b71887fd1fd06eca7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
The files in this directory support controlled benchmarking of the ACE
synchronization mechanisms.

  These mechanisms include:

	. Mutexes
	. Reader/writer locks
	. Condition variables
	. Semaphores
        . Tokens
        . Adaptive lockings

There are additional tests that measure the memory bandwidth under the
following conditions:

	. User memory-to-memory copying of data within a single thread
 	. User memory-to-kernel-to-user memory copying via pipes
	  between separate processes, as well as between separate
	  threads in the same process

There are many options available for this module that can be put into
svc.conf files.  See the Performance_Test_Options.[Chi] file for more
details.  Some reasonable options to use to run the tests are:

 -v -B -s 15
 -v -n 4 -t 4 -s 15

You should experiment with other options as you see fit.  Note that on
Solaris, you should always make sure that you have more than 1 LWP (by
using either the -B or the -n options) since otherwise the program may
get into an infinite loop due to the semantics of SunOS unbound
threads... (This may no longer be the case.)


Available Options in Performance_Test module:
=============================================

Thread Creation:
----------------
      -B:    Create thread with THR_BOUND
      -D:    Create thread with THR_DETACHED
      -N:    Create thread with flag THR_NEW_LWP
      -n:    Set # of lwp's (default is 0)
      -t:    Set # of threads contending the lock (default is 4)

Run Test:
---------
      -s:    Set testing duration (in seconds, default is 100)
      -T:    Enable/disable tracing.

Misc:
-----
      -p:    Toggle whether summary is printed
      -e:    Perform eager exit (without cleaning up)
      -M:    Set message size in pipe_[proc|thr]_test

Reserved Flags:
---------------
      -a:    Not used.  (do_ack ???)
      -A:    Not used.  (set rendezvous point)
      -c:    Not used.  (# of connections)
      -C:    Not used.  (Toggle calculate checksum)
      -d:    Not used.  (Enable debugging)
      -F:    Not used.  (Free memory)
      -g:    Not used.  (generate data ??)
      -H:    Not used.  (set high water mark)
      -i:    Not used.  (# of iterations)
      -L:    Not used.  (set low water mark)
      -l:    Not used.  (set initial queue length)
      -m:    Not used.  (set mapped file name)
      -P:    Not used.  (set consecutive ports)
      -S:    Not used.  (set service_entry ???)
      -u:    Not used.  (use udp)
      -v:    Not used.  (set display verbosely)
      -X:    Not used.  (Use xdr conversion)
      -Z:    Not used.  (Do zero copy)