|  |  | @@ -149,6 +149,25 @@ static int bmp_decode_frame(AVCodecContext *avctx, | 
		
	
		
			
			|  |  |  | case 16: | 
		
	
		
			
			|  |  |  | if(comp == BMP_RGB) | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = PIX_FMT_RGB555; | 
		
	
		
			
			|  |  |  | if(comp == BMP_BITFIELDS) | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = rgb[1] == 0x07E0 ? PIX_FMT_RGB565 : PIX_FMT_RGB555; | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 8: | 
		
	
		
			
			|  |  |  | if(hsize - ihsize - 14 > 0) | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = PIX_FMT_PAL8; | 
		
	
		
			
			|  |  |  | else | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = PIX_FMT_GRAY8; | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 4: | 
		
	
		
			
			|  |  |  | if(hsize - ihsize - 14 > 0){ | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = PIX_FMT_PAL8; | 
		
	
		
			
			|  |  |  | }else{ | 
		
	
		
			
			|  |  |  | av_log(avctx, AV_LOG_ERROR, "Unknown palette for 16-colour BMP\n"); | 
		
	
		
			
			|  |  |  | return -1; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 1: | 
		
	
		
			
			|  |  |  | avctx->pix_fmt = PIX_FMT_MONOBLACK; | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | default: | 
		
	
		
			
			|  |  |  | av_log(avctx, AV_LOG_ERROR, "depth %d not supported\n", depth); | 
		
	
	
		
			
				|  |  | @@ -183,6 +202,9 @@ static int bmp_decode_frame(AVCodecContext *avctx, | 
		
	
		
			
			|  |  |  | return -1; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if(depth == 4 || depth == 8) | 
		
	
		
			
			|  |  |  | memset(p->data[1], 0, 1024); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if(height > 0){ | 
		
	
		
			
			|  |  |  | ptr = p->data[0] + (avctx->height - 1) * p->linesize[0]; | 
		
	
		
			
			|  |  |  | linesize = -p->linesize[0]; | 
		
	
	
		
			
				|  |  | @@ -191,7 +213,43 @@ static int bmp_decode_frame(AVCodecContext *avctx, | 
		
	
		
			
			|  |  |  | linesize = p->linesize[0]; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if(avctx->pix_fmt == PIX_FMT_PAL8){ | 
		
	
		
			
			|  |  |  | buf = buf0 + 14 + ihsize; //palette location | 
		
	
		
			
			|  |  |  | if((hsize-ihsize-14)>>depth < 4){ // OS/2 bitmap, 3 bytes per palette entry | 
		
	
		
			
			|  |  |  | for(i = 0; i < (1 << depth); i++) | 
		
	
		
			
			|  |  |  | ((uint32_t*)p->data[1])[i] = bytestream_get_le24(&buf); | 
		
	
		
			
			|  |  |  | }else{ | 
		
	
		
			
			|  |  |  | for(i = 0; i < (1 << depth); i++) | 
		
	
		
			
			|  |  |  | ((uint32_t*)p->data[1])[i] = bytestream_get_le32(&buf); | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | buf = buf0 + hsize; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | switch(depth){ | 
		
	
		
			
			|  |  |  | case 1: | 
		
	
		
			
			|  |  |  | for(i = 0; i < avctx->height; i++){ | 
		
	
		
			
			|  |  |  | memcpy(ptr, buf, n); | 
		
	
		
			
			|  |  |  | buf += n; | 
		
	
		
			
			|  |  |  | ptr += linesize; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 4: | 
		
	
		
			
			|  |  |  | for(i = 0; i < avctx->height; i++){ | 
		
	
		
			
			|  |  |  | int j; | 
		
	
		
			
			|  |  |  | for(j = 0; j < n; j++){ | 
		
	
		
			
			|  |  |  | ptr[j*2+0] = (buf[j] >> 4) & 0xF; | 
		
	
		
			
			|  |  |  | ptr[j*2+1] = buf[j] & 0xF; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | buf += n; | 
		
	
		
			
			|  |  |  | ptr += linesize; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 8: | 
		
	
		
			
			|  |  |  | for(i = 0; i < avctx->height; i++){ | 
		
	
		
			
			|  |  |  | memcpy(ptr, buf, avctx->width); | 
		
	
		
			
			|  |  |  | buf += n; | 
		
	
		
			
			|  |  |  | ptr += linesize; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | break; | 
		
	
		
			
			|  |  |  | case 24: | 
		
	
		
			
			|  |  |  | for(i = 0; i < avctx->height; i++){ | 
		
	
		
			
			|  |  |  | memcpy(ptr, buf, avctx->width*(depth>>3)); | 
		
	
	
		
			
				|  |  | 
 |