diff options
| -rw-r--r-- | erts/configure.in | 106 | ||||
| -rw-r--r-- | erts/doc/src/erlang.xml | 52 | ||||
| -rw-r--r-- | erts/emulator/beam/atom.names | 11 | ||||
| -rw-r--r-- | erts/emulator/beam/bif.tab | 15 | ||||
| -rw-r--r-- | erts/emulator/beam/external.c | 111 | ||||
| -rw-r--r-- | erts/emulator/beam/external.h | 26 | ||||
| -rw-r--r-- | erts/emulator/test/binary_SUITE.erl | 35 | ||||
| -rw-r--r-- | lib/stdlib/src/Makefile | 10 | ||||
| -rwxr-xr-x | otp_build | 10 | 
9 files changed, 275 insertions, 101 deletions
| diff --git a/erts/configure.in b/erts/configure.in index faccf5f102..ea97d73aa8 100644 --- a/erts/configure.in +++ b/erts/configure.in @@ -1,20 +1,20 @@  dnl Process this file with autoconf to produce a configure script. -*-m4-*-  dnl %CopyrightBegin% -dnl  -dnl Copyright Ericsson AB 1997-2009. All Rights Reserved. -dnl  +dnl +dnl Copyright Ericsson AB 1997-2010. All Rights Reserved. +dnl  dnl The contents of this file are subject to the Erlang Public License,  dnl Version 1.1, (the "License"); you may not use this file except in  dnl compliance with the License. You should have received a copy of the  dnl Erlang Public License along with this software. If not, it can be  dnl retrieved online at http://www.erlang.org/. -dnl  +dnl  dnl Software distributed under the License is distributed on an "AS IS"  dnl basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  dnl the License for the specific language governing rights and limitations  dnl under the License. -dnl  +dnl  dnl %CopyrightEnd%  dnl The string "FIXME convbreak" means that there is a break of @@ -344,6 +344,9 @@ case $host_os in  	AC_MSG_WARN([Reverting to 32-bit time_t])  	CPPFLAGS="$CPPFLAGS -D_USE_32BIT_TIME_T"  	;; +    darwin*) +        CPPFLAGS="$CPPFLAGS -D_XOPEN_SOURCE" +        ;;      *)  	;;  esac @@ -2098,6 +2101,44 @@ if test X${enable_hipe} != Xno; then    	esac    fi  fi + +case $ARCH-$OPSYS in +	amd64-darwin*|x86-darwin*) +		AC_MSG_CHECKING([For modern (leopard) style mcontext_t]) +		AC_TRY_COMPILE([ +				#include <stdlib.h> +				#include <sys/types.h> +				#include <unistd.h> +				#include <mach/mach.h> +				#include <pthread.h> +				#include <machine/signal.h> +				#include <ucontext.h> +				],[ +				#if defined(__APPLE__) && defined(__MACH__) && !defined(__DARWIN__) +				#define __DARWIN__ 1 +				#endif + +				#ifndef __DARWIN__ +				#error inpossible +				#else + +				mcontext_t mc = NULL; +				int x = mc->__fs.__fpu_mxcsr; + +				#endif +				],darwin_mcontext_leopard=yes, +				darwin_mcontext_leopard=no) +				if test X"$darwin_mcontext_leopard" = X"yes"; then +				   AC_DEFINE(DARWIN_MODERN_MCONTEXT,[],[Modern style mcontext_t in MacOSX]) +				   AC_MSG_RESULT(yes) +				else +				   AC_MSG_RESULT(no) +				fi +		;; +	*) +		darwin_mcontext_leopard=no +		;; +esac  if test X${enable_fp_exceptions} = Xauto ; then     if test X${enable_hipe} = Xyes; then        enable_fp_exceptions=yes @@ -2487,6 +2528,7 @@ static void fpe_sig_action(int sig, siginfo_t *si, void *puc)      regs[PT_FPSCR] = 0x80|0x40|0x10;	/* VE, OE, ZE; not UE or XE */  #endif  #elif defined(__DARWIN__) +#if defined(DARWIN_MODERN_MCONTEXT)  #if defined(__x86_64__)      mcontext_t mc = uc->uc_mcontext;      struct __darwin_x86_float_state64 *fpstate = &mc->__fs; @@ -2502,6 +2544,23 @@ static void fpe_sig_action(int sig, siginfo_t *si, void *puc)      mc->ss.srr0 += 4;      mc->fs.fpscr = 0x80|0x40|0x10;  #endif +#else +#if defined(__x86_64__) +    mcontext_t mc = uc->uc_mcontext; +    struct x86_float_state64_t *fpstate = &mc->fs; +    fpstate->fpu_mxcsr = 0x1F80; +    *(unsigned short *)&fpstate->fpu_fsw &= ~0xFF; +#elif defined(__i386__) +    mcontext_t mc = uc->uc_mcontext; +    x86_float_state32_t	*fpstate = &mc->fs; +    fpstate->fpu_mxcsr = 0x1F80; +    *(unsigned short *)&fpstate->fpu_fsw &= ~0xFF; +#elif defined(__ppc__) +    mcontext_t mc = uc->uc_mcontext; +    mc->ss.srr0 += 4; +    mc->fs.fpscr = 0x80|0x40|0x10; +#endif +#endif  #elif defined(__FreeBSD__) && defined(__x86_64__)      mcontext_t *mc = &uc->uc_mcontext;      struct savefpu *savefpu = (struct savefpu*)&mc->mc_fpstate; @@ -2615,43 +2674,6 @@ fi)      fi  fi	 -case $ARCH-$OPSYS in -	amd64-darwin*|x86-darwin*) -		AC_MSG_CHECKING([For modern (leopard) style mcontext_t]) -		AC_TRY_COMPILE([ -				#include <stdlib.h> -				#include <sys/types.h> -				#include <unistd.h> -				#include <mach/mach.h> -				#include <pthread.h> -				#include <machine/signal.h> -				#include <ucontext.h> -				],[ -				#if defined(__APPLE__) && defined(__MACH__) && !defined(__DARWIN__) -				#define __DARWIN__ 1 -				#endif - -				#ifndef __DARWIN__ -				#error inpossible -				#else - -    				mcontext_t mc = NULL; -    				int x = mc->__fs.__fpu_mxcsr; - -				#endif -				],darwin_mcontext_leopard=yes, -				darwin_mcontext_leopard=no) -				if test X"$darwin_mcontext_leopard" = X"yes"; then -				   AC_DEFINE(DARWIN_MODERN_MCONTEXT,[],[Modern style mcontext_t in MacOSX]) -				   AC_MSG_RESULT(yes) -				else -				   AC_MSG_RESULT(no) -				fi		 -		;; -	*)	 -		darwin_mcontext_leopard=no -		;; -esac diff --git a/erts/doc/src/erlang.xml b/erts/doc/src/erlang.xml index 871fc0fd63..4a401156d1 100644 --- a/erts/doc/src/erlang.xml +++ b/erts/doc/src/erlang.xml @@ -4,7 +4,7 @@  <erlref>    <header>      <copyright> -      <year>1996</year><year>2009</year> +      <year>1996</year><year>2010</year>        <holder>Ericsson AB. All Rights Reserved.</holder>      </copyright>      <legalnotice> @@ -13,12 +13,12 @@        compliance with the License. You should have received a copy of the        Erlang Public License along with this software. If not, it can be        retrieved online at http://www.erlang.org/. -     +        Software distributed under the License is distributed on an "AS IS"        basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See        the License for the specific language governing rights and limitations        under the License. -     +      </legalnotice>      <title>erlang</title> @@ -342,8 +342,50 @@ iolist() = [char() | binary() | iolist()]        <desc>          <p>Returns an Erlang term which is the result of decoding            the binary object <c>Binary</c>, which must be encoded -          according to the Erlang external term format. See also -          <seealso marker="#term_to_binary/1">term_to_binary/1</seealso>.</p> +          according to the Erlang external term format.</p> +        <warning> +	  <p>When decoding binaries from untrusted sources, consider using +	     <c>binary_to_term/2</c> to prevent denial of service attacks.</p> +        </warning> +	<p>See also +	   <seealso marker="#term_to_binary/1">term_to_binary/1</seealso> +           and +	   <seealso marker="#binary_to_term/2">binary_to_term/2</seealso>.</p> +      </desc> +    </func> +    <func> +      <name>erlang:binary_to_term(Binary, Opts) -> term()</name> +      <fsummary>Decode an Erlang external term format binary</fsummary> +      <type> +        <v>Opts = [safe]</v> +        <v>Binary = ext_binary()</v> +      </type> +      <desc> +        <p>As <c>binary_to_term/1</c>, but takes options that affect decoding +           of the binary.</p> +        <taglist> +          <tag><c>safe</c></tag> +          <item> +	    <p>Use this option when receiving binaries from an untrusted +               source.</p> +	    <p>When enabled, it prevents decoding data that may be used to +	       attack the Erlang system.  In the event of receiving unsafe +               data, decoding fails with a badarg error.</p> +	    <p>Currently, this prevents creation of new atoms directly, +	       creation of new atoms indirectly (as they are embedded in +	       certain structures like pids, refs, funs, etc.), and creation of +	       new external function references.  None of those resources are +	       currently garbage collected, so unchecked creation of them can +               exhaust available memory.</p> +          </item> +        </taglist> +	<p>Failure: <c>badarg</c> if <c>safe</c> is specified and unsafe data +           is decoded.</p> +        <p>See also +           <seealso marker="#term_to_binary/1">term_to_binary/1</seealso>, +           <seealso marker="#binary_to_term/1">binary_to_term/1</seealso>, +           and <seealso marker="#list_to_existing_atom/1"> +             list_to_existing_atom/1</seealso>.</p>        </desc>      </func>      <func> diff --git a/erts/emulator/beam/atom.names b/erts/emulator/beam/atom.names index 04eac2d807..3ce26c4a7a 100644 --- a/erts/emulator/beam/atom.names +++ b/erts/emulator/beam/atom.names @@ -1,19 +1,19 @@  #  # %CopyrightBegin% -#  -# Copyright Ericsson AB 1996-2009. All Rights Reserved. -#  +# +# Copyright Ericsson AB 1996-2010. All Rights Reserved. +#  # The contents of this file are subject to the Erlang Public License,  # Version 1.1, (the "License"); you may not use this file except in  # compliance with the License. You should have received a copy of the  # Erlang Public License along with this software. If not, it can be  # retrieved online at http://www.erlang.org/. -#  +#  # Software distributed under the License is distributed on an "AS IS"  # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  # the License for the specific language governing rights and limitations  # under the License. -#  +#  # %CopyrightEnd%  # @@ -446,6 +446,7 @@ atom running  atom running_ports  atom running_procs  atom runtime +atom safe  atom save_calls  atom scheduler   atom scheduler_id diff --git a/erts/emulator/beam/bif.tab b/erts/emulator/beam/bif.tab index 85a729208f..b6fa06354a 100644 --- a/erts/emulator/beam/bif.tab +++ b/erts/emulator/beam/bif.tab @@ -1,19 +1,19 @@  #  # %CopyrightBegin% -#  -# Copyright Ericsson AB 1996-2009. All Rights Reserved. -#  +# +# Copyright Ericsson AB 1996-2010. All Rights Reserved. +#  # The contents of this file are subject to the Erlang Public License,  # Version 1.1, (the "License"); you may not use this file except in  # compliance with the License. You should have received a copy of the  # Erlang Public License along with this software. If not, it can be  # retrieved online at http://www.erlang.org/. -#  +#  # Software distributed under the License is distributed on an "AS IS"  # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  # the License for the specific language governing rights and limitations  # under the License. -#  +#  # %CopyrightEnd%  # @@ -755,6 +755,11 @@ bif erlang:call_on_load_function/1  bif erlang:finish_after_on_load/2  # +# New Bifs in R13B4 +# +bif erlang:binary_to_term/2 + +#  # Obsolete  # diff --git a/erts/emulator/beam/external.c b/erts/emulator/beam/external.c index f856cce18f..f380e7732e 100644 --- a/erts/emulator/beam/external.c +++ b/erts/emulator/beam/external.c @@ -1,19 +1,19 @@  /*   * %CopyrightBegin% - *  - * Copyright Ericsson AB 1996-2009. All Rights Reserved. - *  + * + * Copyright Ericsson AB 1996-2010. All Rights Reserved. + *   * The contents of this file are subject to the Erlang Public License,   * Version 1.1, (the "License"); you may not use this file except in   * compliance with the License. You should have received a copy of the   * Erlang Public License along with this software. If not, it can be   * retrieved online at http://www.erlang.org/. - *  + *   * Software distributed under the License is distributed on an "AS IS"   * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See   * the License for the specific language governing rights and limitations   * under the License. - *  + *   * %CopyrightEnd%   */ @@ -1059,10 +1059,10 @@ binary2term_abort(ErtsBinary2TermState *state)  }  static ERTS_INLINE Eterm -binary2term_create(ErtsBinary2TermState *state, Eterm **hpp, ErlOffHeap *ohp) +binary2term_create(ErtsDistExternal *edep, ErtsBinary2TermState *state, Eterm **hpp, ErlOffHeap *ohp)  {      Eterm res; -    if (!dec_term(NULL, hpp, state->extp, ohp, &res)) +    if (!dec_term(edep, hpp, state->extp, ohp, &res))  	res = THE_NON_VALUE;      if (state->exttmp) {  	state->exttmp = 0; @@ -1086,7 +1086,7 @@ erts_binary2term_abort(ErtsBinary2TermState *state)  Eterm  erts_binary2term_create(ErtsBinary2TermState *state, Eterm **hpp, ErlOffHeap *ohp)  { -    return binary2term_create(state, hpp, ohp); +    return binary2term_create(NULL,state, hpp, ohp);  }  BIF_RETTYPE binary_to_term_1(BIF_ALIST_1) @@ -1114,7 +1114,67 @@ BIF_RETTYPE binary_to_term_1(BIF_ALIST_1)      hp = HAlloc(BIF_P, heap_size);      endp = hp + heap_size; -    res = binary2term_create(&b2ts, &hp, &MSO(BIF_P)); +    res = binary2term_create(NULL, &b2ts, &hp, &MSO(BIF_P)); + +    erts_free_aligned_binary_bytes(temp_alloc); + +    if (hp > endp) { +	erl_exit(1, ":%s, line %d: heap overrun by %d words(s)\n", +		 __FILE__, __LINE__, hp-endp); +    } + +    HRelease(BIF_P, endp, hp); + +    if (res == THE_NON_VALUE) +	goto error; + +    return res; +} + +BIF_RETTYPE binary_to_term_2(BIF_ALIST_2) +{ +    Sint heap_size; +    Eterm res; +    Eterm opts; +    Eterm opt; +    Eterm* hp; +    Eterm* endp; +    Sint size; +    byte* bytes; +    byte* temp_alloc = NULL; +    ErtsBinary2TermState b2ts; +    ErtsDistExternal fakedep; + +    fakedep.flags = 0; +    opts = BIF_ARG_2; +    while (is_list(opts)) { +        opt = CAR(list_val(opts)); +        if (opt == am_safe) { +	    fakedep.flags |= ERTS_DIST_EXT_BTT_SAFE; +        } else { +            goto error; +        } +        opts = CDR(list_val(opts)); +    } + +    if (is_not_nil(opts)) +        goto error; + +    if ((bytes = erts_get_aligned_binary_bytes(BIF_ARG_1, &temp_alloc)) == NULL) { +    error: +	erts_free_aligned_binary_bytes(temp_alloc); +	BIF_ERROR(BIF_P, BADARG); +    } +    size = binary_size(BIF_ARG_1); + +    heap_size = binary2term_prepare(&b2ts, bytes, size); +    if (heap_size < 0) +	goto error; + +    hp = HAlloc(BIF_P, heap_size); +    endp = hp + heap_size; + +    res = binary2term_create(&fakedep, &b2ts, &hp, &MSO(BIF_P));      erts_free_aligned_binary_bytes(temp_alloc); @@ -1300,7 +1360,7 @@ dec_atom(ErtsDistExternal *edep, byte* ep, Eterm* objp)      switch (*ep++) {      case ATOM_CACHE_REF: -	if (!(edep->flags & ERTS_DIST_EXT_ATOM_TRANS_TAB)) +	if (!(edep && (edep->flags & ERTS_DIST_EXT_ATOM_TRANS_TAB)))  	    goto error;  	n = get_int8(ep);  	ep++; @@ -1312,13 +1372,18 @@ dec_atom(ErtsDistExternal *edep, byte* ep, Eterm* objp)      case ATOM_EXT:  	len = get_int16(ep),  	ep += 2; -	*objp = am_atom_put((char*)ep, len); -	ep += len; -	break; +        goto dec_atom_common;      case SMALL_ATOM_EXT:  	len = get_int8(ep);  	ep++; -	*objp = am_atom_put((char*)ep, len); +    dec_atom_common: +        if (edep && (edep->flags & ERTS_DIST_EXT_BTT_SAFE)) { +	    if (!erts_atom_get((char*)ep, len, objp)) { +                goto error; +	    } +        } else { +            *objp = am_atom_put((char*)ep, len); +        }  	ep += len;  	break;      default: @@ -1864,13 +1929,18 @@ dec_term(ErtsDistExternal *edep, Eterm** hpp, byte* ep, ErlOffHeap* off_heap, Et  	case ATOM_EXT:  	    n = get_int16(ep);  	    ep += 2; -	    *objp = am_atom_put((char*)ep, n); -	    ep += n; -	    break; +            goto dec_term_atom_common;  	case SMALL_ATOM_EXT:  	    n = get_int8(ep);  	    ep++; -	    *objp = am_atom_put((char*)ep, n); +dec_term_atom_common: +	    if (edep && (edep->flags & ERTS_DIST_EXT_BTT_SAFE)) { +		if (!erts_atom_get((char*)ep, n, objp)) { +		    goto error; +		} +	    } else { +	        *objp = am_atom_put((char*)ep, n); +	    }  	    ep += n;  	    break;  	case LARGE_TUPLE_EXT: @@ -2039,7 +2109,6 @@ dec_term(ErtsDistExternal *edep, Eterm** hpp, byte* ep, ErlOffHeap* off_heap, Et  		goto ref_ext_common;  	    case NEW_REFERENCE_EXT: -  		ref_words = get_int16(ep);  		ep += 2; @@ -2218,6 +2287,10 @@ dec_term(ErtsDistExternal *edep, Eterm** hpp, byte* ep, ErlOffHeap* off_heap, Et  		if (arity < 0) {  		    goto error;  		} +		if (edep && (edep->flags & ERTS_DIST_EXT_BTT_SAFE)) { +		    if (!erts_find_export_entry(mod, name, arity)) +			goto error; +                }  		*objp = make_export(hp);  		*hp++ = HEADER_EXPORT;  		*hp++ = (Eterm) erts_export_get_or_make_stub(mod, name, arity); diff --git a/erts/emulator/beam/external.h b/erts/emulator/beam/external.h index f308680f89..eada6d4f27 100644 --- a/erts/emulator/beam/external.h +++ b/erts/emulator/beam/external.h @@ -1,19 +1,19 @@  /*   * %CopyrightBegin% - *  - * Copyright Ericsson AB 1996-2009. All Rights Reserved. - *  + * + * Copyright Ericsson AB 1996-2010. All Rights Reserved. + *   * The contents of this file are subject to the Erlang Public License,   * Version 1.1, (the "License"); you may not use this file except in   * compliance with the License. You should have received a copy of the   * Erlang Public License along with this software. If not, it can be   * retrieved online at http://www.erlang.org/. - *  + *   * Software distributed under the License is distributed on an "AS IS"   * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See   * the License for the specific language governing rights and limitations   * under the License. - *  + *   * %CopyrightEnd%   */ @@ -98,9 +98,19 @@ typedef struct {      Eterm atom[ERTS_ATOM_CACHE_SIZE];  } ErtsAtomTranslationTable; -#define ERTS_DIST_EXT_DFLAG_HDR (((Uint32) 1) << 31) -#define ERTS_DIST_EXT_ATOM_TRANS_TAB (((Uint32) 1) << 30) -#define ERTS_DIST_EXT_CON_ID_MASK ((Uint32) 0x3fffffff) +/* + * These flags are tagged onto the high bits of a connection ID and stored in + * the ErtsDistExternal structure's flags field.  They are used to indicate + * various bits of state necessary to decode binaries in a variety of + * scenarios. The mask ERTS_DIST_EXT_CON_ID_MASK is used later to separate the + * connection ID from the flags. Be careful to ensure that the mask does not + * overlap any of the bits used for flags, or ERTS will leak flags bits into + * connection IDs and leak connection ID bits into the flags. + */ +#define ERTS_DIST_EXT_DFLAG_HDR      ((Uint32) 0x80000000) +#define ERTS_DIST_EXT_ATOM_TRANS_TAB ((Uint32) 0x40000000) +#define ERTS_DIST_EXT_BTT_SAFE       ((Uint32) 0x20000000) +#define ERTS_DIST_EXT_CON_ID_MASK    ((Uint32) 0x1fffffff)  #define ERTS_DIST_EXT_CON_ID(DIST_EXTP) \    ((DIST_EXTP)->flags & ERTS_DIST_EXT_CON_ID_MASK) diff --git a/erts/emulator/test/binary_SUITE.erl b/erts/emulator/test/binary_SUITE.erl index e47dfa18f7..44b6bbe785 100644 --- a/erts/emulator/test/binary_SUITE.erl +++ b/erts/emulator/test/binary_SUITE.erl @@ -1,19 +1,19 @@  %%  %% %CopyrightBegin% -%%  -%% Copyright Ericsson AB 1997-2009. All Rights Reserved. -%%  +%% +%% Copyright Ericsson AB 1997-2010. All Rights Reserved. +%%  %% The contents of this file are subject to the Erlang Public License,  %% Version 1.1, (the "License"); you may not use this file except in  %% compliance with the License. You should have received a copy of the  %% Erlang Public License along with this software. If not, it can be  %% retrieved online at http://www.erlang.org/. -%%  +%%  %% Software distributed under the License is distributed on an "AS IS"  %% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  %% the License for the specific language governing rights and limitations  %% under the License. -%%  +%%  %% %CopyrightEnd%  %% @@ -27,6 +27,7 @@  %%	binary_to_list/1  %%	binary_to_list/3  %%	binary_to_term/1 +%%  	binary_to_term/2  %%      bitstr_to_list/1  %%	term_to_binary/1  %%      erlang:external_size/1 @@ -49,7 +50,7 @@  	 t_hash/1,  	 bad_size/1,  	 bad_term_to_binary/1, -	 bad_binary_to_term_2/1, +	 bad_binary_to_term_2/1,safe_binary_to_term2/1,  	 bad_binary_to_term/1, bad_terms/1, more_bad_terms/1,  	 otp_5484/1,otp_5933/1,  	 ordering/1,unaligned_order/1,gc_test/1, @@ -66,7 +67,7 @@ all(suite) ->       t_split_binary, bad_split, t_concat_binary,       bad_list_to_binary, bad_binary_to_list, terms, terms_float,       external_size, t_iolist_size, -     bad_binary_to_term_2, +     bad_binary_to_term_2,safe_binary_to_term2,       bad_binary_to_term, bad_terms, t_hash, bad_size, bad_term_to_binary,       more_bad_terms, otp_5484, otp_5933, ordering, unaligned_order,       gc_test, bit_sized_binary_sizes, bitlevel_roundtrip, otp_6817, otp_8117, @@ -438,8 +439,11 @@ terms(Config) when is_list(Config) ->  			      ok  		      end,  		      Term = binary_to_term(Bin), +		      Term = erlang:binary_to_term(Bin, [safe]),  		      Unaligned = make_unaligned_sub_binary(Bin),  		      Term = binary_to_term(Unaligned), +		      Term = erlang:binary_to_term(Unaligned, []), +		      Term = erlang:binary_to_term(Bin, [safe]),  		      BinC = erlang:term_to_binary(Term, [compressed]),  		      Term = binary_to_term(BinC),  		      true = size(BinC) =< size(Bin), @@ -538,6 +542,23 @@ bad_binary_to_term(Config) when is_list(Config) ->  bad_bin_to_term(BadBin) ->      {'EXIT',{badarg,_}} = (catch binary_to_term(BadBin)). +bad_bin_to_term(BadBin,Opts) -> +    {'EXIT',{badarg,_}} = (catch erlang:binary_to_term(BadBin,Opts)). + +safe_binary_to_term2(doc) -> "Test safety options for binary_to_term/2"; +safe_binary_to_term2(Config) when is_list(Config) -> +    ?line bad_bin_to_term(<<131,100,0,14,"undefined_atom">>, [safe]), +    ?line bad_bin_to_term(<<131,100,0,14,"other_bad_atom">>, [safe]), +    BadHostAtom = <<100,0,14,"badguy@badhost">>, +    Empty = <<0,0,0,0>>, +    BadRef = <<131,114,0,3,BadHostAtom/binary,0,<<0,0,0,255>>/binary, +	      Empty/binary,Empty/binary>>, +    ?line bad_bin_to_term(BadRef, [safe]), % good ref, with a bad atom +    ?line fullsweep_after = erlang:binary_to_term(<<131,100,0,15,"fullsweep_after">>, [safe]), % should be a good atom +    BadExtFun = <<131,113,100,0,4,98,108,117,101,100,0,4,109,111,111,110,97,3>>, +    ?line bad_bin_to_term(BadExtFun, [safe]), +    ok. +  %% Tests bad input to binary_to_term/1.  bad_terms(suite) -> []; diff --git a/lib/stdlib/src/Makefile b/lib/stdlib/src/Makefile index 9c4110231e..37c836a254 100644 --- a/lib/stdlib/src/Makefile +++ b/lib/stdlib/src/Makefile @@ -1,19 +1,19 @@  #  # %CopyrightBegin% -#  -# Copyright Ericsson AB 1996-2009. All Rights Reserved. -#  +# +# Copyright Ericsson AB 1996-2010. All Rights Reserved. +#  # The contents of this file are subject to the Erlang Public License,  # Version 1.1, (the "License"); you may not use this file except in  # compliance with the License. You should have received a copy of the  # Erlang Public License along with this software. If not, it can be  # retrieved online at http://www.erlang.org/. -#  +#  # Software distributed under the License is distributed on an "AS IS"  # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  # the License for the specific language governing rights and limitations  # under the License. -#  +#  # %CopyrightEnd%  # @@ -1,20 +1,20 @@  #! /bin/sh  #  # %CopyrightBegin% -#  -# Copyright Ericsson AB 2002-2009. All Rights Reserved. -#  +# +# Copyright Ericsson AB 2002-2010. All Rights Reserved. +#  # The contents of this file are subject to the Erlang Public License,  # Version 1.1, (the "License"); you may not use this file except in  # compliance with the License. You should have received a copy of the  # Erlang Public License along with this software. If not, it can be  # retrieved online at http://www.erlang.org/. -#  +#  # Software distributed under the License is distributed on an "AS IS"  # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See  # the License for the specific language governing rights and limitations  # under the License. -#  +#  # %CopyrightEnd%  # | 
