blob: b7cef2fecdb5ddff7b89aff9149e5a45f017eaeb (
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
|
{-# LANGUAGE Trustworthy #-}
{-# LANGUAGE NoImplicitPrelude #-}
-- | @since 4.7.0.0
module GHC.Profiling ( -- * Cost Centre Profiling
startProfTimer
, stopProfTimer
-- * Heap Profiling
, startHeapProfTimer
, stopHeapProfTimer
, requestHeapCensus
)where
import GHC.Base
-- | Stop attributing ticks to cost centres. Allocations will still be
-- attributed.
--
-- @since 4.7.0.0
foreign import ccall stopProfTimer :: IO ()
-- | Start attributing ticks to cost centres. This is called by the RTS on
-- startup.
--
-- @since 4.7.0.0
foreign import ccall startProfTimer :: IO ()
-- | Request a heap census on the next context switch. The census can be
-- requested whether or not the heap profiling timer is running.
-- Note: This won't do anything unless you also specify a profiling mode on the
-- command line using the normal RTS options.
--
-- @since 4.16.0.0
foreign import ccall requestHeapCensus :: IO ()
-- | Start heap profiling. This is called normally by the RTS on start-up,
-- but can be disabled using the rts flag `--no-automatic-heap-samples`
-- Note: This won't do anything unless you also specify a profiling mode on the
-- command line using the normal RTS options.
--
-- @since 4.16.0.0
foreign import ccall startHeapProfTimer :: IO ()
-- | Stop heap profiling.
-- Note: This won't do anything unless you also specify a profiling mode on the
-- command line using the normal RTS options.
--
-- @since 4.16.0.0
foreign import ccall stopHeapProfTimer :: IO ()
|