errmsg("parameter \"%s\" cannot be changed",
                             name)));
 
+       /*
+        * If a value is specified, verify that it's sane.
+        */
        if (value)
        {
            union config_var_val newval;
            void       *newextra = NULL;
 
+           /* Check that it's acceptable for the indicated parameter */
            if (!parse_and_validate_value(record, name, value,
                                          PGC_S_FILE, ERROR,
                                          &newval, &newextra))
                ereport(ERROR,
-                       (errmsg("invalid value for parameter \"%s\": \"%s\"",
+                       (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
+                        errmsg("invalid value for parameter \"%s\": \"%s\"",
                                name, value)));
 
            if (record->vartype == PGC_STRING && newval.stringval != NULL)
                free(newval.stringval);
            if (newextra)
                free(newextra);
+
+           /*
+            * We must also reject values containing newlines, because the
+            * grammar for config files doesn't support embedded newlines in
+            * string literals.
+            */
+           if (strchr(value, '\n'))
+               ereport(ERROR,
+                       (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
+                        errmsg("parameter value for ALTER SYSTEM must not contain a newline")));
        }
    }
 
            infile = AllocateFile(AutoConfFileName, "r");
            if (infile == NULL)
                ereport(ERROR,
-                       (errmsg("could not open file \"%s\": %m",
+                       (errcode_for_file_access(),
+                        errmsg("could not open file \"%s\": %m",
                                AutoConfFileName)));
 
            /* parse it */
            if (!ParseConfigFp(infile, AutoConfFileName, 0, LOG, &head, &tail))
                ereport(ERROR,
-                       (errmsg("could not parse contents of file \"%s\"",
+                       (errcode(ERRCODE_CONFIG_FILE_ERROR),
+                        errmsg("could not parse contents of file \"%s\"",
                                AutoConfFileName)));
 
            FreeFile(infile);