* grub-core/kern/err.c (GRUB_MAX_ERRMSG): Move to ...

* include/grub/err.h (GRUB_MAX_ERRMSG): ... here.
	* include/grub/err.h (grub_error_saved): New struct.
	(grub_errmsg): Make array size explicit.
	* include/grub/misc.h (grub_error_save): New function.
	(grub_error_load): Likewise.
	* grub-core/kern/err.c (grub_error_stack_items): Use grub_error_saved.
	(grub_error_push): Update `errno' member name.
	(grub_error_pop): Likewise
	* grub-core/net/tftp.c (tftp_data): New member save_err.
	(tftp_receive): Save error.
	(tftp_open): Restore error.
This commit is contained in:
Vladimir 'phcoder' Serbinenko 2012-02-05 10:24:53 +01:00
parent a51dab1328
commit aca002f7e4
5 changed files with 54 additions and 11 deletions

View file

@ -1,3 +1,18 @@
2012-02-05 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/kern/err.c (GRUB_MAX_ERRMSG): Move to ...
* include/grub/err.h (GRUB_MAX_ERRMSG): ... here.
* include/grub/err.h (grub_error_saved): New struct.
(grub_errmsg): Make array size explicit.
* include/grub/misc.h (grub_error_save): New function.
(grub_error_load): Likewise.
* grub-core/kern/err.c (grub_error_stack_items): Use grub_error_saved.
(grub_error_push): Update `errno' member name.
(grub_error_pop): Likewise
* grub-core/net/tftp.c (tftp_data): New member save_err.
(tftp_receive): Save error.
(tftp_open): Restore error.
2012-02-05 Vladimir Serbinenko <phcoder@gmail.com> 2012-02-05 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/lib/i386/relocator16.S (grub_relocator16_start): Move switch * grub-core/lib/i386/relocator16.S (grub_relocator16_start): Move switch

View file

@ -22,18 +22,13 @@
#include <stdarg.h> #include <stdarg.h>
#include <grub/i18n.h> #include <grub/i18n.h>
#define GRUB_MAX_ERRMSG 256
#define GRUB_ERROR_STACK_SIZE 10 #define GRUB_ERROR_STACK_SIZE 10
grub_err_t grub_errno; grub_err_t grub_errno;
char grub_errmsg[GRUB_MAX_ERRMSG]; char grub_errmsg[GRUB_MAX_ERRMSG];
int grub_err_printed_errors; int grub_err_printed_errors;
static struct static struct grub_error_saved grub_error_stack_items[GRUB_ERROR_STACK_SIZE];
{
grub_err_t errno;
char errmsg[GRUB_MAX_ERRMSG];
} grub_error_stack_items[GRUB_ERROR_STACK_SIZE];
static int grub_error_stack_pos; static int grub_error_stack_pos;
static int grub_error_stack_assert; static int grub_error_stack_assert;
@ -71,7 +66,7 @@ grub_error_push (void)
if (grub_error_stack_pos < GRUB_ERROR_STACK_SIZE) if (grub_error_stack_pos < GRUB_ERROR_STACK_SIZE)
{ {
/* Copy active error message to stack. */ /* Copy active error message to stack. */
grub_error_stack_items[grub_error_stack_pos].errno = grub_errno; grub_error_stack_items[grub_error_stack_pos].grub_errno = grub_errno;
grub_memcpy (grub_error_stack_items[grub_error_stack_pos].errmsg, grub_memcpy (grub_error_stack_items[grub_error_stack_pos].errmsg,
grub_errmsg, grub_errmsg,
sizeof (grub_errmsg)); sizeof (grub_errmsg));
@ -99,7 +94,7 @@ grub_error_pop (void)
/* Pop error message from error stack to current active error. */ /* Pop error message from error stack to current active error. */
grub_error_stack_pos--; grub_error_stack_pos--;
grub_errno = grub_error_stack_items[grub_error_stack_pos].errno; grub_errno = grub_error_stack_items[grub_error_stack_pos].grub_errno;
grub_memcpy (grub_errmsg, grub_memcpy (grub_errmsg,
grub_error_stack_items[grub_error_stack_pos].errmsg, grub_error_stack_items[grub_error_stack_pos].errmsg,
sizeof (grub_errmsg)); sizeof (grub_errmsg));

View file

@ -102,6 +102,7 @@ typedef struct tftp_data
grub_uint64_t block; grub_uint64_t block;
grub_uint32_t block_size; grub_uint32_t block_size;
int have_oack; int have_oack;
struct grub_error_saved save_err;
grub_net_udp_socket_t sock; grub_net_udp_socket_t sock;
grub_priority_queue_t pq; grub_priority_queue_t pq;
} *tftp_data_t; } *tftp_data_t;
@ -181,6 +182,7 @@ tftp_receive (grub_net_udp_socket_t sock __attribute__ ((unused)),
data->block = 0; data->block = 0;
grub_netbuff_free (nb); grub_netbuff_free (nb);
err = ack (data->sock, 0); err = ack (data->sock, 0);
grub_error_save (&data->save_err);
if (err) if (err)
return err; return err;
return GRUB_ERR_NONE; return GRUB_ERR_NONE;
@ -246,8 +248,11 @@ tftp_receive (grub_net_udp_socket_t sock __attribute__ ((unused)),
} }
return GRUB_ERR_NONE; return GRUB_ERR_NONE;
case TFTP_ERROR: case TFTP_ERROR:
data->have_oack = 1;
grub_netbuff_free (nb); grub_netbuff_free (nb);
return grub_error (GRUB_ERR_IO, (char *) tftph->u.err.errmsg); grub_error (GRUB_ERR_IO, (char *) tftph->u.err.errmsg);
grub_error_save (&data->save_err);
return GRUB_ERR_NONE;
default: default:
grub_netbuff_free (nb); grub_netbuff_free (nb);
return GRUB_ERR_NONE; return GRUB_ERR_NONE;
@ -368,11 +373,16 @@ tftp_open (struct grub_file *file, const char *filename)
} }
if (!data->have_oack) if (!data->have_oack)
grub_error (GRUB_ERR_TIMEOUT, "Time out opening tftp.");
else
grub_error_load (&data->save_err);
if (grub_errno)
{ {
grub_net_udp_close (data->sock); grub_net_udp_close (data->sock);
destroy_pq (data); destroy_pq (data);
return grub_error (GRUB_ERR_TIMEOUT, "Time out opening tftp."); return grub_errno;
} }
file->size = data->file_size; file->size = data->file_size;
return GRUB_ERR_NONE; return GRUB_ERR_NONE;

