forked from mirrors/linux
		
	The i915 DRM driver very cleverly used ascii85 encoding for their GPU state file. Move the encode functions to a general header file to support other drivers that might be interested in the same functionality. v4: Make the return value const char * as suggested by Chris Wilson v3: Fix error_puts -> err_puts pointed out by the 01.org bot v2: Update API to be cleaner for the caller as suggested by Chris Wilson Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org> Signed-off-by: Rob Clark <robdclark@gmail.com>
		
			
				
	
	
		
			38 lines
		
	
	
	
		
			532 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
	
		
			532 B
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * SPDX-License-Identifier: GPL-2.0
 | 
						|
 *
 | 
						|
 * Copyright (c) 2008 Intel Corporation
 | 
						|
 * Copyright (c) 2018 The Linux Foundation. All rights reserved.
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef _ASCII85_H_
 | 
						|
#define _ASCII85_H_
 | 
						|
 | 
						|
#include <linux/kernel.h>
 | 
						|
 | 
						|
#define ASCII85_BUFSZ 6
 | 
						|
 | 
						|
static inline long
 | 
						|
ascii85_encode_len(long len)
 | 
						|
{
 | 
						|
	return DIV_ROUND_UP(len, 4);
 | 
						|
}
 | 
						|
 | 
						|
static inline const char *
 | 
						|
ascii85_encode(u32 in, char *out)
 | 
						|
{
 | 
						|
	int i;
 | 
						|
 | 
						|
	if (in == 0)
 | 
						|
		return "z";
 | 
						|
 | 
						|
	out[5] = '\0';
 | 
						|
	for (i = 5; i--; ) {
 | 
						|
		out[i] = '!' + in % 85;
 | 
						|
		in /= 85;
 | 
						|
	}
 | 
						|
 | 
						|
	return out;
 | 
						|
}
 | 
						|
 | 
						|
#endif
 |