2007-09-07 Robert Millan <rmh@aybabtu.com>
* kern/powerpc/ieee1275/cmain.c (grub_ieee1275_test_flag): Detect SmartFirmware version updates (as released by Sven Luther), and avoid setting GRUB_IEEE1275_FLAG_NO_PARTITION_0 or GRUB_IEEE1275_FLAG_0_BASED_PARTITIONS unless the running version is known broken.
This commit is contained in:
		
							parent
							
								
									5618afbf59
								
							
						
					
					
						commit
						6b5d80fa11
					
				
					 2 changed files with 46 additions and 5 deletions
				
			
		|  | @ -1,3 +1,11 @@ | ||||||
|  | 2007-09-07  Robert Millan  <rmh@aybabtu.com> | ||||||
|  | 
 | ||||||
|  | 	* kern/powerpc/ieee1275/cmain.c (grub_ieee1275_test_flag): Detect | ||||||
|  | 	SmartFirmware version updates (as released by Sven Luther), and avoid | ||||||
|  | 	setting GRUB_IEEE1275_FLAG_NO_PARTITION_0 or | ||||||
|  | 	GRUB_IEEE1275_FLAG_0_BASED_PARTITIONS unless the running version is | ||||||
|  | 	known broken. | ||||||
|  | 
 | ||||||
| 2007-09-03  Yoshinori K. Okuji  <okuji@enbug.org> | 2007-09-03  Yoshinori K. Okuji  <okuji@enbug.org> | ||||||
| 
 | 
 | ||||||
| 	From Hitoshi Ozeki: | 	From Hitoshi Ozeki: | ||||||
|  |  | ||||||
|  | @ -30,9 +30,9 @@ int (*grub_ieee1275_entry_fn) (void *); | ||||||
| grub_ieee1275_phandle_t grub_ieee1275_chosen; | grub_ieee1275_phandle_t grub_ieee1275_chosen; | ||||||
| 
 | 
 | ||||||
| static grub_uint32_t grub_ieee1275_flags; | static grub_uint32_t grub_ieee1275_flags; | ||||||
| 
 |  | ||||||
|  |  | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| int | int | ||||||
| grub_ieee1275_test_flag (enum grub_ieee1275_flag flag) | grub_ieee1275_test_flag (enum grub_ieee1275_flag flag) | ||||||
| { | { | ||||||
|  | @ -52,6 +52,8 @@ grub_ieee1275_find_options (void) | ||||||
|   grub_ieee1275_phandle_t openprom; |   grub_ieee1275_phandle_t openprom; | ||||||
|   int rc; |   int rc; | ||||||
|   int realmode = 0; |   int realmode = 0; | ||||||
|  |   char tmp[32]; | ||||||
|  |   int is_smartfirmware = 0; | ||||||
| 
 | 
 | ||||||
|   grub_ieee1275_finddevice ("/options", &options); |   grub_ieee1275_finddevice ("/options", &options); | ||||||
|   rc = grub_ieee1275_get_property (options, "real-mode?", &realmode, |   rc = grub_ieee1275_get_property (options, "real-mode?", &realmode, | ||||||
|  | @ -60,12 +62,43 @@ grub_ieee1275_find_options (void) | ||||||
|     grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_REAL_MODE); |     grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_REAL_MODE); | ||||||
| 
 | 
 | ||||||
|   grub_ieee1275_finddevice ("/openprom", &openprom); |   grub_ieee1275_finddevice ("/openprom", &openprom); | ||||||
|   rc = grub_ieee1275_get_property (openprom, "SmartFirmware-version", 0, 0, 0); | 
 | ||||||
|   if (rc >= 0) |   rc = grub_ieee1275_get_property (openprom, "CodeGen-copyright", | ||||||
|  | 				   tmp,	sizeof (tmp), 0); | ||||||
|  | #define SF "SmartFirmware(tm)" | ||||||
|  |   if (rc >= 0 && !grub_strncmp (tmp, SF, sizeof (SF) - 1)) | ||||||
|  |     is_smartfirmware = 1; | ||||||
|  | 
 | ||||||
|  |   if (is_smartfirmware) | ||||||
|     { |     { | ||||||
|       grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_NO_PARTITION_0); |       /* Broken in all versions */ | ||||||
|       grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_0_BASED_PARTITIONS); |  | ||||||
|       grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_BROKEN_OUTPUT); |       grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_BROKEN_OUTPUT); | ||||||
|  | 
 | ||||||
|  |       /* There are two incompatible ways of checking the version number.  Try
 | ||||||
|  |          both. */ | ||||||
|  |       rc = grub_ieee1275_get_property (openprom, "SmartFirmware-version", | ||||||
|  | 				       tmp, sizeof (tmp), 0); | ||||||
|  |       if (rc < 0) | ||||||
|  | 	rc = grub_ieee1275_get_property (openprom, "firmware-version", | ||||||
|  | 					 tmp, sizeof (tmp), 0); | ||||||
|  |       if (rc >= 0) | ||||||
|  | 	{ | ||||||
|  | 	  /* It is tempting to implement a version parser to set the flags for
 | ||||||
|  | 	     e.g. 1.3 and below.  However, there's a special situation here. | ||||||
|  | 	     3rd party updates which fix the partition bugs are common, and for | ||||||
|  | 	     some reason their fixes aren't being merged into trunk.  So for | ||||||
|  | 	     example we know that 1.2 and 1.3 are broken, but there's 1.2.99 | ||||||
|  | 	     and 1.3.99 which are known good (and appliing this workaround | ||||||
|  | 	     would cause breakage). */ | ||||||
|  | 	  if (!grub_strcmp (tmp, "1.0") | ||||||
|  | 	      || !grub_strcmp (tmp, "1.1") | ||||||
|  | 	      || !grub_strcmp (tmp, "1.2") | ||||||
|  | 	      || !grub_strcmp (tmp, "1.3")) | ||||||
|  | 	    { | ||||||
|  | 	      grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_NO_PARTITION_0); | ||||||
|  | 	      grub_ieee1275_set_flag (GRUB_IEEE1275_FLAG_0_BASED_PARTITIONS); | ||||||
|  | 	    } | ||||||
|  | 	} | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue