diff options
| author | bors <bors@rust-lang.org> | 2013-11-22 07:31:35 -0800 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2013-11-22 07:31:35 -0800 |
| commit | d3cb24b1fe3fd0e31cccf8ca3c53470f747bae0c (patch) | |
| tree | 566b929fc15c4b7fd91a490aaf3e24b7289dab52 | |
| parent | cad1f89bb5f2b5bdbaa740f7b36d319374fc0b1a (diff) | |
| parent | bf61641e9f30927d751d98b52f00a6685c79c347 (diff) | |
| download | rust-d3cb24b1fe3fd0e31cccf8ca3c53470f747bae0c.tar.gz rust-d3cb24b1fe3fd0e31cccf8ca3c53470f747bae0c.zip | |
auto merge of #10610 : thestinger/rust/breakpoint, r=pnkfelix
This can be used to grab the attention of a debugger, and unlike `abort` execution can be resumed.
| -rw-r--r-- | src/librustc/middle/trans/base.rs | 1 | ||||
| -rw-r--r-- | src/librustc/middle/trans/intrinsic.rs | 5 | ||||
| -rw-r--r-- | src/librustc/middle/typeck/check/mod.rs | 3 | ||||
| -rw-r--r-- | src/libstd/unstable/intrinsics.rs | 4 |
4 files changed, 12 insertions, 1 deletions
diff --git a/src/librustc/middle/trans/base.rs b/src/librustc/middle/trans/base.rs index 80b3455e9fa..0ece7c8c024 100644 --- a/src/librustc/middle/trans/base.rs +++ b/src/librustc/middle/trans/base.rs @@ -2759,6 +2759,7 @@ pub fn declare_intrinsics(llmod: ModuleRef) -> HashMap<&'static str, ValueRef> { [i8p, Type::i8(), Type::i64(), Type::i32(), Type::i1()], Type::void()); ifn!(intrinsics, "llvm.trap", [], Type::void()); + ifn!(intrinsics, "llvm.debugtrap", [], Type::void()); ifn!(intrinsics, "llvm.frameaddress", [Type::i32()], i8p); ifn!(intrinsics, "llvm.powi.f32", [Type::f32(), Type::i32()], Type::f32()); diff --git a/src/librustc/middle/trans/intrinsic.rs b/src/librustc/middle/trans/intrinsic.rs index 38bffd4f6e5..3f3659ceaed 100644 --- a/src/librustc/middle/trans/intrinsic.rs +++ b/src/librustc/middle/trans/intrinsic.rs @@ -228,6 +228,11 @@ pub fn trans_intrinsic(ccx: @mut CrateContext, Call(bcx, llfn, [], []); Unreachable(bcx); } + "breakpoint" => { + let llfn = bcx.ccx().intrinsics.get_copy(&("llvm.debugtrap")); + Call(bcx, llfn, [], []); + RetVoid(bcx); + } "size_of" => { let tp_ty = substs.tys[0]; let lltp_ty = type_of::type_of(ccx, tp_ty); diff --git a/src/librustc/middle/typeck/check/mod.rs b/src/librustc/middle/typeck/check/mod.rs index 8d643ef2200..533102c1d38 100644 --- a/src/librustc/middle/typeck/check/mod.rs +++ b/src/librustc/middle/typeck/check/mod.rs @@ -3968,7 +3968,8 @@ pub fn check_intrinsic_type(ccx: @mut CrateCtxt, it: @ast::foreign_item) { } else { match name { - "abort" => (0, ~[], ty::mk_bot()), + "abort" => (0, ~[], ty::mk_bot()), + "breakpoint" => (0, ~[], ty::mk_nil()), "size_of" | "pref_align_of" | "min_align_of" => (1u, ~[], ty::mk_uint()), "init" => (1u, ~[], param(ccx, 0u)), diff --git a/src/libstd/unstable/intrinsics.rs b/src/libstd/unstable/intrinsics.rs index f0b94c10fdc..ea3ed10da4e 100644 --- a/src/libstd/unstable/intrinsics.rs +++ b/src/libstd/unstable/intrinsics.rs @@ -176,6 +176,10 @@ extern "rust-intrinsic" { /// Abort the execution of the process. pub fn abort() -> !; + /// Execute a breakpoint trap, for inspection by a debugger. + #[cfg(not(stage0))] + pub fn breakpoint(); + /// Atomic compare and exchange, sequentially consistent. pub fn atomic_cxchg(dst: &mut int, old: int, src: int) -> int; /// Atomic compare and exchange, acquire ordering. |