View file

@ -22,6 +22,8 @@
#include <grub/symbol.h> #include <grub/symbol.h>
#define GRUB_MAX_ERRMSG 256
typedef enum typedef enum
{ {
GRUB_ERR_NONE = 0, GRUB_ERR_NONE = 0,
@ -70,8 +72,14 @@ typedef enum
} }
grub_err_t; grub_err_t;
struct grub_error_saved
{
grub_err_t grub_errno;
char errmsg[GRUB_MAX_ERRMSG];
};
extern grub_err_t EXPORT_VAR(grub_errno); extern grub_err_t EXPORT_VAR(grub_errno);
extern char EXPORT_VAR(grub_errmsg)[]; extern char EXPORT_VAR(grub_errmsg)[GRUB_MAX_ERRMSG];
grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *fmt, ...); grub_err_t EXPORT_FUNC(grub_error) (grub_err_t n, const char *fmt, ...);
void EXPORT_FUNC(grub_fatal) (const char *fmt, ...) __attribute__ ((noreturn)); void EXPORT_FUNC(grub_fatal) (const char *fmt, ...) __attribute__ ((noreturn));

View file

@ -424,4 +424,19 @@ extern int EXPORT_VAR(grub_no_autoload);
#define grub_no_autoload 0 #define grub_no_autoload 0
#endif #endif
static inline void
grub_error_save (struct grub_error_saved *save)
{
grub_memcpy (save->errmsg, grub_errmsg, sizeof (save->errmsg));
save->grub_errno = grub_errno;
save->grub_errno = GRUB_ERR_NONE;
}
static inline void
grub_error_load (const struct grub_error_saved *save)
{
grub_memcpy (grub_errmsg, save->errmsg, sizeof (grub_errmsg));
grub_errno = save->grub_errno;
}
#endif /* ! GRUB_MISC_HEADER */ #endif /* ! GRUB_MISC_HEADER */