SharpodInclient est une bibliothèque .NET qui permet aux applications .NET de communiquer avec les appareils Android Samsung en mode téléchargement.
Un client approprié pour Flash (image, tar.md5, lz4), obtenant des informations et implémentation d'autres fonctionnalités.
Il fournit une implémentation .NET du protocole Odin.
La communication USB dans Sharpodinclient est Serialport.
Ajoutez d'abord des espaces de noms de SharpodInclient sur votre projet
using SharpOdinClient.structs;
using SharpOdinClient.util;
private Odin Odin = new Odin();
public MainWindow()
{
InitializeComponent();
Odin.Log += Odin_Log;
Odin.ProgressChanged += Odin_ProgressChanged;
}
private void Odin_ProgressChanged(string filename, long max, long value, long WritenSize)
{
}
private void Odin_Log(string Text, SharpOdinClient.util.utils.MsgType Color)
{
}
Événement ProgressChanged
Nom de fichier: nom de fichier du clignotement sur l'appareil
Max: taille du fichier
Valeur: taille du fichier à combler
Événement en journal
Texte: journal texte
Couleur: Couleur du journal
{
//Find Auto odin device
var device = await Odin.FindDownloadModePort();
//device name
Console.WriteLine(device.Name);
// COM Port Of device
Console.WriteLine(device.COM);
// VID and PID Of Device
Console.WriteLine(device.VID);
Console.WriteLine(device.PID);
}
{
if(await Odin.FindAndSetDownloadMode())
{
//get info from device
var info = await Odin.DVIF();
await Odin.PrintInfo();
}
}
Dans la variable info nous obtenons le dictionnaire de string , string le concept de certaines «clés»
capa = CAPA Numéroproduct = ID de produitmodel = numéro de modèlefwver = version du firmwarevendor = vendeursales = code de ventever = Numéro de constructiondid = a fait le nombreun = ID uniquetmu_temp = Numéro TMUprov = provision {
if(await Odin.FindAndSetDownloadMode())
{
await Odin.PrintInfo();
if (await Odin.IsOdin())
{
if(await Odin.LOKE_Initialize(0))
{
var Pit = await Odin.Read_Pit();
if (Pit.Result)
{
var buffer = Pit.data;
var entry = Pit.Pit;
}
}
}
}
}
Pour faire n'importe quelle action en mode téléchargement, il faut d'abord vérifier IsOdin et exécuter l'argument LOKE_Initialize , si vous ne voulez rien écrire sur le paramètre LOKE_Initialize totalfilesize sur zéro (0)
buffer = Is Byte Array of Fit à partir de l'appareil, vous pouvez écrire ce tampon dans le fichier pour enregistrer entry des pits = IS Liste des informations de partition de votre appareil
/// <summary>
/// write pit file on your device
/// </summary>
/// <param name="pit">in this parameter, you can set tar.md5 contains have pit file(Like csc package of firmware)
/// or pit file with .pit format
/// </param>
/// <returns>true if success</returns>
public async Task<bool> Write_Pit(string pit)
{
if (await Odin.FindAndSetDownloadMode())
{
await Odin.PrintInfo();
if (await Odin.IsOdin())
{
if (await Odin.LOKE_Initialize(0))
{
var Pit = await Odin.Write_Pit(pit);
return Pit.status;
}
}
}
return false;
}
pit = Si vous souhaitez écrire Pit à partir de TAR ou TAR.MD5 (comme CSC) Fichier sur l'appareil, vous pouvez définir votre chemin de fichier de type TAR, vous pouvez également définir votre fichier unique Pit avec un fichier de format. /// Add List Of Your tar package (bl,ap,cp,csc , or more)
/// </summary>
/// <param name="ListOfTarFile">add tar type files path in this list</param>
/// <returns></returns>
public async Task<bool> FlashFirmware(List<string> ListOfTarFile)
{
var FlashFile = new List<FileFlash>();
foreach(var i in ListOfTarFile)
{
var item = Odin.tar.TarInformation(i);
if(item.Count > 0)
{
foreach (var Tiem in item)
{
if (!Exist(Tiem , FlashFile))
{
var Extension = System.IO.Path.GetExtension(Tiem.Filename);
var file = new FileFlash
{
Enable = true,
FileName = Tiem.Filename,
FilePath = i
};
if (Extension == ".pit")
{
//File Contains have pit
}
else if (Extension == ".lz4")
{
file.RawSize = Odin.CalculateLz4SizeFromTar(i, Tiem.Filename);
}
else
{
file.RawSize = Tiem.Filesize;
}
FlashFile.Add(file);
}
}
}
}
if(FlashFile.Count > 0)
{
var Size = 0L;
foreach (var item in FlashFile)
{
Size += item.RawSize;
}
if (await Odin.FindAndSetDownloadMode())
{
await Odin.PrintInfo();
if (await Odin.IsOdin())
{
if (await Odin.LOKE_Initialize(Size))
{
var findPit = FlashFile.Find(x => x.FileName.ToLower().EndsWith(".pit"));
if(findPit != null)
{
var res = MessageBox.Show("Pit Finded on your tar package , you want to repartition?", "", MessageBoxButton.YesNo);
if (res == MessageBoxResult.Yes)
{
var Pit = await Odin.Write_Pit(findPit.FilePath);
}
}
var ReadPit = await Odin.Read_Pit();
if (ReadPit.Result)
{
var EfsClearInt = 0;
var BootUpdateInt = 1;
if (await Odin.FlashFirmware(FlashFile, ReadPit.Pit, EfsClearInt, BootUpdateInt, true))
{
if (await Odin.PDAToNormal())
{
return true;
}
}
}
}
}
}
}
return false;
}
Pour clignoter TAR, TAR.MD5 contient des fichiers (LZ4, Image, Bin et plus ...), nous devons créer une liste de FileFlash à partir des informations du package TAR.
Enable la propriété dans FileFlash est bool si vous définissez cette proposition sur False, SharpodInclient ne clignote pas sur le téléphone.
Dans FlashFirmware Fonction, SharpodIncLIENT peut écrire LZ4 à partir de CONTANT OF TOT TAR Package
Vous pouvez flasher votre fichier unique comme boot.img ou plus de fichiers sur les partitions
/// <summary>
/// Flash Single File lz4 , image
/// </summary>
/// <param name="FilePath">path of your file</param>
/// <param name="PartitionFileName">like boot.img , sboot.bin or more ...</param>
/// <returns></returns>
public async Task<bool> FlashSingleFile(string FilePath , string PartitionFileName)
{
var FlashFile = new FileFlash
{
Enable = true,
FileName = PartitionFileName,
FilePath = FilePath,
RawSize = new FileInfo(FilePath).Length
};
if (await Odin.FindAndSetDownloadMode())
{
await Odin.PrintInfo();
if (await Odin.IsOdin())
{
if (await Odin.LOKE_Initialize(FlashFile.RawSize))
{
var ReadPit = await Odin.Read_Pit();
if (ReadPit.Result)
{
var EfsClearInt = 0;
var BootUpdateInt = 0;
if (await Odin.FlashSingleFile(FlashFile, ReadPit.Pit, EfsClearInt, BootUpdateInt, true))
{
if (await Odin.PDAToNormal())
{
return true;
}
}
}
}
}
}
return false;
}