| 
									
										
										
										
											2004-01-25 17:40:34 +00:00
										 |  |  | /* LibTomCrypt, modular cryptographic library -- Tom St Denis
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LibTomCrypt is a library that provides various cryptographic | 
					
						
							|  |  |  |  * algorithms in a highly modular and flexible manner. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The library is free for all purposes without any express | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  |  * guarantee it works. | 
					
						
							| 
									
										
										
										
											2004-01-25 17:40:34 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-04-17 11:37:13 +00:00
										 |  |  |  * Tom St Denis, tomstdenis@gmail.com, http://libtomcrypt.org
 | 
					
						
							| 
									
										
										
										
											2004-01-25 17:40:34 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2004-12-30 23:55:53 +00:00
										 |  |  | #include "tomcrypt.h"
 | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-30 23:55:53 +00:00
										 |  |  | /** 
 | 
					
						
							|  |  |  |    @file pmac_shift_xor.c | 
					
						
							|  |  |  |    PMAC implementation, internal function, by Tom St Denis  | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2003-03-03 00:59:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  | #ifdef PMAC
 | 
					
						
							| 
									
										
										
										
											2003-03-03 00:59:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-30 23:55:53 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |   Internal function.  Performs the state update (adding correct multiple) | 
					
						
							|  |  |  |   @param pmac   The PMAC state. | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  | void pmac_shift_xor(pmac_state *pmac) | 
					
						
							| 
									
										
										
										
											2003-03-03 00:59:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  |    int x, y; | 
					
						
							|  |  |  |    y = pmac_ntz(pmac->block_index++); | 
					
						
							| 
									
										
										
										
											2005-04-17 11:37:13 +00:00
										 |  |  | #ifdef LTC_FAST
 | 
					
						
							|  |  |  |    for (x = 0; x < pmac->block_len; x += sizeof(LTC_FAST_TYPE)) { | 
					
						
							|  |  |  |        *((LTC_FAST_TYPE*)((unsigned char *)pmac->Li + x)) ^= | 
					
						
							|  |  |  |        *((LTC_FAST_TYPE*)((unsigned char *)pmac->Ls[y] + x)); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  |    for (x = 0; x < pmac->block_len; x++) { | 
					
						
							|  |  |  |        pmac->Li[x] ^= pmac->Ls[y][x]; | 
					
						
							|  |  |  |    } | 
					
						
							| 
									
										
										
										
											2005-04-17 11:37:13 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2003-03-03 00:59:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-05-12 20:42:16 +00:00
										 |  |  | #endif
 |