diff --git a/CHANGES b/CHANGES
index b2651d8c93148f91b962f58981b27a0fecfd29cd..5e3ff81bb20c3668d8e6fcb97cc17fcd093d8db6 100644
--- a/CHANGES
+++ b/CHANGES
@@ -103,6 +103,8 @@ Applications
    variable, AVAILCAUSECODE, instead of overwriting the device state in AVAILSTATUS.
  * Added 'd' option to app_followme.  This option disables the "Please hold"
    announcement.
+ * Added 'y' option to app_record. This option enables a mode where any DTMF digit
+   received will terminate recording.
 
 Dialplan Functions
 ------------------
diff --git a/apps/app_record.c b/apps/app_record.c
index ce4181d6a19f105c2856e201ef059cca91d57e19..14b665d3071b42610148c4c374d3db329872cd04 100644
--- a/apps/app_record.c
+++ b/apps/app_record.c
@@ -77,7 +77,10 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 					</option>
 					<option name="k">
 					        <para>Keep recording if channel hangs up.</para>
-					</option>	
+					</option>
+					<option name="y">
+					        <para>Terminate recording if *any* DTMF digit is received.</para>
+					</option>
 				</optionlist>
 			</parameter>
 		</syntax>
@@ -117,6 +120,7 @@ enum {
 	OPTION_IGNORE_TERMINATE = (1 << 5),
 	OPTION_KEEP = (1 << 6),
 	FLAG_HAS_PERCENT = (1 << 7),
+	OPTION_ANY_TERMINATE = (1 << 8),
 };
 
 AST_APP_OPTIONS(app_opts,{
@@ -126,6 +130,7 @@ AST_APP_OPTIONS(app_opts,{
 	AST_APP_OPTION('q', OPTION_QUIET),
 	AST_APP_OPTION('s', OPTION_SKIP),
 	AST_APP_OPTION('t', OPTION_STAR_TERMINATE),
+	AST_APP_OPTION('y', OPTION_ANY_TERMINATE),
 	AST_APP_OPTION('x', OPTION_IGNORE_TERMINATE),
 });
 
@@ -372,7 +377,8 @@ static int record_exec(struct ast_channel *chan, const char *data)
 				break;
 			}
 		} else if ((f->frametype == AST_FRAME_DTMF) &&
-		    (f->subclass.integer == terminator)) {
+			   ((f->subclass.integer == terminator) ||
+			    (ast_test_flag(&flags, OPTION_ANY_TERMINATE)))) {
 			ast_frfree(f);
 			pbx_builtin_setvar_helper(chan, "RECORD_STATUS", "DTMF");
 			break;